MOON
Server: Apache
System: Linux vps.erhabenn.com.br 3.10.0-1160.119.1.el7.tuxcare.els2.x86_64 #1 SMP Mon Jul 15 12:09:18 UTC 2024 x86_64
User: machen (1008)
PHP: 8.2.31
Disabled: NONE
Upload Files
File: /disk001/machen/public_html/_wildcard_.machen.ai/static/js/main.e977fcd5.chunk.js.map
{"version":3,"sources":["functions/index.js","assets/img/googlePlay-ptBR.png","assets/img/appleStore-ptBR.png","assets/img/default-avatar.png","components/Card/new.js","assets/img/dashboard/Mockup_App_WEB.png","assets/img/dashboard/supportMockup.png","assets/sound/notification.mp3","assets/icons/BrigthAndConnected.js","components/Icon/index.js","assets/icons/Matrix.js","components/Tooltip/html.js","store/actions.js","functions/upload.js","components/Progress/circular.js","components/PlataformContracts/PolicyAndTerms.js","components/PlataformContracts/LicensingAgreement.js","components/ErrorBoundary/index.js","assets/jss/material-dashboard-pro-react/components/buttonStyle.js","components/CustomButtons/Button.js","assets/jss/material-dashboard-pro-react/components/authNavbarStyle.js","components/Navbars/AuthNavbar.js","assets/jss/material-dashboard-pro-react/components/footerStyle.js","components/Footer/Footer.js","assets/jss/material-dashboard-pro-react/components/LightBox.js","components/LightBox/index.js","components/PreLoader/index.js","components/LoaderPage/index.js","assets/jss/material-dashboard-pro-react/components/iconButtonStyle.js","components/CustomButtons/IconButton.js","components/Reactions_V2/index.js","components/MoreMenu/index.js","components/Filter/period.js","components/TextField/index.js","components/Header/card.js","components/CustomButtons/icon.js","assets/jss/material-dashboard-pro-react/components/Mentions-Input.js","assets/jss/material-dashboard-pro-react/components/timelineSending.js","functions/users.js","functions/chat.js","components/Grid/GridContainer.js","components/Grid/GridItem.js","components/Timeline/sending.js","components/Icons/index.js","assets/jss/material-dashboard-pro-react/components/headerWithIcon.js","components/Header/withIcon.js","functions/files.js","components/Navigation/index.js","components/Progress/linear.js","components/Checkbox/index.js","components/User/quick.js","components/User/avatarList.js","assets/jss/material-dashboard-pro-react/components/KPI_change.js","components/KPI/dataSave.js","components/User/select.js","components/Timer/timer.js","components/Card/Card.css.js","components/Card/FakeExpanded.js","functions/kanban.js","components/Checklist/Card.js","components/Switch/index.js","components/Quick/functions.js","components/Quick/card.js","components/Checklist/index.js","components/ConnectedIn/index.js","components/PopperMenu/index.js","components/KPI/change.js","assets/jss/material-dashboard-pro-react/components/Card-SWOT.js","components/Card/SWOT.js","assets/jss/material-dashboard-pro-react/components/Card.js","components/Card/cardExpanded.js","components/Cropper/Cropper.css.js","components/Cropper/index.js","components/Card/useTemplate.js","components/Card/index.js","components/Badge/user.js","assets/jss/material-dashboard-pro-react/components/timelineStyle.js","assets/jss/material-dashboard-pro-react/components/customDropdownStyle.js","components/CustomDropdown/CustomDropdown.js","variables/general.js","components/Timeline/message.js","components/MiroBoard/index.js","components/SideModule/closeAndSave.js","components/SideModule/sideModule.css.js","components/Timeline/Messages.css.js","components/Timeline/newMessages.js","assets/jss/material-dashboard-pro-react/views/search.js","components/Timeline/Search/messages.js","components/Timeline/Search/index.js","components/Timeline/messages.js","components/Timeline/index.js","components/AutoComplete/index.js","components/Chip/index.js","components/TextField/dark.js","assets/jss/material-dashboard-pro-react/components/TextField.js","components/AutoComplete/multiple.js","assets/jss/material-dashboard-pro-react/components/Tags-input.js","components/MultInput/input.js","assets/jss/material-dashboard-pro-react/components/sideModule-Card.js","components/User/edit.js","components/Password/index.js","assets/jss/material-dashboard-pro-react/components/sideModule-Users.js","components/User/access.js","components/User/TwoFactor.js","components/User/Settings.js","components/DataPicker/index.js","components/Account/Settings.js","components/User/Mobile.js","assets/jss/material-dashboard-pro-react/components/sideModule.js","components/SideModule/MenuButton.js","components/CustomButtons/Custom.js","components/Card/Delete.js","components/Card/approval.js","components/Buttons/grouped.js","components/Recurrence/settings.js","components/Tags/input.js","components/Card/edit.js","assets/jss/material-dashboard-pro-react/components/sideModule-Card-KPI.js","components/Card/kpi.js","assets/jss/material-dashboard-pro-react/components/sideModule-Card-Resume.js","components/Card/resume.js","components/Card/settings.js","components/Catenation/index.js","components/Columns/edit.js","components/Avatar/index.js","components/Files/file_V2.js","components/Files/list.js","components/Recurrence/list.js","assets/jss/material-dashboard-pro-react/components/SpeedDial.js","components/SendTo/index.js","components/Timer/exportAll.js","assets/jss/material-dashboard-pro-react/components/cardStyle.js","components/Card/Card.js","assets/jss/material-dashboard-pro-react/components/cardBodyStyle.js","components/Card/CardBody.js","assets/jss/material-dashboard-pro-react/components/cardHeaderStyle.js","components/Card/CardHeader.js","components/Timer/chart.js","assets/jss/material-dashboard-pro-react/components/timerLog.js","components/Timer/log.js","components/User/Delete.js","components/Radio/index.js","assets/jss/material-dashboard-pro-react/components/sideModule-Card-Users.js","components/User/in.js","assets/jss/material-dashboard-pro-react/components/sideModule-Feed.js","functions/feeds.js","components/Feed/edit.js","components/Link/edit.js","components/SideModule/index.js","components/Dialog/index.js","functions/tags.js","assets/jss/material-dashboard-pro-react/components/tagsMenu.js","components/Tags/menu.js","components/Chat/countIcon.js","assets/jss/material-dashboard-pro-react/components/customInputStyle.js","components/CustomInput/CustomInput.js","assets/jss/material-dashboard-pro-react/components/cardFooterStyle.js","components/Card/CardFooter.js","assets/jss/material-dashboard-pro-react/views/loginPageStyle.js","views/Pages/ActivateUser.js","components/BoardModels/index.js","assets/jss/material-dashboard-pro-react/components/Backoffice-languages.js","views/BackOffice/languages.js","views/BackOffice/input.js","views/BackOffice/data.js","views/BackOffice/index.js","components/Card/loader.js","assets/jss/material-dashboard-pro-react/components/filter.js","components/Filter/header.js","assets/jss/material-dashboard-pro-react/components/InsightBoards.js","views/BrightAndConnected/InsightBoards.js","assets/jss/material-dashboard-pro-react/components/BrightAndConnected-card.js","components/BrightAndConnected/skeletonCard.js","views/BrightAndConnected/Radar.js","components/BrightAndConnected/card.js","components/BrightAndConnected/FeedFakeCard.js","components/BrightAndConnected/channel.js","components/BrightAndConnected/listLinks.js","assets/jss/material-dashboard-pro-react/components/BrightAndConnected.js","views/BrightAndConnected/Feeds.js","assets/jss/material-dashboard-pro-react/components/Mentions-InputNew.js","assets/jss/material-dashboard-pro-react/components/timelineNewSending.js","components/Timeline/newSending.js","components/Timeline/comment.js","assets/jss/material-dashboard-pro-react/components/timelineSocialStyle.js","components/Timeline/social.js","components/BrightAndConnected/socialCard.js","views/BrightAndConnected/Home.js","views/BrightAndConnected/Read.js","views/BrightAndConnected/index.js","components/Tooltip/transparent.js","views/Calendar/Calendar.js","assets/jss/material-dashboard-pro-react/views/dashboard.js","views/Dashboard/myChannels.js","views/Dashboard/resumeTasks.js","views/Dashboard/resume.js","components/User/dayList.js","views/Dashboard/daytasks.js","views/Dashboard/index.js","assets/jss/material-dashboard-pro-react/views/errorPageStyles.js","views/Pages/ErrorPage.js","views/Library/index.js","views/Pages/LoginPage.js","views/Pages/MaintenancePage.js","views/Pages/OffLinePage.js","assets/jss/material-dashboard-pro-react/components/Agile-Column.js","components/AgileV2/Column.js","components/AgileV2/status.js","views/MyTasks/index.js","views/MasterAdmin/Resume.js","components/Account/exportAll.js","views/MasterAdmin/Accounts.js","views/MasterAdmin/Languages.js","views/MasterAdmin/index.js","assets/jss/material-dashboard-pro-react/components/badgeStyle.js","components/Badge/index.js","assets/jss/material-dashboard-pro-react/components/timelineMiniStyle.js","components/Timeline/Mini.js","components/Notifications/fullCard.js","assets/jss/material-dashboard-pro-react/components/sidebarInteractive.js","views/Notifications/index.js","components/PreLoader/linear.js","assets/jss/material-dashboard-pro-react/customCheckboxRadioSwitch.js","assets/jss/material-dashboard-pro-react/views/registerPageStyle.js","views/Pages/RegisterPage.js","components/AgileKanban/index.js","assets/jss/material-dashboard-pro-react/components/Agile-Card.js","components/Agile/Card.js","components/Agile/Column.js","components/Agile/status.js","views/StrategyAndPlans/Actions/index.js","views/StrategyAndPlans/Dashboard/StrategyAndPlans.js","views/InsightBoards/index.js","components/DialogButtons/index.js","components/DragDrop/cards.js","components/Agile/swot.js","views/StrategyAndPlans/MATRIX/index.js","components/AgileV2/overview.js","components/Filter/index.js","components/Filter/menuFilter.js","views/StrategyAndPlans/Overview/index.js","views/Radar/index.js","views/StrategyAndPlans/plans.js","components/User/card.js","views/StrategyAndPlans/homePlans.js","views/StrategyAndPlans/index.js","views/Tags/index.js","components/ErrorPages/index.js","assets/jss/material-dashboard-pro-react/views/users.js","functions/account.js","views/Users/index.js","components/Clearfix/Clearfix.js","assets/jss/material-dashboard-pro-react/components/cardIconStyle.js","components/Card/CardIcon.js","assets/jss/material-dashboard-pro-react/components/cardAvatarStyle.js","components/Card/CardAvatar.js","assets/jss/material-dashboard-pro-react/views/userProfileStyles.js","views/Profile/index.js","components/Account/creditCard.js","views/Account/invoices.js","views/Account/integrations.js","views/Account/profile.js","components/Percentual/bar.js","components/Account/edit.js","components/Account/preffers.js","components/Account/SubscriptionDetails.js","views/Account/resume.js","components/ColorPicker/Gradient.js","views/Account/whiteLabel.js","views/Account/index.js","views/Pages/subscriptionPlan.js","views/Pages/deniedAccess.js","routes.js","assets/jss/material-dashboard-pro-react/components/sidebar-submenu.js","components/Sidebar/subMenu.js","components/Sidebar/index.js","components/Chat/notifications.js","components/NotificationsV2/myDay.js","components/NotificationsV2/requireApproval.js","components/NotificationsV2/card.js","components/NotificationsV2/index.js","components/QuickAdd/index.js","components/Timer/notifications.js","components/TopSearch/cards.js","components/TopSearch/messages.js","components/Files/file.js","components/TopSearch/files.js","assets/jss/material-dashboard-pro-react/components/SideBarMenuUser.js","components/TopHeader/User.js","components/TopHeader/index.js","components/Chat/chatsStyles.js","components/Chat/chats.js","assets/jss/material-dashboard-pro-react/components/chatMenu2204.js","components/Chat/menu.js","components/Chat/Typing.js","assets/jss/material-dashboard-pro-react/components/chat.js","components/Chat/ButtonViewOnline.js","components/Chat/index.js","assets/jss/material-dashboard-pro-react/components/MobileNav.js","components/MobileNav/index.js","components/CardActions/index.js","components/AgileKanban/modal.js","functions/socket.js","assets/jss/material-dashboard-pro-react/layouts/adminStyle.js","assets/jss/material-dashboard-pro-react/layouts/authStyle.js","layouts/index.js","root.js","index.js","assets/jss/material-dashboard-pro-react/components/Tags.js","components/Tags/Card.js","components/Buttons/custom.js","functions/cards.js","store/search-initialState.js","components/ColorPicker/index.js","api/index.js","assets/icons/Ideas.js","store/alert.js","store/card.js","store/chat.js","store/chats.js","store/functions.js","store/languages.js","store/lightBox.js","store/notifications.js","store/preLoader.js","store/search.js","store/session.js","store/sessionLoads.js","store/sideModule.js","store/timeline.js","store/toLoad.js","store/usersStatus.js","store/chatTyping.js","store/sagas.js","store/index.js","store/history.js","assets/img/logoMachen.svg","assets/icons/svg.png","apims/index.js","assets/jss/material-dashboard-pro-react.js","store/db.js","functions/loadData.js","components/NotificationsV2/count.js","variables/charts.js","assets/jss/material-dashboard-pro-react/components/CardSimple.js","assets/img/tour/strategy-pt.png","assets/img/userCover.jpg","store/controls.js","assets/img/fundoLogin.jpg","components/Icon/Badge.js","assets/icons/GuidelineC.js","assets/icons/GuidelineD.js","assets/icons/GuidelineE.js","assets/icons/GuidelineR.js","assets/icons/machen.svg","assets/img/fundo-sonne.png","assets/icons/microsoftWord.svg","assets/icons/microsoftExcel.svg","assets/icons/microsoftPowerpoint.svg","assets/icons/SWOT.js","assets/icons/pdf.svg"],"names":["i","require","config","languageADD","window","location","hostname","indexOf","String","process","translate","al","style","words","reduxStore","getState","languages","session","language","newText","split","map","a","word","replace","trim","toLowerCase","console","log","api","post","name","e","locales","filter","locale","length","result","toUpperCase","substring","concat","nl2br","str","is_xhtml","break1","break2","breakTag","hexToRgba","opacity","test","hex","substr","rgb","parseInt","customApp","prop","custom","validateEmail","email","appAlert","options","key","MD5","JSON","stringify","toString","content","message","confirm","minWidth","display","width","marginTop","justifyContent","shadow","title","text","color","icon","size","onClick","toast","dismiss","marginLeft","buttons","b","bi","marginBottom","toastOptions","toastId","position","POSITION","BOTTOM_RIGHT","persist","autoClose","horizontal","BOTTOM_LEFT","BOTTOM_CENTER","isActive","variant","info","success","warn","error","decimal","val","digits","value","match","nv","parseFloat","replaceAll","formatNumber","s","currency","Intl","NumberFormat","setMaximumFractionDigits","format","languageUPD","props","data","newLocales","alias","Array","from","flatMap","lc","push","_id","reduxFunction","deleteNode","onlyRedux","db","nodeType","cards","users","deleted","removeSeats","seats","newStr","change","Highlighted","highlight","dark","wordBreak","dangerouslySetInnerHTML","__html","parts","RegExp","part","fontWeight","paddingTop","paddingBottom","backgroundColor","links","lines","ln","ppar","lln","par","ybQuery","getAppAccess","AppAccess","_access","favoriteNode","del","put","delete","padZero","textColor","reqColor","bw","r","g","light","colors","slice","Error","getDate","d","date","low","moment","Date","tz","formatSizeUnits","bytes","toFixed","BytesConvert","decimals","k","dm","sizes","Math","floor","pow","module","exports","Container","styled","div","selectable","selected","locked","priority","isDragDisable","isDragging","inLine","connect","dispatch","bindActionCreators","reduxActions","withStyles","styles","classes","functions","socket","React","useState","steps","Object","keys","card","_parent","type","sort","orderA","step","orderB","provided","draggableProps","ref","innerRef","snapshot","className","container","showSelected","_selected","sideModule","id","activeModule","dataType","iniModule","dragHandleProps","alignItems","padding","nodeId","float","findIndex","border","borderRadius","x","xi","arrow","status","height","st","clear","startDate","endDate","dates","dateInfo","overlap","dateIco","disabled","isNaN","_users","usersContent","max","alt","src","image","defaultAvatar","_tags","showOptions","_interopRequireDefault","defineProperty","default","_react","_default","createElement","Fragment","fill","Component","children","static","fontSize","cursor","preventDefault","stopPropagation","margin","HtmlTooltip","theme","tooltip","maxWidth","typography","pxToRem","boxShadow","Tooltip","action","next","preLoader","redirect","upload","fileData","fullData","file","originalName","formData","FormData","append","Promise","resolve","reject","onUploadProgress","request","returnFile","onUploadError","useStylesFacebook","makeStyles","root","bottom","palette","grey","left","top","animationDuration","circle","strokeLinecap","FacebookCircularProgress","thickness","disableShrink","PolicyAndTerms","consent","privacy","setPrivacy","terms","setTerms","loading","setLoading","useEffect","setTimeout","updateConsent","accepted_at","unix","emit","method","version","Backdrop","zIndex","backdropFilter","open","innerWidth","right","overflow","background","onScroll","store","AgreeRef","useRef","licensingAgreement","agree","onLoad","current","contentWindow","ErrorBoundary","state","hasError","errorInfo","this","setState","buttonStyle","button","minHeight","grayColor","whiteColor","hexToRgb","textTransform","letterSpacing","willChange","transition","lineHeight","textAlign","whiteSpace","verticalAlign","touchAction","blackColor","marginRight","transform","fullWidth","custom_color","custom_menuColor","custom_mediumColor","primary","primaryColor","infoColor","successColor","warning","warningColor","danger","dangerColor","rose","roseColor","white","twitter","twitterColor","facebook","facebookColor","google","googleColor","linkedin","linkedinColor","pinterest","pinterestColor","youtube","youtubeColor","tumblr","tumblrColor","github","behance","behanceColor","dribbble","dribbbleColor","reddit","redditColor","simple","transparent","pointerEvents","lg","sm","round","block","link","justIcon","paddingLeft","paddingRight","useStyles","RegularButton","forwardRef","muiClasses","rest","btnClasses","classNames","Button","pagesHeaderStyle","appBar","borderBottom","flex","defaultFont","appResponsive","defaultBoxShadow","list","listStyle","listItem","breakpoints","down","navLink","textDecoration","listItemIcon","listItemText","navLinkActive","drawerPaper","transitionProperty","transitionDuration","transitionTimingFunction","drawerWidth","visibility","overflowY","borderTop","sidebarButton","AuthNavbar","appBarClasses","brandText","cx","List","AppBar","Toolbar","footerStyle","footer","containerFluid","inlineBlock","Footer","fluid","rtlActive","anchor","center","getYear","href","target","backdrop","header","btClose","loader","img","backgroundRepeat","backgroundSize","backgroundPosition","maxHeight","movie","embed","leftButtom","rightButtom","lightbox","lightBox","mounted","setMounted","setLoader","sideChange","setsideChange","activeFile","setActiveFile","path","setPath","setOriginalPath","pdfLoader","setPDFLoader","pdfScale","addEventListener","interaction","files","encodeURIComponent","pathOriginal","ext","fileExtensions","viewer","keyCode","active","f","changeFile","close","removeEventListener","side","downloadPath","newDownloadPath","onSwipeMove","event","y","onSwipeEnd","Icon","CircularProgress","SVGIcon","onError","zoom","autoPlay","controls","PreLoaderContent","Escurecer","CircularIndeterminate","fullScreen","userSelect","buttonText","reverse","flexDirection","iconButton","onlyIcon","btnClassesText","iconColor","iconBackground","setData","reactThis","react","user","newData","_reactions","displayName","reactDate","re","us","ReactionComp","primaryIcon","secondaryIcon","hideDisables","IconButton","Avatar","iconButtonStyleTransaparent","iconButtonStyleWhite","memo","setOpen","anchorRef","handleClose","contains","onClose","handleListKeyDown","aria-controls","undefined","aria-haspopup","aria-label","prevOpen","onOpen","textOverflow","count","usePropagation","btColor","horizontalButton","Popper","anchorEl","role","TransitionProps","placement","Grow","transformOrigin","Paper","ClickAwayListener","onClickAway","MenuList","autoFocusItem","onKeyDown","hide","MenuItem","forceStopPropagation","render","avatar","badgeContent","setAnchorEl","Boolean","period","dashboard","option","subtractDays","pageLoadCards","currentTarget","Menu","keepMounted","PaperProps","ITEM_HEIGHT","TextField","borderBottomColor","borderColor","contentWithExpand","headerIcon","headerTitle","overflowX","actionButtons","cancelButton","saveButton","parent","iconButtonStyle","setName","editing","setEditing","showPrivateCard","setShowPrivateCard","unlockedPrivates","editable","saveData","noLog","onEdit","backClick","onExpanding","private","lockPrivate","Badge","iconTitle","searchText","searchTextStyle","textStyle","inputStyle","label","fieldName","InputLabelProps","shrink","InputProps","autoComplete","onChange","placeholder","autoFocus","noAutoFocus","multiline","onCancel","actionsSize","onSave","expanded","viewAllName","onDoubleClick","showOrder","html","tmp","document","innerHTML","textContent","innerText","stripHtml","privateTitle","periodFilter","moreButton","colorPicker","ColorPicker","c","show","noExpanding","isExpanded","MoreMenu","noButton","prev","setPrivate","optionsProps","CustomButton","control","fontFamily","highlighter","boxSizing","input","suggestions","item","timelineStyle","rootRelative","timeline","scrollEnd","timelineSimple","timelineBadge","timelineSimpleBadge","badgeIcon","timelinePanel","borderLeftWidth","borderRightWidth","borderLeft","borderRight","timelineSimplePanel","timelinePanelInverted","up","timelineHeading","timelineBody","timelineFooter","footerUser","footerLine","dropFile","onDropFile","editor","editorRelative","textEditor","textEditorIcon","progressBar","actionButton","sendingMessage","valuePositive","positive","valueNegative","lastValue","timeInfo","urlPreview","mentionInput","mentionWrapper","outline","resize","save","oldData","hashs","hash","response","_token","tokenId","imageResult","saveAccess","access","safety","_safety","dbUpdateUser","emailExist","apims","get","emailExistDB","validateEmailToken","token","emailTokenGenerate","cardsAccess","userId","userData","cardAccessUpdate","cardId","cardType","parentUser","groupAccess","groupId","_groups","groupAccessRemove","groups","isResponsible","userParam","chatReaded","newTimeline","readedBy","m","mi","readedDate","_notifications","notifications","interact","reactions","u","timelineComment","dt","idRel","loadCardsV2","cardLoad","ignoreLoader","node","comment","to","idUser","_toUser","loadTimeline","lastMessageDate","chat","ids","limit","skip","toId","ini","reqChildrens","newUpdates","lastDate","nodes","nodesIds","reqTimeline","timelines","chatOpenId","tm","params","toUsers","msg","created_at","manualEntry","fin","noReg","total","group","groupEnd","load","countUnRead","unReadCountGroup","unReadCountUser","externalGroups","externalUsers","deleteMessage","req","deletedReason","comm","grid","GridContainer","Grid","GridItem","storie","draft","chats","drafts","setMessage","sending","setSending","fileDropDrag","setFileDropDrag","fileList","setFileList","fileSend","setFileSend","fileProgress","setFileProgress","fileError","setFileError","setUrlPreview","urlPreviewLoad","setUrlPreviewLoad","urlErrors","setUrlErros","onEmojiPicker","setOnEmojiPicker","inputHeight","setHeight","refFileDrop","createRef","sendingInput","CardAccess","find","isSubscribed","inputId","getElementById","reply","focus","mentionedUsers","usersMentioned","test1","sendMessage","dataMessage","uuid","replyData","mentions","notifyUsers","filesCount","_client","client","onSending","userAccessNew","sendFiles","fi","percentCompleted","loaded","n","sendedList","fileUpload","nFilesSend","verifyText","url","pattern","dataUrl","contentSnippet","urlErrorsArray","usersSuggestion","owner","planAdmin","planModerate","fil","_planId","fs","offsetHeight","FileDrop","relative","onDragOver","disabledSend","onDrop","accept","editorStyle","Skeleton","hideCards","showUserName","noReactions","URL","createObjectURL","splice","deleteFile","LinearProgress","valueBuffer","xs","md","xl","site","clientHeight","onBlur","onPaste","clipboardData","mentionInputStyle","shiftKey","forceSuggestionsAboveCursor","autosize","minRows","maxRows","trigger","renderSuggestion","suggestion","search","highlightedDisplay","backgroundImage","multiple","closeOption","onEmojiClick","emojiObject","emoji","groupVisibility","recently_used","onDragLeave","drawer","box","iconList","showList","setShowList","setSelected","index","callBack","buttonsHover","setButtonsHover","setIcon","modMessageOpen","setModMessageOpen","customButtons","bt","saveName","onMouseEnter","onMouseLeave","permitIcon","iconOnEditable","onChangeIcon","noCancel","tooltipText","actionButtonsStyle","actionsButtons","timelineMessage","tooltipprops","disableFocusListener","disableHoverListener","disableTouchListener","PopperProps","disablePortal","interactive","component","loadFiles","page","asc","childrens","reqFiles","navFolders","types","reqFolders","navFiles","showPrivate","selectedParent","setSelectedParent","setFiles","setPreloader","folders","setFolders","searchFolder","setSearchFolder","idPlan","fds","lf","ff","folder","openFolder","nFolders","RenderFolder","onSelect","reqSubFolders","endAdornment","InputAdornment","ProgressLinear","textSize","bar","newProps","showText","customColor","Checkbox","removeUsers","setRemoveUsers","myDayUsers","setMyDayUsers","searchValue","setSearchValue","setSearch","selectToMyDay","setSelectToMyDay","getUserList","userList","getUserAccess","admin","plan","selectUser","acc","noNotification","deleteAccessUser","userIds","sendToDay","setMyDay","GroupMenuItem","UserMenuItem","pr","userPermission","permission","myDay","customDefine","setResponsible","setUserParam","param","on","checked","mdu","usersToRemove","validateUser","userGroup","AvatarGroup","flexWrap","AvatarList","noLimit","avatarSize","avatarBorder","listingStyle","aa","aai","dataSave","fieldSet","progress","progressPercentage","setReqSave","description","setDescription","setValue","timer","changeKPI","newValue","PositiveValue","kpi_type","diff","updated_at","manualAdd","kpiTimerDelete","kpi_currency","selectedUser","setSelectedUser","admins","idu","isArray","getAdminList","onlyCard","selectedUsers","selectedUserId","Dialog","timerFunction","reqSave","started","setStart","setTimer","cardsWithKpi","setCardsWithKpi","setStartDate","setEndDate","manualTime","setManualTime","manualMinuteEntry","setManualMinuteEntry","manualHourEntry","setManualHourEntry","kpi_ini","kpi_fin","clearTimeout","verifyTimer","childrenCards","kpiCards","chields","kpi_useParent","Set","_kpiTimer","calcTimer","kill","ignoreManual","iniTimer","diffText","hours","trunc","minutes","seconds","startTimer","kpiTimerStart","stopTimer","kpiTimerStop","kpiChart","model","series","labels","kpi_flow","_timeline","kpi_total","percent100","meta","high","plugins","Chartist","tooltipFnc","axisX","showGrid","axisY","onlyInteger","sumKpi","percentKpi","ceil","inputProps","isValid","diffCalc","min","includeMe","time","containerNoShadow","infos","indicators","indicatorsIcon","imagePreview","imagePreviewList","PreLoader","lateDates","avatarIconColor","addColumn","newCards","uid","newId","reorder","orderBy","linkCard","automation","parentCard","dataUpdate","automationDueDateType","add","automationDueDate","automationStatusType","automationStatus","completed_at","automationUsers","automationTags","newTags","removeTags","addTags","nt","tag","automationExec","destination","getKanbanData","columns","columnsOrder","c1","c2","step1","step2","column","items","cid","ca","cb","order","cIndex","columnOrder","reason","approval","approved","flowCard","moveTo","onConcludedStepMoveTo","nextStep","requireApproval","showCard","edit","setEdit","over","setOver","update","updateCardData","deleteThis","cardContainer","onMouseOver","viewTimer","noDelete","dragStatus","checklist","_hasStep","setCompleted","switchBase","track","Switch","addCard","rows","parentData","channel","nameI","refUsers","setSelectedUsers","inputRef","saveRef","createCards","initialData","placeHolder","explain","which","defineResponsible","setAdd","addLoad","setDragStatus","setChecklist","today","tasksCards","noChecklist","onDragEnd","source","draggableId","droppableId","itemOrderIds","onDragStart","onDragUpdate","openCards","listStepLock","board","showProgress","direction","droppableProps","isDraggingOver","dataA","dataB","alignContent","ConnectedIn","connectedIn","connectInMount","returnConnections","connectedCardAccess","planAccountVerify","showLegend","legend","Comp","cloneElement","setPositiveValue","iniKpi","l","fnIdentification","accomplished","goalKpi","goalValue","balanceValue","chartShow","listener","animation","kpii","kpif","kpiInfo","PopperMenu","aspectsTitle","aspects","setAspects","newAspects","internal","external","internalType","externalType","internalTypeMult","externalTypeMult","Chip","ImagePreview","setImagePreview","stopLoading","setStopLoading","showChecklist","setShowChecklist","loadingData","setLoadingData","init","_loadTimeline","kpiType","reqParents","reqFullData","onExpand","openSideModule","hasYoutube","alignSelf","frameBorder","allow","allowFullScreen","BrightAndConnectedIco","MachenIco","viewList","Resume","ignoreList","_aspects","SWOT","kpi","_timelineCount","onlyOption","_logCount","_kpiCount","_timerCount","borderTopLeftRadius","borderTopRightRadius","Checklist","cropperStyle","avatarImage","addImage","cropper","circleCropper","CroppedImage","SetCroppedImage","ImageCropDialog","SetImageCropDialog","ImagetoCrop","SetImagetoCrop","fileInput","_crop","getCroppedCanvas","toDataURL","nameImg","typeImg","urltoFile","imgResult","maxSizeMB","maxWidthOrHeight","useWebWorker","imgResizer","Resizer","imageFileResizer","then","filename","mimeType","fetch","res","arrayBuffer","buf","File","avatarIcon","openFile","openLightBox","click","reader","FileReader","onloadend","readAsDataURL","handleImageChange","onDelete","aria-labelledby","aspectRatio","ignoreAspect","guides","noGuides","viewMode","checkOrientation","toTemplate","errorData","setErrorData","installProgress","setInstallProgress","installTemplate","dataSend","templateId","isTemplate","saveCard","installStep2","copyCards","installStep3","loadPlan","completed","loadPlanCompleted","onComplete","history","helperText","defaultValue","separator","isCombining","cardsExpanded","Card","setExpanded","globalExpanded","setGlobalExpanded","useTemplate","setUseTemplate","showMoreButton","setShowMoreButton","cardColorPicker","getCardColor","cardColor","setCardColor","duplicate","setDuplicate","move","copyName","setCopyName","copyModel","copyRel","setCopyRel","selectTarget","setSelectTarget","duplicateLoader","setDuplicateLoader","combine","setCombine","cardRef","onResize","newSize","manualExpanded","combineTargetFor","isMounted","selectThis","activeCards","saveMATRIX","selectSWOT","countChildrens","updateCardStatus","cardStatus","openPlan","deleteCard","directDeletion","restoreThis","restoreCard","noExpanded","notGlobalExpanded","_expanded","duplicateCard","isModel","moveCard","modules","planningTypes","noShadow","onContextMenu","_createdBy","parentPrivate","planEdit","archived","_isFavorite","myDayOption","myDayClick","onAction","at","selectOption","viewButton","updateCard","disableDelete","my","showCompleteOption","prevExpanded","_cardCode","showTags","_recurrenceId","noShowRecurrenceCard","recurrenceCreatedDate","Modal","aria-describedby","ignoreTypes","StyledBadge","badge","paper","StyledBadgeAway","spacing","usersStatus","setStatus","anchorOrigin","vertical","scrollEndNoEditor","timelineSimpleWithHeader","borderBottomRightRadius","borderBottomLeftRadius","timelineBadgeInverted","timelineSimpleBadgeInverted","timelineDate","overflowWrap","timelineLog","customDropdownStyle","popperClose","popperNav","manager","innerManager","dropdown","backgroundClip","menuList","popperResponsive","dropdownItem","darkHover","primaryHover","primaryBoxShadow","infoHover","infoBoxShadow","successHover","successBoxShadow","warningHover","warningBoxShadow","dangerHover","dangerBoxShadow","roseHover","roseBoxShadow","dropdownItemRTL","dropdownDividerItem","buttonIcon","caret","caretActive","caretDropup","caretRTL","dropdownHeader","noLiPadding","CustomDropdown","handleCloseMenu","dropdownList","buttonProps","dropup","hoverColor","dropPlacement","innerDropDown","navDropdown","caretClasses","dropDownMenu","divider","Divider","aria-owns","in","defaultProps","CardTravel","Extension","Fingerprint","Build","stories","inverted","badgeColor","titleColor","body","footerTitle","FlightLand","getFullYear","getMonth","hideImage","setHideImage","overOptions","setOverOptions","cancelReason","setCancelReason","goCancel","setGoCancel","forward","setForward","saveLoading","setSaveLoading","forwardToId","setForwardToId","messageRef","resizeObserver","ResizeObserver","observe","disconnect","overOptionsHandle","mouse","closeOptionsHandle","chatId","parse","reaction","toReplace","userName","cancelConfirm","renderFile","fileName","controlsList","messageClick","boxStyle","isReply","fullName","replyClick","ai","balance","noOptions","renderMessage","like","nolike","love","approve","attention","hideSelected","ignoreId","forwardedId","_forwardToId","forwardMessage","ownProps","miro","miroBoard","saveLoader","saveClose","headerStyle","lock","modulePopup","moduleExpanded","moduleFullScreen","menu","menuButtons_resume","MenuButton","MenuButton_arrow","subTitle","messagesContainer","messages","setStarted","listRef","loadRef","rowHeights","messagesLength","scrollToBottom","clearMessages","unReadeds","unreadeds","loadMore","timelineDb","timelineEnd","lt","newRef","getRowHeight","Row","resetAfterIndex","setRowHeight","force","currentLength","visibleStopIndex","scrollToItem","timerLoad","infinitLoadMore","visibleStartIndex","overscanStopIndex","itemCount","itemSize","onItemsRendered","overscanCount","lastChange","setLastChange","filteredItems","setfilteredItems","searchMessages","onFinish","positin","setShowText","v","setPreLoader","reqStories","kc","renderMessages","showHeader","noSearch","Search","disabledSending","onlyAdminsSendMessages","changeGroups","newArray","dbNode","ws","secondaryParent","valueSelect","returnArray","validation","all","autoCompleteProps","inNode","startAdornment","Autocomplete","CustomChip","deleteIcon","textField","labelTop","noLabel","labelTopLight","noLabelLight","values","setValues","newValues","getOptionLabel","limitTags","freeSolo","disableClearable","renderInput","renderOption","renderTags","getTagProps","newTag","colorPickerCallBack","icons","instruction","picture","changeTags","switch","accessDescription","iniData","emailError","setEmailError","changeData","cl","saveUser","exist","disabledFields","userAdmin","userEdit","tags","LoginPage","cPassword","password","setUser","confirmed","setConfirmed","strength","setStrength","setClear","matchedCase","ctr","calcPass","onConfirmed","newPass","setNewPass","passClear","setPassClear","saveAdmin","isAdmin","GlobalData","saveEdit","inviteUser","savePassword","subscriptionPlan","plans","settings","space","adminLimit","customAdmins","adminUsers","independentAccount","enabled","select","userRead","userInteract","planRead","createTemplate","master","_isAdmin","feed","feedAdmin","feedEdit","feedModerate","masterAdmin","machenAdmin","tokenData","setTokenData","setToken","newToken","verify","code","disableToken","setLanguage","reload","expiresIn","isResale","CustomInput","appearance","DatePickerComponent","registerLocale","pt","onClear","placeholderText","onChangeStartDate","selectsStart","maxDate","range","timeInputLabel","dateFormat","showTimeInput","customInput","showYearDropdown","onChangeEndDate","selectsEnd","minDate","clearButtonPosition","setIniData","expireAccountDate","DataPicker","AppleStoreQR","GooglePlayQR","countNotifications","openModule","CustomizedButtons","migrateComplete","setMigrateComplete","Load","SelectedUser","childrensCards","setChildrensCards","countCards","setCountCards","findNameUser","setFindNameUser","loadUserCards","iniChildrens","getChildrens","deleteAll","rel","migrate","fromData","toData","nameA","nameB","setReason","SplitButton","selectedIndex","setSelectedIndex","handleToggle","ButtonGroup","aria-expanded","clearRecurrenceData","recurrence","recurrenceRepeatDays","recurrenceEndDate","recurrenceLimit","recurrenceMyDay","recurrenceOnlyCompleted","recurrenceDuplicateCard","setCompData","days","newDate","recurrenceNextDate","calcNextRecurrence","isoWeekday","recurrenceCopyCatenation","planType","setNewData","setSaveLoader","setDate","setSetDate","miroOption","setMiroOption","dateDays","setDateDays","loadUrlContent","_requireApproval","d2","newDataCD","article","verifyTemplate","planMyAccountVerify","hideFields","_files","swot","MatrixIcon","fieldsTitle","freeChildrenDate","childrenAutoTag","inputValue","risk","complexity","impact","privateChildrens","broadcast","timelineKpiParent","view","setView","fieldError","notAllocated","pp","setParentKpi","totalAllocated","ch","chi","posision","ToggleButtonGroup","exclusive","ToggleButton","cardAllocated","kpiAccomplished","minValue","maxValue","titlePosition","titleAlign","titleOffsetX","rangeBorderColor","modifiers","measureBorderColor","measureSize","markerSize","rangeColors","measureColors","markerColors","motionConfig","symbol","kip_type","kpi_reqMessage","unlinkCards","unlinkChildrens","loadCards","planId","cardData","cardsOn","completedCards","AutomationAction","ignoreValues","setOnConcludedStepMoveTo","showInPanel","showGroups","shortCutTitle","shortCutDescription","shortCutButtonToAdd","AvatarProps","setFile","createdBy","showParent","timelineId","showConnectedIn","endLoad","setEndLoad","loadingFiles","setLoadingFiles","setPage","lightBoxfiles","newFiles","fl","scrollDiv","scrollTop","innerHeight","scrollHeight","scrollFunction","toLocaleLowerCase","resume","flexGrow","speedDial","speedDialInvisible","typeFilter","setTypeFilter","selectCard","setSelectCard","myRef","dataTypeOptions","sendTo","cardsResults","sharedIn","copy","attach","shared","shareThis","newRel","oldRel","cardMoveTo","AutoComplete","Pagination","newPage","scrollIntoView","ExcelFile","ReactExport","ExcelSheet","ExcelColumn","dataSet1","dataUsers","total_time","total_hours","total_minutes","total_seconds","_times","finalData","calc","timerText","totalTimer","total_diff","total_diffText","element","alignment","wrapText","ds","cardStyle","wordWrap","cardPlain","cardProfile","cardBlog","cardRaised","cardBackground","cardPricing","cardPricingColor","cardProduct","cardChart","cardLogin","plain","profile","blog","raised","pricing","product","testimonial","chart","login","cardClasses","cardBodyStyle","cardBody","WebkitBoxFlex","cardBodyBackground","cardBodyPlain","cardBodyFormHorizontal","cardSignup","cardBodyColor","cardBodyProfile","cardBodyCalendar","CardBody","formHorizontal","signup","calendar","cardBodyClasses","cardHeaderStyle","cardHeader","cardHeaderPlain","cardHeaderImage","cardHeaderContact","cardHeaderSignup","cardHeaderStats","cardHeaderIcon","cardHeaderText","warningCardHeader","successCardHeader","dangerCardHeader","infoCardHeader","primaryCardHeader","roseCardHeader","customCardHeader","CardHeader","contact","stats","cardHeaderClasses","subtract","exportTimers","setExport","setCards","iniCards","ncards","timeSheet","convertSecondsToText","mini","diffTextMini","ts","su","timerTextMini","TimeSheetData","Accordion","AccordionSummary","expandIcon","AccordionDetails","FormGroup","FormControlLabel","textMini","valueFormat","enableArcLabels","scheme","activeOuterRadiusOffset","arcLabelsTextColor","borderWidth","cornerRadius","enableArcLinkLabels","innerRadius","leavesOnly","padAngle","sortByValue","addTimer","setAddTimer","outlineOffset","checkedIcon","StyledRadio","Radio","disableRipple","clsx","accessEditing","btActions","cardUsers","userEditing","setUserEditing","unSelectedUsers","unSelectedGroups","saveGroup","account","addAllUsers","adus","addAllGroups","renderGroup","gr","renderUser","RadioGroup","preview","previewTitle","feedTitle","feedContent","feedFooter","feedDate","feedLink","saveFeed","feeds","loadFeeds","mountFeeds","parents","p","cover","feedLoading","setFeedLoading","_lock","feedValidate","urlToVerify","customTitle","customDescription","feedInsert","font","Moment","pubDate","urlValidate","lk","sideModuleWindow","userModerate","MOD","reqId","EditUser","FeedEdit","template","LinkEdit","Timeline","Catenation","Recurrence","Files","UserAccess","TwoFactor","ownerLock","UserMobile","CardResume","CardEdit","buttonsCount","ColumnEdit","Users","UserDelete","CardDelete","CardKPI","TimerLog","SendTo","AccountSettings","UserSettings","CardSettings","mod","rq","ic","tagUpdate","newTagResult","t","tagDelete","localTagDelete","tagUnlink","localTagUnlink","tagLink","tg","menuExpanded","buttonColor","buttonColorExpanded","moreMenuShow","setMoreMenuShow","moreMenuOpen","setMoreMenuOpen","setEditor","showAll","setShowAll","setTags","mountTags","searchLabel","tagLabel","ta","_count","cta","_countOthers","achi","xx","clearEditor","editTag","saveTag","newColor","deleteTag","unlinkTag","collapse","maxDepth","renderItem","ns","newItems","targetPath","dragItem","customInputStyle","underline","underlineError","underlineSuccess","labelRoot","labelRootError","labelRootSuccess","formControl","whiteUnderline","whiteInput","formControlClasses","formControlProps","labelText","labelProps","inputRootCustomClasses","labelClasses","underlineClasses","inputClasses","helpTextClasses","FormControl","InputLabel","htmlFor","Input","FormHelperText","cardFooterStyle","cardFooter","cardFooterProfile","cardFooterPlain","cardFooterPricing","cardFooterTestimonial","cardFooterStats","cardFooterChart","CardFooter","cardFooterClasses","loginPageStyle","cardTitle","textCenter","justifyContentCenter","customButtonClass","inputAdornment","inputAdornmentIcon","cardHidden","socialLine","ItemList","setId","setBoard","boards","socketData","_board","_order","saveColumn","boardId","columnData","_columnId","_cardColumn","_columnData","_columnsOrder","deleteColumn","_deleted","saveBoard","boardModels","noList","col","onKeyPress","marginBotton","column2","chip","onlyEmpty","setOnlyEmpty","setLimit","setFilter","updateLanguage","myTasksMenuExpanded","TablePagination","onChangePage","rowsPerPage","onChangeRowsPerPage","labelRowsPerPage","DecimalInput","start","blur","TabPanel","other","hidden","Box","a11yProps","setVersion","sendSocket","fn","Tabs","scrollButtons","indicatorColor","Tab","BoardModels","loaders","sessionLoads","searchMobile","logo","logoMini","logoImg","logoNormal","pageLink","pageLinkActive","activeArrow","fields","locationPathName","pathname","pathName","Routes","tabs","searchFields","initialState","units","placeSelf","end","setEnd","loadInsights","radarCards","tagFilter","flexFlow","ii","LoadParent","feedRotate","linkTitle","linkContent","setTotal","loadLinks","RenderSkeleton","ri","setImage","backSize","setBackSize","clickChannel","isoDate","isValidUTF8","utf8","setTitle","caid","deleteChannel","pid","confirmDeleteChannel","deleteId","changeVisible","feedId","visible","_admin","CryptoJS","FeedFakeCard","setHashs","setLinks","setMax","Nhashs","_feeds","back","li","setFeeds","iniFeeds","showHidden","aFeeds","nfeeds","sp","follow","editorInput","messageWithUrl","setStories","timelineD","readMessages","showUnReaded","hideTimeline","loadLink","Home","Read","Feeds","MachenCalendar","withDragAndDrop","Calendar","allDay","previous","month","week","day","agenda","showMore","CustomToolbar","localizer","navigate","onNavigate","events","setEvents","alert","toLocaleString","selectedDate","setSelectedDate","setSelectedCard","showAllEvents","setShowAllEvents","severalDaysActivities","setSeveralDaysActivities","disabledTypes","setDisabledTypes","dow","momentLocalizer","preffers","calendarPreffers","saveCalendarPreffers","CalendarEvents","uf","toDate","diffDate","defaultDate","onSelectSlot","startAccessor","endAccessor","onView","onSelectEvent","eventPropGetter","isSelected","percent","components","leaveDelay","toolbar","dateHeader","onEventResize","onEventDrop","showMultiDayTimes","popup","resizable","defaultView","dashboardStyle","widgetsContent","hidePrivate","channelAdd","setChannelAdd","showCards","setShowCards","showIn","paramA","paramB","sol","viewSuggestions","setViewSuggestions","nextTasksOrderBy","setNextTasksOrderBy","useCookies","cookies","setCookie","myCards","hideSupportAndAppBanner","myDayTasksSuggestionsContent","orderByTitle","orderByTitlePosition","nextDaysContent","now","timeMessage","getHours","FavoritePlans","banner","MockupSupport","MockupApp","updA","updB","countProfile","vocation","legacy","utoPlay","showArrows","stopOnHover","transitionTime","showStatus","strategicStatement","noPagination","Ideas","Dashboard","myDayTasksContent","userCover","adminViewLoader","setAdminView","adminView","filtered","errorPageStyles","contentCenter","setCardsIds","countFiles","setCountFiles","setOrderBy","orderDESC","setorderDESC","setSearchText","preloader","by","ob","desc","onPageChange","onRowsPerPageChange","LKEY","reqTwoFactor","setReqTwoFactor","loginToken","setLoginToken","setLogin","emailLogin","origin","callback","bcrypt","pss","pss2","newKey","base64_encode","lp","twoFactor","localStorage","setItem","validToken","recoveryPassword","cardList","cardAdd","columnStyle","dbCards","agileOrderBy","agileOrderDesc","groupByColor","rowExpandeds","separators","showDeleted","ac","parentId","orderAN","orderAN2","bc","orderBN","orderBN2","idParent","typeAdd","columnId","columnName","columnIcon","customColumns","cardbyGroup","separatorTitle","separatorColor","Item","isDropAnimating","setRowExpanded","isDropDisabled","columnsSettings","isCombineEnabled","mode","renderClone","rubric","inLineAdd","outerRef","itemData","newCardsOrder","sourceColumn","destinationColumn","sourceCardIds","newCardsIds","newState","destinationCards","sourceCards","destinationCardIds","theColumn","emptyHide","myTasks","ExportAll","allUsers","deletedUsers","au","Accounts","SetAccounts","AccountsExport","SetAccountsExport","viewAccountDetail","setViewAccountDetail","userOrderBy","setUserOrderBy","userOrderASC","setUserOrderASC","ReqAccounts","AE","diskUsed","filesSize","cd","pl","unityDeleted","lastSession","usersCount","u_orderBy","User","unity","A","B","usi","setLanguages","sd","setSD","ed","setED","Languages","badgeStyle","gray","userStories","unReaded","Readed","dbNotify","openChat","dbProps","byUser","Header","readed","showTimeline","sideMudule","Mini","sidebarStyle","itemButtom","itemButtomActive","themeExample","moduleTitle","sidebarWrapperWithPerfectScrollbar","viewModule","setViewModule","route","vm","cardNotifications","cardsNotifications","tmNotifications","tmsNotifications","customCheckboxRadioSwitch","checkRoot","radioRoot","checkboxAndRadio","checkboxAndRadioHorizontal","uncheckedIcon","disabledCheckboxAndRadio","labelHorizontal","labelHorizontalRadioCheckbox","labelLeftHorizontal","labelError","radio","radioChecked","radioUnchecked","inlineChecks","iconCheckbox","borderStyle","iconCheckboxChecked","iconCheckboxIcon","switchIcon","switchIconChecked","switchBar","switchChecked","registerPageStyle","form","socialTitle","textFields","checkboxLabelControl","checkboxLabel","reorderList","startIndex","endIndex","removed","getStyle","draggableStyle","virtualStyle","combined","useLayoutEffect","scrollTo","RowProps","itens","isUsingPlaceholder","Column","addColumnActive","setAddColumn","dragActive","setDragActive","newColumnOrder","orderI","cardsOrder","newColumn","columProps","dropAnimation","curve","duration","random","CardList","mainPanelWithPerfectScrollbar","navigator","platform","lastCompletedCards_page","setlastCompletedCards_page","nextActivities_page","setNextActivities_page","dueActivities_page","setDueActivities_page","planNote","setPlanNote","planNoteSave","setPlanNoteSave","timelineParams","setTimelineParams","note","saveNote","clean","titles","TextareaAutosize","spellcheck","colorBy","childColor","enableLabels","labelTextColor","animate","guidelines","objectives","goals","actions","completeA","completeB","insightsCards","blue","SimpleDialog","selectedValue","DialogTitle","ListItem","ListItemAvatar","ListItemText","setSelectedValue","iconSize","defaultName","discountHeight","lockColumns","manualOrder","backToMatrix","selectedGuideline","selectedObjective","selectedGoal","cardsGuidelineR","cardsGuidelineC","cardsGuidelineE","cardsGuidelineD","swotCards","selectedCard","Hidden","smDown","smUp","itemAligns","Migrator","setMigrator","MigratorData","setMigratorData","showCompleted","onlyUnReaded","overview","cardToLink","_childrens","_objectives","_goals","updateType","cancel","iniMigration","MCards","finishMigration","showColors","_skipGoals","_skipObjectives","viewSearch","setviewSearch","findNameClient","setFindNameClient","findNamePlan","setFindNamePlan","confirmSelectClient","clearGroups","indeterminate","cc","selectClient","ua","uc","dc","fa","faa","selectPlan","hideText","Filter","viewCompleted","setViewCompleted","viewColors","setViewColors","setOnlyUnReaded","setShowDeleted","loadingDeleted","setLoadingDeleted","loadDeletedCards","tour1","ClientInfo","noActions","ClientCover","UserCover","matrixAdmin","noShowUsers","late","Client","Plans","scrollTimer","_account","Actions","Overview","Library","adminMode","setAdminMode","searchCards","loadAdmin","searchResult","dbt","filterText","Bright","provisorio","countUsers","maxUsers","usedUsers","userGroups","filteredUsers","filterUsersGroup","ug","clearfix","Clearfix","cardIconStyle","cardIcon","cardAvatarStyle","cardAvatar","cardAvatarProfile","cardAvatarPlain","cardAvatarTestimonial","cardAvatarTestimonialFooter","CardAvatar","testimonialFooter","cardAvatarClasses","userProfileStyles","cardIconTitle","cardCategory","updateProfileButton","cvc","expiry","number","focused","accountData","historyEditor","editorData","setEditorData","EditorState","createEmpty","htmlToDraft","ContentState","createFromBlockArray","contentBlocks","createWithContent","mp","inline","inDropdown","editorState","onEditorStateChange","draftToHtml","convertToRaw","getCurrentContent","hashtag","PercentualBar","valid","cpf","cnpj","customURL","accountResponsible","invoiceResponsible","expire_at","requireExpirePassword","requireToken","passwordExpire","listStyleType","planDetails","upgradeSubscription","customAdminsLimit","customStorageSpace","brightAndConnected","feedDays","radarLimit","insight","planClient","clientAdmin","machenPlan","templates","guidelineLimit","feedLimit","insightLimit","usedSpace","setUsedSpace","SubscriptionDetails","WrappedColorPicker","alpha","GradientColor","css","xc","os","offset","convertLinearToPallet","showAnglePicker","showGradientTypePicker","paletteHeight","onPaletteChange","colorConstruct","setGradientColor","setLogo","setBackground","fieldsRefresh","setFieldsRefresh","saveDataLoading","setSaveDataLoading","setCustom","resetData","newCustom","backgroundResult","customLogo","loginBackground","Gradient","ColumnTitleColor","enableAlpha","colorText","menuColor","menuButtonColor","subMenuColor","subMenuTextColor","subMenuTextColorActive","linearProgress","AvatarBackground","responsive","line","medium","fieldVariant","dashRoutes","auth","BrightAndConnected","subMenu","StrategyAndPlans","hashId","Matrix","MyTasks","Tags","BackOffice","MasterAdmin","Notifications","views","query","URLSearchParams","setChecked","setEmail","validatingEmail","setValidatingEmail","tokenError","setTokenError","validatingToken","setValidatingToken","termsOpen","setTermsOpen","setPassword","emailValidate","validateToken","register","tabIndex","currentIndex","newChecked","Account","accountHas","buttonExpanded","PlanInfo","planOptions","expandingCards","setExpandingCards","adminViewLoading","setAdminViewLoading","pageBase","expandingAllCards","openPage","subMenuExpanded","tf","setSubMenuExpanded","menuExpand","badgeVisible","onExit","packageJson","approvalResponsible","cardIndex","setShowPrivate","markAsRead","onRead","cardTimeline","tmi","noReply","countShow","setCountShow","iniNotifications","ignoreWS","ntCount","iniDate","notCards","notification","lastNotification","firstNotification","mountCards","clearNotifications","ms","ntCountShow","ci","na","nb","lna","lnb","nti","pages","setCount","iniChatNotification","reqCount","timerCards","searchCompleted","setSearchCompleted","searchDeleted","setSearchDeleted","cardsType","setCardsType","searchCardsOnLine","xg","tp","viewMessage","setViewMessage","timelineData","searchFiles","adminNavbarLinksStyle","selectedName","selectedNameText","headerLinksStyle","logout","chatNotifications","cardsLoader","setCardsLoader","setMessagesLoader","filesLoader","setFilesLoader","searchCardsLoading","setSearchCardsLoading","searchFilesLoading","setSearchFilesLoading","cardsStatusSearch","setCardsStatusSearch","sTitle","sIcon","properties","setProperties","routes","QuickAdd","userExtended","userActive","userActiveExtended","lastMessage","lastMessageUnReaded","unReadedCount","myStories","_lastMessage","listChats","onLine","lastMessageA","lastMessageB","countMessages","lenth","chatList","setChatList","findName","setFindName","chatDb","typing","setTyping","fontSite","splitName","avatarGroup","setUsersStatus","setOnLine","setChat","showFiles","setShowFiles","closeChat","toastFy","getElementsByClassName","chatData","updatedAt","Typing","closeButton","confirmRead","rootHide","topLogo","mainButton","logoMachen","nodeUpdate","appStyle","wrapper","mainPanel","mainPanelSidebarMini","pagesStyle","fullPage","audio","Audio","NotificationAudio","API_WS","StyledContainer","ToastContainer","whiteLabel","setWhiteLabel","setAuth","backdropEnabled","setBackdropEnabled","maintenance","offlineDetected","setOfflineDetected","appRoutes","setAppRoutes","stylesAdmin","stylesLogin","pageLoads","mainPanelClasses","connection","offline","verifyLabel","wl","verifySession","getItem","getRoutes","pageDataRequest","initCompleted","interval_id","setInterval","interval_status","sessionInterval","clearInterval","exitTime","verifyMessages","socketStatus","onlyToken","loadLanguages","Notification","requestPermission","initSocket","loadData","ignoreUsers","actualTokenUser","loadUsers","reqTagsA","reqGroups","reqUsers","h","initialLoader","handleDrawerToggle","socketIOClient","transports","newSocket","socketFunctions","authCallBack","CompRender","sk","hideiconvariant","dbUpdateCardSWOT","_sessionId","dbUpdateCard","myDayUpd","dbUpdateCardTimer","dbUpdateCard_V2","cardAccessDelete","cardAccessRemove","reorderCard","socketUnLinkChildrens","loads","reqMd5","changePlanId","updateColumnCards","reorderColumns","columnCards","timelineTyping","typingUser","play","onclick","dbUpdateFeed","notify","chatStatus","backdropTimer","notThis","LoaderPage","xsDown","Sidebar","SideModule","TopHeader","MiroBoard","Chat","getAuthRoutes","pauseOnFocusLoss","Root","exact","patch","Layout","tagsOver","CardTags","ShowOptions","setShowTags","showHiddenButton","setshowHiddenButton","setOptions","rounded","tt","iconText","alignItens","iconText_Text","CustomButtom","loadText","responseAdd","responseUPd","startTime","timerId","kpiTimer","myTask","_loaded","timelineAdd","new","nData","dbCardsDelete","childrensDelete","autoSave","forceUpdate","cardParent","loadNewCard","idCard","as","cardsToReorder","localAddCard","newCard","createDate","cardCopyTo","reqChildrenCards","rcc","parentColor","cardAccess","noInternal","noPlan","firstId","child","localUpdate","fid","_parentCompleted","xxi","newTotal","clients","clearFilter","dateStatus","notStarted","awaitAction","paused","inProgress","normal","setColor","saveColor","onDrag","onDragEnter","onDragCapture","onDragEnterCapture","op","disableAlpha","axios","create","baseURL","defaults","withCredentials","interceptors","use","headers","Authorization","Accept","defaultState","activeChats","AvatarIconColor","darkText","fieldRadius","lightText","mediumText","timelineMyMessage","kpiChange","toLoad","generate","saga","callBackFn","call","takeLatest","takeEvery","sagaMiddleware","createSagaMiddleware","createStore","combineReducers","dismissAll","dismissed","chatTyping","applyMiddleware","routerMiddleware","run","rootSaga","createBrowserHistory","first","second","last","kanban","price","onBoarding","activeLimit","task","uploadLimit","groupUsersLimit","support","mobile","addOn","learneng","denkenDiscount","technician","planLimit","groupLimit","GuidelineD","GuidelineR","GuidelineC","GuidelineE","BrightAndConnectedIcon","MicrosoftWord","MicrosoftExcel","MicrosoftPowerpoint","PDF","permissions","read","moderate","levels","requireFields","noId","loadChildrens","SwotIcon","allStatus","completedDays","reqData","mount","ndata","filterCards","cardCode","favorite","_myDay","inFlow","parentCompleted","startOf","endOf","_loadedFeeds","lineSmooth","Interpolation","cardinal","tension","chartPadding","emailsSubscriptionChart","responsiveOptions","seriesBarDistance","labelInterpolationFnc","draw","begin","dur","easing","completedTasksChart","clone","scale","chartRect","Svg","Easing","easeOutQuint","roundedLineChart","showPoint","straightLinesChart","point","simpleBarChart","colouredLineChart","multipleBarsChart","colouredLinesChart","pieChart","setBadgeVisible","toolTipOpen","setToolTipOpen","disableTouchListene","invisible"],"mappings":"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AnB,YAASmB,IAAU,IACnB,4BACAnB,YAASmB,IAAU,IACnB,UACF,kBAAmB,CACjBlP,gBAAiBkP,IAAU,GAC3BlG,UACE,0BACA+E,YAASmB,IAAU,IACnB,gCACAnB,YAASU,KACT,iCACAV,YAASmB,IAAU,IACnB,WAGNvS,QAAS,CACPqD,gBAAiBmP,IAAa,GAC9BnG,UACE,oBACA+E,YAASoB,IAAa,IACtB,gCACApB,YAASoB,IAAa,IACtB,4BACApB,YAASoB,IAAa,IACtB,UACF,kBAAmB,CACjBnP,gBAAiBmP,IAAa,GAC9BnG,UACE,0BACA+E,YAASoB,IAAa,IACtB,gCACApB,YAASU,KACT,iCACAV,YAASoB,IAAa,IACtB,WAGNC,QAAS,CACPpP,gBAAiBqP,IAAa,GAC9BrG,UACE,oBACA+E,YAASsB,IAAa,IACtB,gCACAtB,YAASsB,IAAa,IACtB,4BACAtB,YAASsB,IAAa,IACtB,UACF,kBAAmB,CACjBrP,gBAAiBqP,IAAa,GAC9BrG,UACE,0BACA+E,YAASsB,IAAa,IACtB,gCACAtB,YAASU,KACT,iCACAV,YAASsB,IAAa,IACtB,WAGNC,OAAQ,CACNtP,gBAAiBuP,IAAY,GAC7BvG,UACE,oBACA+E,YAASwB,IAAY,IACrB,gCACAxB,YAASwB,IAAY,IACrB,4BACAxB,YAASwB,IAAY,IACrB,UACF,kBAAmB,CACjBvP,gBAAiBuP,IAAY,GAC7BvG,UACE,0BACA+E,YAASwB,IAAY,IACrB,gCACAxB,YAASU,KACT,iCACAV,YAASwB,IAAY,IACrB,WAGNC,KAAM,CACJxP,gBAAiByP,IAAU,GAC3BzG,UACE,oBACA+E,YAAS0B,IAAU,IACnB,gCACA1B,YAAS0B,IAAU,IACnB,4BACA1B,YAAS0B,IAAU,IACnB,UACF,kBAAmB,CACjBzP,gBAAiByP,IAAU,GAC3BzG,UACE,0BACA+E,YAAS0B,IAAU,IACnB,gCACA1B,YAASU,KACT,iCACAV,YAAS0B,IAAU,IACnB,WAGNC,MAAO,CACL,oBAAqB,CACnB1P,gBAAiB8N,IACjB3S,MAAO0S,IAAU,KAGrB8B,QAAS,CACP3P,gBAAiB4P,IACjBzU,MAAO2S,IACP9E,UACE,oBACA+E,YAAS6B,KACT,gCACA7B,YAAS6B,KACT,4BACA7B,YAAS6B,KACT,UACF,4BAA6B,CAC3B5P,gBAAiB4P,IACjBzU,MAAO2S,IACP9E,UACE,0BACA+E,YAAS6B,KACT,gCACA7B,YAASU,KACT,iCACAV,YAAS6B,KACT,WAGNC,SAAU,CACR7P,gBAAiB8P,IACjB3U,MAAO2S,IACP9E,UACE,oBACA+E,YAAS+B,KACT,gCACA/B,YAAS+B,KACT,4BACA/B,YAAS+B,KACT,UACF,kBAAmB,CACjB9P,gBAAiB8P,IACjB3U,MAAO2S,IACP9E,UACE,0BACA+E,YAAS+B,KACT,gCACA/B,YAASU,KACT,iCACAV,YAAS+B,KACT,WAGNC,OAAQ,CACN/P,gBAAiBgQ,IACjB7U,MAAO2S,IACP9E,UACE,oBACA+E,YAASiC,KACT,gCACAjC,YAASiC,KACT,4BACAjC,YAASiC,KACT,UACF,kBAAmB,CACjBhQ,gBAAiBgQ,IACjB7U,MAAO2S,IACP9E,UACE,0BACA+E,YAASiC,KACT,gCACAjC,YAASU,KACT,iCACAV,YAASiC,KACT,WAGNC,SAAU,CACRjQ,gBAAiBkQ,IACjB/U,MAAO2S,IACP9E,UACE,oBACA+E,YAASmC,KACT,gCACAnC,YAASmC,KACT,4BACAnC,YAASmC,KACT,UACF,kBAAmB,CACjBlQ,gBAAiBkQ,IACjB/U,MAAO2S,IACP9E,UACE,0BACA+E,YAASmC,KACT,gCACAnC,YAASU,KACT,iCACAV,YAASmC,KACT,WAGNC,UAAW,CACTnQ,gBAAiBoQ,IACjBjV,MAAO2S,IACP9E,UACE,oBACA+E,YAASqC,KACT,gCACArC,YAASqC,KACT,4BACArC,YAASqC,KACT,UACF,kBAAmB,CACjBpQ,gBAAiBoQ,IACjBjV,MAAO2S,IACP9E,UACE,0BACA+E,YAASqC,KACT,gCACArC,YAASU,KACT,iCACAV,YAASqC,KACT,WAGNC,QAAS,CACPrQ,gBAAiBsQ,IACjBnV,MAAO2S,IACP9E,UACE,oBACA+E,YAASuC,KAC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A,SACA,eACA,mBACA,OACA,WACA,kBACA,YACA,aACA,QACA,eACA,SACA,iBACA,oBACA,iBACA,uBACA,gBACA,kBACA,cACA,iBACA,eACA,uBACA,qBACA,QACA,mBACA,OACA,eACA,UACA,iBACA,kBACA,cACA,YACA,cACA,YACA,aACA,SACA,iBACA,iBACA,cACA,MACA,OACA,WACA,eACA,cACA,cACA,iBACA,eACA,MACA,QACA,cACA,QACA,aACA,cACA,UACA,cACA,YACA,OACA,aACA,WACA,kBACA,WACA,aACA,eACA,eACA,cACA,QACA,cACA,iBACA,eACA,gBACA,cACA,QACA,UACA,MACA,QACA,UACA,aACA,OACA,cACA,eACA,gBACA,gBACA,UACA,qBACA,OACA,mBACA,qBACA,kBACA,iBACA,OACA,QACA,oBACA,OACA,QACA,2BACA,gBACA,QACA,kBACA,YACA,WACA,SACA,cACA,aACA,cACA,OACA,OACA,YACA,QACA,UACA,qBACA,WACA,YACA,WACA,iBACA,YACA,iBACA,cACA,WACA,eACA,cACA,oBACA,UACA,kBACA,eACA,cACA,YACA,SACA,WACA,WACA,UACA,UACA,kBACA,kBACA,wBACA,oBACA,0BACA,gBACA,aACA,iBACA,iBACA,OACA,qBACA,yBACA,aACA,gBACA,UACA,qBACA,iBACA,UACA,QACA,cACA,gBACA,kBACA,aACA,UACA,oBACA,SACA,uBACA,UACA,iBACA,UACA,qBACA,eACA,OACA,iBACA,SACA,OACA,WACA,SACA,aACA,WACA,wBACA,0BACA,qBACA,sBACA,gBACA,oBACA,yBACA,2BACA,2BACA,sBACA,wBACA,oBACA,iBACA,iBACA,kBACA,iBACA,OACA,WACA,eACA,kBACA,gBACA,eACA,SACA,gBACA,oBACA,aACA,YACA,QACA,gBACA,QACA,UACA,gBACA,yBACA,qBACA,UACA,aACA,yBACA,YACA,uBACA,WACA,oBACA,MACA,iBACA,aACA,iBACA,uBACA,0BACA,wBACA,qBACA,qBACA,WACA,aACA,WACA,iBACA,WACA,MACA,QACA,OACA,YACA,OACA,gBACA,YACA,gBACA,gBACA,cACA,YACA,gBACA,SACA,UACA,WACA,gBACA,iBACA,cACA,aACA,gBACA,cACA,WACA,gBACA,YACA,cACA,aACA,eACA,cACA,YACA,aACA,iBACA,iBACA,cACA,uBACA,OACA,WACA,eACA,UACA,uBACA,UACA,YAEJ,MAAS,CACL,YACA,cACA,QACA,gBACA,yBACA,WAEJ,GAAM,CACF,KACA,KACA,eACA,UACA,QACA,YACA,WACA,qBACA,iBACA,iBACA,0BACA,iBACA,YACA,WACA,eACA,cACA,qBACA,iBACA,YACA,sBACA,YACA,YACA,qBACA,aACA,aACA,YACA,QACA,KACA,UACA,mBACA,eACA,cACA,oBACA,gBACA,gBACA,OACA,MACA,WACA,UACA,oBACA,QACA,cACA,eACA,iBACA,OACA,QACA,sBACA,uBACA,aACA,qBACA,sBACA,eACA,qBACA,gBACA,QACA,cACA,kBACA,QACA,gBACA,oBACA,SACA,aACA,SACA,YACA,YACA,WACA,UACA,YACA,gBACA,oBACA,SACA,gBACA,QACA,OACA,cACA,gBACA,YACA,iBACA,aACA,cACA,gBACA,iBACA,WACA,eACA,cACA,cACA,aACA,YACA,MACA,aAEJ,cAAiB,CACb,cACA,kBACA,WACA,OACA,WACA,YACA,aACA,cACA,uBACA,gBACA,aACA,sBACA,OACA,cACA,sBACA,YACA,UACA,eACA,gBACA,WACA,0BACA,aACA,UACA,kBACA,sBACA,MACA,QACA,QACA,mBACA,mBACA,gBACA,kBACA,gBACA,oBACA,WACA,YACA,eACA,cACA,eACA,iBACA,mBACA,kBACA,oBACA,UACA,sBACA,YACA,MACA,SACA,qBACA,sBACA,gBACA,QACA,iBACA,gBACA,kBACA,iBACA,iBACA,kBACA,oBACA,iBACA,iBACA,UACA,kBACA,YACA,cACA,WACA,eACA,0BACA,gBACA,yBACA,wBACA,yBACA,wBACA,oBACA,aACA,UACA,cACA,YACA,UACA,gBAEJ,QAAW,CACP,MACA,UACA,aACA,qBACA,cACA,UACA,YACA,SACA,UACA,QACA,YACA,QACA,eACA,cACA,gBACA,SACA,eACA,SACA,eACA,YACA,cACA,OACA,gBACA,SACA,UACA,aACA,cACA,QACA,WACA,OACA,WACA,eACA,OACA,aACA,gBACA,YACA,gBACA,SACA,WACA,OACA,SACA,gBACA,wBACA,QACA,YACA,SACA,aACA,OACA,WACA,aACA,OACA,OACA,cACA,cACA,YACA,OACA,QACA,UACA,iBAEJ,OAAU,CACN,eACA,cACA,WACA,YACA,qBACA,sBACA,wBACA,gBACA,wBACA,eACA,cACA,kBACA,YACA,sBACA,qBACA,sBACA,kBACA,kBACA,iBACA,oBACA,aACA,iBACA,UACA,MACA,YACA,gBACA,UACA,aACA,oBACA,qBACA,kBACA,aACA,MACA,wBACA,uBACA,uBACA,kBACA,aACA,2BACA,wBACA,sBACA,8CACA,yBACA,uBACA,sBACA,oBACA,yBACA,kBACA,UACA,MACA,YACA,UACA,YACA,kBAEJ,OAAU,CACN,cACA,cACA,eACA,YACA,aACA,gBACA,eACA,oBACA,eACA,cACA,eACA,eACA,eACA,aACA,kBACA,eACA,cACA,sBACA,uBACA,oBACA,qBACA,cACA,eACA,qBACA,yBACA,yBACA,gBACA,sBACA,uBACA,uBACA,2BACA,eACA,eACA,gBACA,cACA,uBACA,8BACA,8BACA,oBACA,YACA,SACA,YACA,kBACA,eACA,wBACA,iBACA,oBACA,kBACA,oBACA,cACA,eACA,eACA,aACA,eACA,kBACA,YACA,kBACA,QACA,YACA,WACA,UACA,eACA,QACA,aACA,aACA,YACA,kBACA,YACA,cACA,cACA,aACA,cACA,QACA,wBACA,wBACA,qBACA,aAEJ,KAAQ,CACJ,eACA,aACA,QACA,eACA,aACA,iBACA,YACA,cACA,eACA,oBACA,SACA,cACA,gBACA,gBACA,cACA,iBACA,eACA,SAEJ,SAAY,CACR,wBACA,OACA,iBACA,qBACA,WACA,cACA,kBACA,kBACA,aACA,iBACA,gBACA,OACA,UACA,UACA,cACA,WACA,sBACA,sBACA,uBACA,oBACA,qBACA,oBACA,gBACA,kBACA,eACA,iBACA,SACA,oBACA,aACA,iBACA,SACA,QACA,gBACA,eACA,YACA,gBACA,gBACA,cACA,SACA,UACA,WACA,WACA,aACA,UACA,gBACA,SACA,iBACA,aACA,OACA,KACA,kBACA,SAEJ,KAAQ,CACJ,cACA,iBAEJ,MAAS,CACL,cACA,sBACA,gBACA,SACA,YACA,kBACA,aACA,UACA,gBACA,cACA,WACA,UACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,eACA,QACA,aACA,SACA,aACA,eACA,cACA,cACA,sBACA,oBACA,cACA,uBACA,aACA,WACA,UACA,gBACA,0BACA,OACA,YACA,WACA,WACA,WACA,WACA,YACA,iBACA,gBACA,gBACA,cACA,cACA,SACA,UACA,OACA,OACA,WACA,iBACA,iBACA,kBACA,kBACA,gBACA,SACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,WACA,gBACA,iBACA,sBACA,eACA,gBACA,aACA,cACA,oBACA,iBACA,QACA,aACA,YACA,WACA,OACA,sBACA,kBACA,WACA,QACA,WACA,UACA,UACA,SACA,aACA,WACA,UACA,QACA,qBACA,sBACA,eACA,MACA,YACA,WACA,cACA,OACA,gBACA,QACA,UACA,UACA,UACA,UACA,YACA,YACA,QACA,oBACA,mBACA,uBACA,iBACA,eACA,aACA,YACA,SACA,gBACA,kBACA,gBACA,UACA,WACA,oBACA,sBACA,oBACA,sBACA,QACA,cACA,eACA,eACA,gBACA,2BACA,0BACA,0BACA,iBACA,WACA,eACA,iBACA,wBACA,cACA,eACA,gBACA,YACA,aACA,QACA,gBACA,eACA,YACA,UACA,YACA,QACA,WACA,UACA,YACA,WACA,YACA,OACA,aACA,eACA,WACA,UACA,YACA,kBACA,gBACA,YAEJ,KAAQ,CACJ,MACA,eACA,eACA,mBACA,WACA,cACA,YACA,MACA,WACA,eACA,WACA,oBACA,sBACA,kBACA,kBACA,aACA,kBACA,kBACA,iBACA,iBACA,qBACA,iBACA,oBACA,qBACA,kBACA,kBACA,gBACA,YACA,gBACA,eACA,iBACA,mBACA,sBACA,aACA,WACA,SACA,WACA,sBACA,QACA,OACA,SACA,eACA,iBACA,gBACA,YACA,YACA,aACA,iBACA,0BACA,eACA,cACA,wBACA,gBACA,oBACA,sBACA,iBACA,cACA,wBACA,gBACA,aACA,eACA,cACA,gBACA,iBACA,cACA,cACA,aACA,eACA,oBACA,kBACA,YACA,iBACA,aACA,MACA,WACA,mBACA,YACA,yBACA,QACA,QACA,gBACA,SACA,cACA,aACA,UACA,mBACA,WACA,cACA,sBACA,aACA,aACA,oBACA,eACA,sBACA,WACA,QACA,WACA,cACA,aACA,kBACA,aACA,YACA,WACA,uBACA,aACA,SACA,UACA,UACA,QACA,OACA,4BACA,oBACA,cACA,cACA,WACA,iBACA,gBAEJ,WAAc,CACV,mBACA,OACA,aACA,iBACA,iBACA,kBACA,yBACA,gBACA,gBACA,oBACA,aACA,cACA,eACA,WACA,SACA,QACA,eACA,gBACA,QACA,eACA,OACA,cACA,cACA,aACA,aACA,kBACA,YACA,YACA,gBACA,OACA,YACA,aACA,YACA,QACA,aACA,aACA,WACA,UACA,QACA,aACA,aACA,0BACA,2BACA,cACA,eACA,cACA,cACA,QAEJ,aAAgB,CACZ,eACA,MACA,oBACA,2BACA,gCACA,6BACA,8BACA,+BACA,6BACA,8BACA,kBACA,sBACA,iBACA,YACA,YACA,sBACA,kBACA,aACA,aACA,iBACA,UACA,MACA,OACA,gBACA,iBACA,gBACA,iBACA,iBACA,0BACA,iBACA,kBACA,gBACA,eACA,eACA,eACA,QACA,YACA,gBACA,UACA,MACA,aACA,gBACA,OACA,gBACA,eACA,gBACA,eACA,gBACA,SACA,YACA,aACA,WACA,KACA,OACA,YAEJ,OAAU,CACN,UACA,kBACA,gBACA,YACA,wBACA,WACA,UACA,eACA,QACA,kBACA,YACA,SACA,mBACA,YACA,aACA,iBACA,iBACA,cACA,cACA,eACA,MACA,WACA,YACA,oBACA,kBACA,QACA,oBACA,iBACA,YACA,aACA,iBACA,cACA,QACA,UACA,QACA,eACA,UACA,eACA,YACA,gBACA,UACA,YACA,WACA,UACA,kBACA,iBACA,cACA,OACA,YACA,UACA,mBACA,eACA,YACA,aACA,gBACA,OACA,MACA,aACA,SACA,aACA,WACA,QACA,MACA,WACA,OACA,eACA,qBAEJ,OAAU,CACN,aACA,eACA,cACA,OACA,cACA,0BACA,eACA,cACA,OACA,SACA,UACA,iBACA,eACA,cACA,sBACA,eACA,gBACA,eACA,gBACA,uBACA,cACA,YACA,mBACA,QACA,YACA,cACA,WACA,qBACA,gBACA,QACA,gBACA,OACA,WACA,cACA,gBACA,uBACA,qBACA,oBACA,uBACA,gBACA,QACA,aACA,SACA,aACA,iBACA,SACA,aACA,mBACA,iBACA,gBACA,WACA,OACA,aACA,SACA,aACA,kBACA,YACA,SACA,UACA,mBACA,yBACA,sBACA,8BACA,2BACA,QACA,OACA,aACA,SACA,kBACA,oBACA,iBACA,iBACA,kBACA,cACA,kBACA,gBACA,iBACA,aACA,qBACA,eACA,gBACA,gBACA,oBACA,iBACA,eACA,YAEJ,OAAU,CACN,YACA,0BACA,0BACA,uBACA,yBACA,OACA,cACA,YACA,eACA,aACA,cCv0CO7kB,GAzEK,CAChBuH,OAAO,2BACA1C,KAAW,IACd3X,QAAS,OACTC,MAAO,OACPE,eAAgB,kBAEpBP,QAAS,CACLwB,SAAU,WACVnB,MAAO,OACPyL,OAAQ,OACR1L,QAAS,QAEb8B,KAAM,CACF9B,QAAS,OACTC,MAAO,OACP8K,WAAY,UAEhBiY,WAAY,CACRhjB,QAAS,WACT+K,WAAY,UAEhBkY,YAAa,CACThjB,MAAO,oBAEPijB,UAAW,SACXpK,UAAW,SACX7T,WA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","file":"static/js/main.e977fcd5.chunk.js","sourcesContent":["import React from \"react\";\r\nimport { toast } from 'react-toastify'\r\nimport MD5 from \"crypto-js/md5\"\r\nimport moment from \"moment-timezone\"\r\n\r\n//REDUX\r\nimport reduxStore from \"store/\"\r\n\r\n//COMPONENTS\r\nimport CustomButton from \"components/Buttons/custom\"\r\n\r\n//FUNCTIONS\r\nimport api from \"api/\";\r\nrequire('dotenv').config()\r\n\r\nconst languageADD = window.location.hostname.indexOf('localhost') > -1 && String(process.env.REACT_APP_PROD) === 'true' ? true : false\r\n//const languageADD = false\r\n\r\nconst translate = (al, style) => {\r\n    if (al) {\r\n        const words = reduxStore.getState().languages || {}\r\n        const { session } = reduxStore.getState()\r\n\r\n        let language = session && session.language ? session.language : 'pt-BR'\r\n        // let language = 'pt-BR'\r\n\r\n        let newText = al\r\n\r\n        if (al && al.indexOf('$__') > -1) {\r\n            al.split(' ').map((a, i) => {\r\n                if (a && a.indexOf('$__') > -1) {\r\n                    let word = a.replace('$__', '').trim().toLowerCase()\r\n                    if (languageADD && !words[word]) {\r\n                        console.log(\"add\", word)\r\n                        try {\r\n                            api.post(\"language/add\", {\r\n                                name: word\r\n                            })\r\n                        } catch (e) {\r\n                            console.log(e)\r\n                        }\r\n                    }\r\n                    if (words[word] && words[word].locales.filter(a => a.locale === language).length > 0 && words[word].locales.filter(a => a.locale === language)[0].name) {\r\n                        newText = newText.replace(`${a}`, `${i > 0 ? ` ` : ``}${words[word].locales.filter(a => a.locale === language)[0].name}`)\r\n                    }\r\n                }\r\n            })\r\n        } else {\r\n            return al\r\n        }\r\n\r\n        let result = newText\r\n\r\n        if (!result)\r\n            return ''\r\n\r\n        if (!style)\r\n            return result\r\n\r\n        if (style === '*')//ALL Upper Case\r\n            return result.toUpperCase()\r\n\r\n        if (style === 1) //First Letter Upper Case\r\n            return result.substring(0, 1).toUpperCase().concat(result.substring(1))\r\n    }\r\n}\r\n\r\nfunction nl2br(str, is_xhtml, break1 = \"<br/>\", break2 = \"<br>\") {\r\n    if (typeof str === 'undefined' || str === null) {\r\n        return '';\r\n    }\r\n    var breakTag = (is_xhtml || typeof is_xhtml === 'undefined') ? break1 : break2;\r\n    return (str + '').replace(/([^>\\r\\n]?)(\\r\\n|\\n\\r|\\r|\\n)/g, '$1' + breakTag + '$2');\r\n}\r\n\r\n\r\nfunction hexToRgba(str, opacity) {\r\n    if (/^#([0-9a-f]{3}|[0-9a-f]{6})$/ig.test(str)) {\r\n        var hex = str.substr(1);\r\n        hex = hex.length == 3 ? hex.replace(/(.)/g, '$1$1') : hex;\r\n        var rgb = parseInt(hex, 16);\r\n        return `rgba(${[(rgb >> 16) & 255, (rgb >> 8) & 255, rgb & 255]}, ${opacity || 1})`;\r\n    }\r\n    if (opacity && str && str.indexOf('rgb') > -1 && str.indexOf('rgba') === -1) {\r\n        return str.replace(')', `, ${opacity})`).replace('rgb(', 'rgba(');\r\n    } else {\r\n        return str;\r\n    }\r\n}\r\nfunction rgbaToHex(color) {\r\n    let colorSplit = color.replace('rgba(', '').replace(')', '').split(',')\r\n}\r\n\r\nfunction customApp(prop, opacity) {\r\n    if (reduxStore) {\r\n        const props = reduxStore.getState().session.custom\r\n        return hexToRgba(props[prop], opacity) || prop\r\n    }\r\n}\r\n\r\nfunction validateEmail(email) {\r\n    var filter = /^([\\w-]+(?:\\.[\\w-]+)*)@((?:[\\w-]+\\.)*\\w[\\w-]{0,66})\\.([a-z]{2,6}(?:\\.[a-z]{2})?)$/i;\r\n    if (!filter.test(email)) {\r\n        return false\r\n    } else {\r\n        return true\r\n    }\r\n}\r\n\r\n/**\r\n * \r\n * @param {message} string\r\n * @param {variant} string //warning, danger, info, success or null \r\n * @param {confirm} function //TRUE-FALSE\r\n * @param {closed} boolean //TRUE-FALSE\r\n * @param {persist} boolean // TRUE-FALSE\r\n * @param {content} //HTML\r\n * @param {vertical} options // Vertical position // top, center, bottom\r\n * @param {horizontal} options // Horizontal position // left, center, right\r\n * @param {time} seconds // time to auto hide -> Default 3000\r\n */\r\n\r\n\r\n\r\nfunction appAlert(options = {}) {\r\n    let key = MD5(JSON.stringify(options)).toString()\r\n\r\n    let content = options.content ? options.content : options.message\r\n    if (options.confirm)\r\n        content = (\r\n            <div style={{ minWidth: \"300px\" }}>\r\n                {content}\r\n                <div style={{ display: \"flex\", width: \"100%\", marginTop: 15, justifyContent: \"center\" }}>\r\n                    <CustomButton\r\n                        shadow\r\n                        title={translate(\"$__confirm\")}\r\n                        text={translate(\"$__confirm\")}\r\n                        color=\"green\"\r\n                        icon={\"check\"}\r\n                        size={\"25px\"}\r\n                        onClick={() => {\r\n                            options.confirm()\r\n                            toast.dismiss(key)\r\n                        }}\r\n\r\n                    />\r\n                    <CustomButton\r\n                        shadow\r\n                        title={translate(\"$__cancel\")}\r\n                        text={translate(\"$__cancel\")}\r\n                        color=\"red\"\r\n                        icon={\"close\"}\r\n                        size={\"25px\"}\r\n                        onClick={() => {\r\n                            toast.dismiss(key)\r\n                        }}\r\n                        style={{ marginLeft: 15 }}\r\n                    />\r\n                </div>\r\n            </div>\r\n        )\r\n\r\n    if (options.buttons && options.buttons.length > 0)\r\n        content = (\r\n            <div style={{ minWidth: \"300px\" }}>\r\n                {content}\r\n                <div style={{ width: \"100%\", marginTop: 15, justifyContent: \"center\" }}>\r\n                    {options.buttons.map((b, bi) =>\r\n                        <CustomButton\r\n                            key={bi}\r\n                            {...b}\r\n                            style={{\r\n                                ...options && options.style ? options.style : {},\r\n                                marginBottom: 10\r\n                            }}\r\n                            onClick={() => {\r\n                                if (b.onClick)\r\n                                    b.onClick()\r\n                                toast.dismiss(key)\r\n                            }}\r\n\r\n                        />\r\n                    )}\r\n                </div>\r\n            </div>\r\n        )\r\n\r\n    let toastOptions = {\r\n        toastId: key,\r\n        position: toast.POSITION.BOTTOM_RIGHT,\r\n        ...options.options ? options.options : {},\r\n        ...!options.persist ? { autoClose: options.autoClose ? options.autoClose : 2000 } : {},\r\n        style: { minWidth: \"300px\" },\r\n    }\r\n\r\n    if (options.horizontal === 'left')\r\n        toastOptions = {\r\n            ...toastOptions,\r\n            position: toast.POSITION.BOTTOM_LEFT\r\n        }\r\n    if (options.horizontal === 'right')\r\n        toastOptions = {\r\n            ...toastOptions,\r\n            position: toast.POSITION.BOTTOM_RIGHT\r\n        }\r\n    if (options.horizontal === 'center')\r\n        toastOptions = {\r\n            ...toastOptions,\r\n            position: toast.POSITION.BOTTOM_CENTER\r\n        }\r\n\r\n\r\n    if (!toast.isActive(key)) {\r\n        if (options.variant === 'info' || !options.variant)\r\n            toast.info(content, toastOptions)\r\n\r\n        if (options.variant === 'success')\r\n            toast.success(content, toastOptions)\r\n\r\n        if (options.variant === 'warning')\r\n            toast.warn(content, toastOptions)\r\n\r\n        if (options.variant === 'error')\r\n            toast.error(content, toastOptions)\r\n    }\r\n    return true\r\n}\r\n\r\nconst decimal = (val, digits = 2) => {\r\n    if (!val)\r\n        return ``\r\n\r\n    let value = val.replace(/\\D/g, '')\r\n    if ((value.match(/./g) || []).length > 1) {\r\n        value = val.replace(',', '.')\r\n        let nv = value.split('.')\r\n        if (nv.length === 1)\r\n            return parseFloat(value)\r\n        value = value.replaceAll(`.${nv[nv.length - 1]}`, ``)\r\n        value = String(value).replaceAll('.', '')\r\n        let decimal = nv[nv.length - 1].substring(0, digits)\r\n        value = `${value}.${decimal}`\r\n    }\r\n    return value\r\n}\r\n\r\nconst formatNumber = (a, s = 'decimal', currency) => {\r\n    if (!a)\r\n        return ''\r\n    const { session } = reduxStore.getState()\r\n\r\n    let value = String(a).replace(',', '.')\r\n    let style = s\r\n\r\n\r\n    if (style === 'number' || style === 'time' || style === 'decimal') {\r\n        style = 'decimal'\r\n    } else if (style === 'percent') {\r\n        return `${value}%`\r\n        // value = value / 100\r\n    } else if (style !== 'currency') {\r\n        return String(a)\r\n    }\r\n\r\n    let result = new Intl.NumberFormat(session.custom.locale, { style: style, currency: currency ? currency : session.custom.currency ? session.custom.currency : 'BRL' })\r\n\r\n    result.setMaximumFractionDigits = s === 'number' ? 0 : 2\r\n    return result.format(value)\r\n}\r\n\r\nconst languageUPD = (props, data) => {\r\n\r\n    let newLocales = reduxStore.getState().languages[data.alias] && reduxStore.getState().languages[data.alias].locales ? Array.from(reduxStore.getState().languages[data.alias].locales) : []\r\n\r\n    newLocales.flatMap(a => {\r\n        if (a.locale === data.locale)\r\n            return [a.name = data.text]\r\n    })\r\n    if (newLocales.filter(lc => lc.locale === data.locale).length === 0)\r\n        newLocales.push({\r\n            _id: data._id,\r\n            locale: data.locale,\r\n            name: data.text\r\n        })\r\n\r\n    props.reduxFunction(\"ASYNC\", \"SET_LANGUAGE\", {\r\n        ...reduxStore.getState().languages,\r\n        [data.alias]: {\r\n            ...reduxStore.getState().languages[data.alias] && reduxStore.getState().languages[data.alias],\r\n            locales: newLocales\r\n        }\r\n    });\r\n}\r\n\r\nconst deleteNode = async (props, data, onlyRedux, childrensDelete = false) => {\r\n    let { db } = reduxStore.getState()\r\n    let nodeType = 'cards'\r\n    if (db.cards[data._id]) {\r\n        nodeType = 'cards'\r\n    } else if (db.users[data._id]) {\r\n        nodeType = 'users'\r\n    }\r\n\r\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n        ...reduxStore.getState().db,\r\n        [nodeType]: {\r\n            ...reduxStore.getState().db[nodeType],\r\n            [data._id]: {\r\n                ...reduxStore.getState().db[nodeType][data._id],\r\n                deleted: true\r\n            }\r\n        }\r\n    });\r\n}\r\nconst removeSeats = (str) => {\r\n    let seats = \"ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖØÙÚÛÜÝŔÞßàáâãäåæçèéêëìíîïðñòóôõöøùúûüýþÿŕ\";\r\n    let cleanStr = \"AAAAAAACEEEEIIIIDNOOOOOOUUUUYRsBaaaaaaaceeeeiiiionoooooouuuuybyr\";\r\n\r\n    let newStr = \"\";\r\n    for (let i = 0; i < str.length; i++) {\r\n        let change = false;\r\n        for (let a = 0; a < seats.length; a++) {\r\n            if (str.substr(i, 1) == seats.substr(a, 1)) {\r\n                newStr += cleanStr.substr(a, 1);\r\n                change = true;\r\n                break;\r\n            }\r\n        }\r\n        if (change == false) {\r\n            newStr += str.substr(i, 1);\r\n        }\r\n    }\r\n    return newStr;\r\n}\r\n\r\nconst Highlighted = (text, highlight, dark) => {\r\n    if (!highlight || (highlight && !highlight.trim())) {\r\n        return <span style={{ wordBreak: \"break-word\" }} dangerouslySetInnerHTML={{\r\n            __html: nl2br(text)\r\n        }} />\r\n    }\r\n    let newText = nl2br(text)\r\n    const parts = newText.split(new RegExp(`(${highlight.replace('*.', '.')})`, 'gi'));\r\n    return (\r\n        <span> {parts.map((part, i) =>\r\n            <span key={i} style={part.toLowerCase() === highlight.toLowerCase() ? { fontWeight: 'bold', paddingTop: '3px', paddingBottom: '3px', backgroundColor: '#ffff00b3', color: dark ? '#000000 !important' : '' } : {}}\r\n                dangerouslySetInnerHTML={{\r\n                    __html: nl2br(part)\r\n                }}\r\n            >\r\n            </span>)\r\n        } </span>\r\n    )\r\n}\r\n\r\nconst links = (text) => {\r\n    let newText = nl2br(text)\r\n    const lines = newText.split(\"\\n\")\r\n\r\n    let result = \"\"\r\n    lines.map((ln) => {\r\n        const parts = ln.split(\" \")\r\n        parts.map(ppar => {\r\n            let lln = ppar.split(\"\\n\")\r\n            if (lln.length > 0) {\r\n                lln.map((par) => {\r\n                    if (par.indexOf(\".youtube.com/watch?\") > -1) {\r\n                        let ybQuery = par.split(\"?\")[1].split(\"v=\")[1].split(\"&\")[0]\r\n                        if (ybQuery)\r\n                            result += `<iframe width=\"560\" height=\"315\" style=\"width:100%; max-width:500px\" src=\"https://www.youtube.com/embed/${ybQuery}\" title=\"YouTube video player\" frameBorder=\"0\" allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>`\r\n                    } else if (par.indexOf(\"//youtu.be/\") > -1) {\r\n                        let ybQuery = par.split(\".be/\")[1]\r\n                        if (ybQuery)\r\n                            result += `<iframe width=\"560\" height=\"315\" style=\"width:100%; max-width:500px\" src=\"https://www.youtube.com/embed/${ybQuery}\" title=\"YouTube video player\" frameBorder=\"0\" allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>`\r\n                    } else if (par.indexOf(\"http://\") > -1 || par.indexOf(\"https://\") > -1) {\r\n                        result += `<a style=\"word-break:break-all\" href=\"${par.replace('<br/>', '')}\" target=\"_blank\">${par}</a>`\r\n                    } else {\r\n                        result += par\r\n                    }\r\n                })\r\n                result += \" \"\r\n            } else if (lln[0].indexOf(\".youtube.com/watch?\") > -1\r\n                && lln[0].split(\"?\").length > 1\r\n                && lln[0].split(\"?\")[1].split(\"v=\").length > 1\r\n            ) {\r\n                let ybQuery = lln[0].split(\"?\")[1].split(\"v=\")[1].split(\"&\")[0]\r\n                if (ybQuery)\r\n                    result += `<iframe width=\"560\" height=\"315\" style=\"width:100%; max-width:500px\" src=\"https://www.youtube.com/embed/${ybQuery}\" title=\"YouTube video player\" frameBorder=\"0\" allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>`\r\n            } else if (lln[0].indexOf(\"http://\") > -1 || lln[0].indexOf(\"https://\") > -1) {\r\n                result += `<a href=\"${lln[0].replace('<br/>', '')}\" target=\"_blank\">${lln[0]} </a>`\r\n            } else {\r\n                result += `${ppar} `\r\n            }\r\n        })\r\n        result += \"\"\r\n    })\r\n    return result\r\n}\r\n\r\nconst readedNotifications = (props, nodes) => {\r\n    let socket\r\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\r\n        socket = reduxStore.getState().functions.socket\r\n    } else {\r\n        socket = reduxStore.getState().functions.socket\r\n    }\r\n    let notification = reduxStore.getState().notifications\r\n    Object.keys(notification).map(a => {\r\n        if (nodes && nodes.indexOf(a) > -1)\r\n            notification[a] = {\r\n                ...notification[a],\r\n                readed: true\r\n            }\r\n    })\r\n    socket.emit(\"data\", {\r\n        module: \"notifications\",\r\n        method: \"put\",\r\n        action: \"readed\",\r\n    }, {\r\n        nodes\r\n    })\r\n    props.reduxFunction(\"ASYNC\", \"SET_NOTIFICATIONS\", {\r\n        ...reduxStore.getState().notifications,\r\n        ...notification\r\n    });\r\n}\r\n\r\nconst getAppAccess = () => {\r\n    const { session } = reduxStore.getState()\r\n    let AppAccess = {}\r\n    if (session && session._access)\r\n        AppAccess = session._access\r\n    return AppAccess\r\n}\r\n\r\nconst favoriteNode = async (props, _id, del = false) => {\r\n    const { db } = reduxStore.getState()\r\n    if (!del) {\r\n        try {\r\n            const response = await api.put('/node/favorite', { _id })\r\n        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    } else {\r\n        try {\r\n            const response = await api.delete(`/node/favorite/${_id}`)\r\n        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    }\r\n}\r\n\r\nconst padZero = (a) => {\r\n    var s = a;\r\n    while (s.length === 1) {\r\n        s = '0' + s;\r\n    }\r\n    return s;\r\n};\r\n\r\nconst textColor = (reqColor, bw, light = '#FFFFFF', dark = '#000000') => {\r\n    let color = reqColor\r\n    var r,\r\n        g,\r\n        b\r\n\r\n    if (color.indexOf('rgba') > -1) {\r\n        color = color.replace('rgba(', '')\r\n        let colors = color.split(',')\r\n        r = colors[0]\r\n        g = colors[1]\r\n        b = colors[2]\r\n    } else {\r\n        if (color.indexOf('#') === 0) {\r\n            color = color.slice(1);\r\n        }\r\n        if (color.length === 3) {\r\n            color = color[0] + color[0] + color[1] + color[1] + color[2] + color[2];\r\n        }\r\n        if (color.length !== 6) {\r\n            throw new Error('Invalid HEX color.');\r\n        }\r\n        r = parseInt(color.slice(0, 2), 16)\r\n        g = parseInt(color.slice(2, 4), 16)\r\n        b = parseInt(color.slice(4, 6), 16)\r\n    }\r\n\r\n    if (bw) {\r\n        return (r * 0.299 + g * 0.587 + b * 0.114) > 186\r\n            ? dark\r\n            : light\r\n    }\r\n    r = (255 - r).toString(16);\r\n    g = (255 - g).toString(16);\r\n    b = (255 - b).toString(16);\r\n    return \"#\" + padZero(r) + padZero(g) + padZero(b);\r\n}\r\n\r\nconst getDate = (d) => {\r\n    let date = 0\r\n    if (d?.low) {\r\n        date = parseInt(d.low)\r\n    } else {\r\n        date = parseInt(d)\r\n    }\r\n    if (moment(new Date()).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") === moment(date * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")) {\r\n        return moment(date * 1000).tz(\"America/Sao_Paulo\").format(\"H:mm\")\r\n    } else if (moment(new Date()).tz(\"America/Sao_Paulo\").format(\"YYYY\") === moment(date * 1000).tz(\"America/Sao_Paulo\").format(\"YYYY\")) {\r\n        return moment(date * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM H:mm\")\r\n    } else {\r\n        return moment(date * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")\r\n    }\r\n}\r\n\r\nfunction formatSizeUnits(bytes) {\r\n    if (bytes >= 1073741824) { bytes = (bytes / 1073741824).toFixed(2) + \" GB\"; }\r\n    else if (bytes >= 1048576) { bytes = (bytes / 1048576).toFixed(2) + \" MB\"; }\r\n    else if (bytes >= 1024) { bytes = (bytes / 1024).toFixed(2) + \" KB\"; }\r\n    else if (bytes > 1) { bytes = bytes + \" bytes\"; }\r\n    else if (bytes == 1) { bytes = bytes + \" byte\"; }\r\n    else { bytes = \"0 bytes\"; }\r\n    return bytes;\r\n}\r\n\r\n// const units = ['bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];\r\n\r\nfunction BytesConvert(bytes, decimals = 2) {\r\n    if (bytes === 0) return '0 Bytes';\r\n    const k = 1024;\r\n    const dm = decimals < 0 ? 0 : decimals;\r\n    const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\r\n    return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + ' ' + sizes[i];\r\n}\r\n\r\nexport {\r\n    BytesConvert,\r\n    Highlighted,\r\n    appAlert,\r\n    customApp,\r\n    decimal,\r\n    deleteNode,\r\n    favoriteNode,\r\n    formatNumber,\r\n    formatSizeUnits,\r\n    getAppAccess,\r\n    getDate,\r\n    hexToRgba,\r\n    languageUPD,\r\n    links,\r\n    nl2br,\r\n    readedNotifications,\r\n    removeSeats,\r\n    rgbaToHex,\r\n    textColor,\r\n    translate,\r\n    validateEmail,\r\n}","module.exports = __webpack_public_path__ + \"static/media/googlePlay-ptBR.6583181e.png\";","module.exports = __webpack_public_path__ + \"static/media/appleStore-ptBR.2049e321.png\";","module.exports = \"data:image/png;base64,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\"","import React from \"react\";\r\nimport moment from \"moment-timezone\";\r\nimport styled from \"styled-components\";\r\n\r\n//REDUX\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport { connect } from \"react-redux\";\r\n\r\n//COMPONENTS\r\nimport Badge from \"components/Icon/Badge\";\r\nimport CardTags from \"components/Tags/Card\";\r\nimport NotificationCount from \"components/NotificationsV2/count\";\r\nimport HtmlTooltip from \"components/Tooltip/html\"\r\nimport Icon from \"components/Icon\"\r\n\r\n//@MATERIAL\r\nimport Avatar from \"@material-ui/core/Avatar\";\r\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\";\r\nimport Tooltip from \"@material-ui/core/Tooltip\";\r\nimport { withStyles } from \"@material-ui/core/styles\";\r\n\r\n//STYLES\r\nimport styles from \"assets/jss/material-dashboard-pro-react/components/CardSimple.js\";\r\n\r\n//IMAGES\r\nimport defaultAvatar from \"assets/img/fundo-sonne.png\"\r\n\r\n//FUNCTIONS\r\nimport { translate, customApp } from \"functions/\";\r\n\r\nconst Container = styled.div`\r\n${props =>\r\n        props.selectable && props.selected ? `\r\n    opacity:1;`\r\n            : props.selectable ? `\r\n    opacity:0.5;`\r\n                : ``\r\n    }\r\n${props =>\r\n        props.locked ?\r\n            `cursor:no-drop !important;`\r\n            : `cursor:pointer;`\r\n    }\r\n${props =>\r\n        props.priority ?\r\n            `border-left:5px solid ${props.priority};`\r\n            : ``\r\n    }\r\n${props =>\r\n        !props.selectable && props.selected ?\r\n            `border-bottom:solid 5px ${customApp(\"color\")};`\r\n            : ``\r\n    }\r\n${props =>\r\n        props.isDragDisable\r\n            ? \"\"\r\n            : props.isDragging\r\n                ? `opacity:0.88;\r\n                 max-width:320px;`\r\n                : ``\r\n    }\r\n${props =>\r\n        props.inLine ?\r\n            `position:relative;\r\n            float:left;\r\n            margin:1px;\r\n            width:calc(20% - 7px);\r\n            // maxWidth:320px;\r\n            `\r\n            : `\r\n            width:calc(100%) !important;\r\n            margin:1px 0px 1px 0px;\r\n            `\r\n    }\r\n    width:calc(100%) !important;\r\n    margin-top:7px;\r\n    margin-right:7px;\r\n    padding:15px;\r\n`\r\nfunction Card(props) {\r\n    const { classes } = props;\r\n    const { socket } = reduxStore.getState().functions\r\n    const { db } = reduxStore.getState();\r\n    const [activeStep, setActiveStep] = React.useState(0);\r\n\r\n    let data = props.data && props.data._id ? reduxStore.getState().db.cards[props.data._id] : {}\r\n\r\n    let steps = Object.keys(reduxStore.getState().db.cards).filter(card =>\r\n        reduxStore.getState().db.cards[card]._parent === reduxStore.getState().db.cards[data._parent]._parent\r\n        && reduxStore.getState().db.cards[card].type === \"step\"\r\n        && !reduxStore.getState().db.cards[card].deleted\r\n    )\r\n        .sort((a, b) => {\r\n            let orderA = parseInt(reduxStore.getState().db.cards[a].step),\r\n                orderB = parseInt(reduxStore.getState().db.cards[b].step)\r\n\r\n            if (orderA < orderB)\r\n                return -1\r\n            if (orderA > orderB)\r\n                return 1\r\n            return 0\r\n        }).map(card => reduxStore.getState().db.cards[card])\r\n\r\n    return (\r\n        <Container\r\n            {...props.provided && props.provided.draggableProps}\r\n            ref={props.provided && props.provided.innerRef}\r\n            isDragging={props.snapshot && props.snapshot.isDragging}\r\n            isDragDisable={data.isDragDisable || props.isDragDisable || false}\r\n            inLine={props.inLine}\r\n            className={classes.container}\r\n            selectable={props.showSelected}\r\n            selected={data._selected}\r\n            priority={data.priority ? db.priority.filter(a => String(a.value) === String(data.priority))[0].color : null}\r\n            locked={props.locked || false}\r\n            onClick={() => {\r\n                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\r\n                    ...reduxStore.getState().sideModule,\r\n                    db: 'cards',\r\n                    id: data._id,\r\n                    module: \"cardEdit\",\r\n                    activeModule: reduxStore.getState().db.dataType.filter(a => a.name === data.type)[0].iniModule || module,\r\n                    data: data,\r\n                })\r\n            }}\r\n        >\r\n            <div {...props.provided && props.provided.dragHandleProps}>\r\n\r\n                <div\r\n                    style={{\r\n                        position: 'relative',\r\n                        alignItems: 'center'\r\n                    }}\r\n                >\r\n                    <div style={{\r\n                        width: '100%',\r\n                        padding: '7px',\r\n                        display: \"flex\",\r\n                        justifyContent: \"space-between\",\r\n                    }}>\r\n                        {data.name ? data.name : translate(\"$__new\", 1)}\r\n                        <NotificationCount nodeId={data._id} />\r\n                    </div >\r\n                    <div style={{\r\n                        position: \"relative\",\r\n                        float: \"left\",\r\n                        width: \"100%\"\r\n                    }}>\r\n                        <div>{translate(\"$__step\", \"*\")} {steps.findIndex(a => a._id === data._parent) + 1} {translate(\"$__of\")} {steps.length}</div>\r\n                        <div\r\n                            style={{\r\n                                position: \"relative\",\r\n                                width: \"100%\",\r\n                                border: \"solid 1px rgba(0,0,0,0.1)\",\r\n                                justifyContent: \"space-between\",\r\n                                display: \"flex\",\r\n                                alignItems: \"center\",\r\n                                borderRadius: 7\r\n                            }}\r\n                        >\r\n                            {steps.map((x, xi) =>\r\n                                <HtmlTooltip\r\n                                    arrow\r\n                                    title={(\r\n                                        <div>\r\n                                            {x.name} ({steps.findIndex(a => a._id === data._parent) > xi ? translate(`$__completed`) : steps.findIndex(a => a._id === data._parent) === xi ? translate(`$__${data.status}`) : translate(`$__waitingForPreviousStep`)})\r\n                                        </div>\r\n                                    )\r\n                                    } >\r\n                                    <div\r\n                                        key={x._id}\r\n                                        style={{\r\n                                            height: 7,\r\n                                            ...steps.findIndex(a => a._id === data._parent) > xi ? { backgroundColor: \"#02b915\" } : {},\r\n                                            ...steps.findIndex(a => a._id === data._parent) === xi ? { backgroundColor: \"#00a2e9\" } : {},\r\n                                            ...steps.findIndex(a => a._id === data._parent) < xi ? { backgroundColor: \"#e9e9e9\" } : {},\r\n                                            width: \"-webkit-fill-available\",\r\n                                            border: \"solid 1px #FFFFFF\"\r\n                                        }}></div>\r\n                                </HtmlTooltip>\r\n                            )}\r\n                            <HtmlTooltip\r\n                                arrow\r\n                                title={(\r\n                                    <div>\r\n                                        {translate(`$__${data.status}`, '*')}\r\n                                    </div>\r\n                                )\r\n                                } >\r\n                                <div>\r\n                                    <Icon color={reduxStore.getState().db.status.filter(st => st.value === data.status)[0].color}>{reduxStore.getState().db.status.filter(st => st.value === data.status)[0].icon}</Icon>\r\n                                </div>\r\n                            </HtmlTooltip>\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div style={{\r\n                        width: '100%', padding: '7px',\r\n                        clear: \"both\"\r\n                    }}>\r\n                        {((data.startDate || data.endDate) || (data.startDate || data.endDate)) &&\r\n                            <div className={classes.dates}>\r\n                                {data.startDate &&\r\n                                    <div className={classes.dateInfo}>\r\n                                        <Badge\r\n                                            overlap=\"rectangular\"\r\n                                            className={classes.dateIco} icon=\"insert_invitation\" title={\"startDate\"} size=\"14px\" disabled />\r\n                                        {(new Date(data.startDate * 1000) instanceof Date && !isNaN(new Date(data.startDate * 1000))) ?\r\n                                            moment(new Date(data.startDate * 1000)).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\r\n                                            :\r\n                                            moment(data.startDate).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\r\n                                        }\r\n                                    </div>\r\n                                }\r\n                                {data.endDate &&\r\n                                    <div className={classes.dateInfo}>\r\n                                        <Badge\r\n                                            overlap=\"rectangular\"\r\n                                            className={classes.dateIco} icon=\"event_available\" title={\"endDate\"} size=\"14px\" disabled />\r\n                                        {(new Date(data.endDate * 1000) instanceof Date && !isNaN(new Date(data.endDate * 1000))) ?\r\n                                            moment(new Date(data.endDate * 1000)).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\r\n                                            :\r\n                                            moment(data.endDate).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\r\n                                        }\r\n                                    </div>\r\n                                }\r\n                            </div>\r\n                        }\r\n                        {data && data._users && Object.keys(data._users).length > 1 &&\r\n                            <div className={classes.usersContent}>\r\n                                <div className={classes.users}>\r\n                                    <AvatarGroup max={4}>\r\n                                        {Object.keys(data._users).map((a, i) => {\r\n                                            if (data._users[a] && data._users[a].name)\r\n                                                return (\r\n                                                    <Tooltip\r\n                                                        title={data._users[a].name}\r\n                                                        key={i}\r\n                                                    >\r\n                                                        <Avatar alt={data._users[a].name} src={data._users[a].image || defaultAvatar} >\r\n                                                            {data._users[a].name.substr(0, 1)}\r\n                                                        </Avatar>\r\n                                                    </Tooltip>\r\n                                                )\r\n                                        })}\r\n                                    </AvatarGroup>\r\n                                </div>\r\n                            </div>\r\n                        }\r\n                    </div>\r\n                    <CardTags options={data._tags} showOptions={false} />\r\n\r\n                </div>\r\n            </div>\r\n\r\n        </Container>\r\n    )\r\n}\r\n\r\n//REACT\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch);\r\n\r\nexport default connect(\r\n    null,\r\n    mapDispatchToProps\r\n)(withStyles(styles)(Card));","module.exports = __webpack_public_path__ + \"static/media/Mockup_App_WEB.0ed158a4.png\";","module.exports = __webpack_public_path__ + \"static/media/supportMockup.ec51b4aa.png\";","module.exports = __webpack_public_path__ + \"static/media/notification.d7241ff2.mp3\";","//\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"@material-ui/icons/utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(_react.default.Fragment, null, _react.default.createElement(\"path\", {\n  fill: \"none\",\n  d: \"M3,19.77a1,1,0,0,1,.29-.7l2.43-2.43a1,1,0,0,1,1.41,0,1,1,0,0,1,0,1.42L4.65,20.48a1,1,0,0,1-1.41,0A1,1,0,0,1,3,19.77Z\"\n}), _react.default.createElement(\"path\", {\n  d: \"M3,19.77a1,1,0,0,1,.29-.7l2.43-2.43a1,1,0,0,1,1.41,0,1,1,0,0,1,0,1.42L4.65,20.48a1,1,0,0,1-1.41,0A1,1,0,0,1,3,19.77Z\"\n}), _react.default.createElement(\"g\", null, _react.default.createElement(\"path\", {\n  d: \"M3.15,4.67A1,1,0,0,1,4.86,4L7.28,6.38a1,1,0,0,1,0,1.42,1,1,0,0,1-1.41,0L3.44,5.37A1,1,0,0,1,3.15,4.67Z\"\n}), _react.default.createElement(\"path\", {\n  d: \"M15.67,17.18a1,1,0,0,1,.29-.7,1,1,0,0,1,1.41,0L19.8,18.9a1,1,0,0,1-1.42,1.42L16,17.89A1,1,0,0,1,15.67,17.18Z\"\n}), _react.default.createElement(\"path\", {\n  d: \"M15.67,7.09A1,1,0,0,1,16,6.38L18.38,4A1,1,0,0,1,19.8,4a1,1,0,0,1,0,1.41L17.37,7.8A1,1,0,0,1,16,7.8,1,1,0,0,1,15.67,7.09Z\"\n}), _react.default.createElement(\"path\", {\n  d: \"M.73,12a1,1,0,0,1,1-1H6.58a5.26,5.26,0,0,1,4.13-4.13V1.44a1,1,0,1,1,2,0V7.78a1,1,0,0,1-1,1A3.23,3.23,0,0,0,8.48,12a1,1,0,0,1-1,1H1.73A1,1,0,0,1,.73,12Z\"\n}), _react.default.createElement(\"path\", {\n  d: \"M10.71,22.56V16.22a1,1,0,0,1,1-1A3.22,3.22,0,0,0,14.93,12a1,1,0,0,1,1-1h6.34a1,1,0,0,1,0,2H16.83a5.23,5.23,0,0,1-4.12,4.13v5.43a1,1,0,0,1-2,0Z\"\n}))), 'Brigth');\n\nexports.default = _default;","//CORE\nimport React from 'react'\n\n//@MATERIAL\nimport Icon from \"@material-ui/core/Icon\"\n\n//COMPONENTS\nimport HtmlTooltip from \"components/Tooltip/html\"\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\"\n\nexport default function Component(props) {\n    return (\n        <HtmlTooltip\n            title={props.title ? translate(props.title, 1) : ''}\n        >\n            {(typeof props.icon === 'string') || (typeof props.children === 'string') ?\n                <Icon\n                    className={props.className ? props.className : ''}\n                    style={{\n                        position: `${props.static ? 'static' : ''}`,\n                        display: 'flex',\n                        justifyContent: 'center',\n                        alignItems: 'center',\n                        height: props.size || '22px',\n                        width: props.size || '22px',\n                        fontSize: props.size || '22px',\n                        color: props.color || customApp('medium'),\n                        opacity: !props.disabled ? '1' : '0.5',\n                        cursor: props.onClick ? 'pointer' : '',\n                        ...props.style\n                    }}\n                    onClick={props.onClick ? (e) => {\n                        props.onClick()\n                        e.preventDefault();\n                        e.stopPropagation();\n                    } : null\n                    }\n                >\n                    {props.icon || props.children}\n                </Icon>\n                :\n                <props.icon\n                    className={props.className ? props.className : ''}\n                    style={{\n                        width: props.size || '22px',\n                        height: props.size || '22px',\n                        fontSize: props.size || '22px',\n                        color: props.color || customApp('medium'),\n                        opacity: !props.disabled ? '1' : '0.5',\n                        cursor: props.onClick ? 'pointer' : '',\n                        margin: 'auto',\n                        ...props.style\n                    }}\n                    onClick={props.onClick ? (e) => {\n                        props.onClick()\n                        e.preventDefault();\n                        e.stopPropagation();\n                    } : null\n                    }\n                />\n            }\n        </HtmlTooltip>\n    )\n}","// \"use strict\";\n\nconst _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nconst _react = _interopRequireDefault(require(\"react\"));\n\nconst _createSvgIcon = _interopRequireDefault(require(\"@material-ui/icons/utils/createSvgIcon\"));\n\nconst _default = (0, _createSvgIcon.default)(_react.default.createElement(_react.default.Fragment, null, _react.default.createElement(\"path\", {\n  fill: \"none\",\n  d: `M5.9,12.6C5.9,12.6,5.8,12.6,5.9,12.6l-0.1-0.1c0,0,0,0,0,0l0,0c0,0-0.1,0-0.1,0H3.1c0,0-0.1,0-0.1,0l-0.1,0\n\t\t\tc0,0,0,0,0,0l0,0c0,0,0,0,0,0l0,0c0,0,0,0,0,0l0,0c0,0,0,0,0,0.1c0,0,0,0,0,0l0,0c0,0,0,0,0,0l0,0c0,0,0,0.1,0,0.1\n\t\t\tc0,0,0,0.1,0,0.1l0,0.1c0,0,0,0,0,0l0,0c0,0,0,0,0.1,0.1l8.8,8.8v-1.2l-7.4-7.4h1.3l6.1,6.1v-1.2L5.9,12.6L5.9,12.6z M2.9,12.7\n\t\t\tL2.9,12.7L2.9,12.7L2.9,12.7z M2.8,13L2.8,13L2.8,13L2.8,13z M2.9,13.1L2.9,13.1L2.9,13.1L2.9,13.1z`\n}), _react.default.createElement(\"path\", {\n  d: `M5.9,12.6C5.9,12.6,5.8,12.6,5.9,12.6l-0.1-0.1c0,0,0,0,0,0l0,0c0,0-0.1,0-0.1,0H3.1c0,0-0.1,0-0.1,0l-0.1,0\n\t\t\tc0,0,0,0,0,0l0,0c0,0,0,0,0,0l0,0c0,0,0,0,0,0l0,0c0,0,0,0,0,0.1c0,0,0,0,0,0l0,0c0,0,0,0,0,0l0,0c0,0,0,0.1,0,0.1\n\t\t\tc0,0,0,0.1,0,0.1l0,0.1c0,0,0,0,0,0l0,0c0,0,0,0,0.1,0.1l8.8,8.8v-1.2l-7.4-7.4h1.3l6.1,6.1v-1.2L5.9,12.6L5.9,12.6z M2.9,12.7\n\t\t\tL2.9,12.7L2.9,12.7L2.9,12.7z M2.8,13L2.8,13L2.8,13L2.8,13z M2.9,13.1L2.9,13.1L2.9,13.1L2.9,13.1z`\n}), _react.default.createElement(\"path\", {\n  d: `M18.9,13C18.9,13,18.9,13,18.9,13c0-0.1,0-0.1,0-0.2l-0.1-0.2c0,0,0,0,0,0v0l-0.1,0c0,0,0,0-0.1-0.1l0,0\n\t\t\tc0,0,0,0,0,0l0,0c0,0-0.1,0-0.1,0H16c0,0-0.1,0-0.1,0l0,0c0,0,0,0,0,0l-0.1,0c0,0,0,0,0,0l-3.2,3.2l0,0v1.2l3.7-3.7h1.2l-4.8,4.8\n\t\t\tl0,0v1.2l6.2-6.2l0,0v0c0,0,0,0,0,0l0,0l-0.1-0.1L18.9,13L18.9,13z M18.7,12.8L18.7,12.8L18.7,12.8L18.7,12.8z`\n}), _react.default.createElement(\"path\", {\n  d: `M18.1,11.3L18.1,11.3c0.1,0,0.1,0.1,0.1,0.1l0,0c0,0,0,0,0,0l0,0c0,0,0.1,0,0.1,0h2.5c0,0,0.1,0,0.1,0\n\t\t\tl0.2-0.1c0,0,0,0,0.1,0l0,0c0,0,0,0,0-0.1l0.1-0.2c0,0,0-0.1,0-0.1c0,0,0-0.1,0-0.1l0-0.1c0,0,0,0,0-0.1c0,0,0,0,0-0.1L12.5,2v1.2\n\t\t\tl7.4,7.4h-1.3l-6.1-6.1v1.2L18.1,11.3L18.1,11.3z M18.3,11.3L18.3,11.3L18.3,11.3L18.3,11.3z`\n}), _react.default.createElement(\"path\", {\n  d: `M12.9,11.5H16c0,0,0.1,0,0.1,0l0.1-0.1c0,0,0,0,0,0l0.1,0v0c0,0,0,0,0,0c0,0,0,0,0,0l0,0c0,0,0,0,0,0l0,0\n\t\t\tc0,0,0-0.1,0-0.1c0,0,0-0.1,0-0.1l0-0.1c0,0,0,0,0,0l0,0c0,0,0,0,0,0l-3.8-3.9l0,4.1C12.5,11.3,12.7,11.5,12.9,11.5z`\n}), _react.default.createElement(\"path\", {\n  d: `M5.2,10.8C5.2,10.8,5.2,10.8,5.2,10.8C5.2,10.8,5.2,10.9,5.2,10.8l-0.1,0.2L5.3,11l-0.2,0c0,0,0,0.1,0,0.1\n\t\t\tc0,0,0,0.1,0,0.1l0,0.1c0,0,0,0,0,0l0,0c0,0,0,0,0.1,0.1l0,0c0,0,0,0,0,0l0.1-0.1h0l0,0.1l0.1-0.1l0,0.1c0,0,0,0,0.1,0\n\t\t\tc0,0,0.1,0,0.1,0H8c0,0,0.1,0,0.1,0l0,0c0,0,0,0,0,0l0.1,0c0,0,0,0,0,0l3.2-3.2V6.9l-3.7,3.7H6.6l4.9-4.9V4.5L5.2,10.8L5.2,10.8z\n\t\t\t M5.3,11.1L5.3,11.1L5.3,11.1L5.3,11.1z`\n}), _react.default.createElement(\"path\", {\n  d: `M11.1,12.5H8c0,0-0.1,0-0.1,0l-0.1,0c0,0,0,0,0,0l0,0c0,0,0,0-0.1,0.1c0,0,0,0-0.1,0.1l0,0.1l0.1,0.1l-0.2,0\n\t\t\tl0,0c0,0,0,0.1,0,0.1c0,0,0,0.1,0,0.1l0.1,0.1c0,0,0,0,0.1,0.1l3.8,3.8v-4.1C11.5,12.7,11.3,12.5,11.1,12.5z M7.8,12.8\n\t\t\tC7.8,12.8,7.8,12.8,7.8,12.8L7.8,12.8L7.8,12.8z M7.7,12.9L7.7,12.9L7.7,12.9L7.7,12.9z`\n}), _react.default.createElement(\"path\", {\n  d: `M21.3,12.6L21.3,12.6c-0.2-0.2-0.4-0.2-0.6,0l-8.1,8.1l0,0V22l8.8-8.8c0.1-0.1,0.1-0.2,0.1-0.3\n\t\t\tC21.4,12.8,21.3,12.7,21.3,12.6z`\n}), _react.default.createElement(\"path\", {\n  d: `M2.7,11.4L2.7,11.4c0.1,0.1,0.2,0.1,0.3,0.1c0.1,0,0.2,0,0.3-0.1l8.2-8.2V2l-8.8,8.8\n\t\t\tC2.6,10.9,2.6,11.2,2.7,11.4z`\n})), 'Matrix');\n\nexports.default = _default;\n","import { withStyles } from '@material-ui/core/styles';\nimport Tooltip from \"@material-ui/core/Tooltip\"\n\nconst HtmlTooltip = withStyles((theme) => ({\n    tooltip: {\n        backgroundColor: '#f5f5f9',\n        color: 'rgba(0, 0, 0, 0.87)',\n        maxWidth: 220,\n        fontSize: theme.typography.pxToRem(12),\n        border: '1px solid #dadde9',\n        borderRadius: '7px',\n        boxShadow: '0 0 3px 3px rgba(0,0,0,0.03)',\n        display: 'flex',\n        alignItems: 'center',\n        justifyContent: 'center',\n    },\n}))(Tooltip);\n\nexport default HtmlTooltip","export function reduxFunction(type, action, value, next = null, preLoader = false, redirect = null) {\r\n    return {\r\n        type: type,\r\n        action: action,\r\n        value: value,\r\n        next: next,\r\n        preLoader: preLoader,\r\n        redirect: redirect\r\n    }\r\n}","import $ from \"jquery\"\r\nimport api from \"api\"\r\n\r\nexport const upload = async (id, fileData, fullData = false, functions) => {\r\n    let file = fileData\r\n    file.originalName = file.name\r\n    var formData = new FormData();\r\n    formData.append(\"file\", file, file.name);\r\n    formData.append(\"id\", id);\r\n\r\n    let returnFile\r\n    let send = await new Promise(async (resolve, reject) => {\r\n        try {\r\n            if (functions && functions.onUploadProgress) {\r\n                const { onUploadProgress } = functions\r\n                // apims\r\n                let request = await api.post(\"upload/file/\", formData, {\r\n                    onUploadProgress\r\n                })\r\n                if (request)\r\n                    returnFile = request.data\r\n            } else {\r\n                let request = await api.post(\"upload/file/\", formData)\r\n                if (request)\r\n                    returnFile = request.data\r\n            }\r\n        } catch (e) {\r\n            if (functions && functions.onUploadError)\r\n                functions.onUploadError(e)\r\n            reject(false)\r\n        } finally {\r\n            resolve(true)\r\n        }\r\n\r\n    })\r\n\r\n    if (send) {\r\n        if (!fullData) {\r\n            return `https://machen.azureedge.net/${returnFile.file}`\r\n        } else {\r\n            return returnFile\r\n        }\r\n    } else {\r\n        return false\r\n    }\r\n}\r\n\r\nexport const uploadThumb = async (name, ext, fileData, instalThumb = false) => {\r\n    let file = fileData\r\n    file.originalName = file.name\r\n    var formData = new FormData();\r\n    formData.append(\"file\", file, file.name);\r\n    formData.append(\"id\", name);\r\n    formData.append(\"ext\", ext)\r\n    formData.append(\"thumb\", instalThumb)\r\n\r\n    const api = String(process.env.REACT_APP_PROD) === 'true' ? process.env.REACT_APP_WS : process.env.REACT_APP_devWS;\r\n\r\n    const request = await $.ajax({\r\n        method: \"POST\",\r\n        url: `${api}/upload/thumb/`,\r\n        headers: {\r\n            Authorization: `Bearer ${localStorage.getItem('TOKEN')}`\r\n        },\r\n        cache: false,\r\n        data: formData,\r\n        contentType: false,\r\n        processData: false,\r\n    })\r\n    return true\r\n}","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport CircularProgress from '@material-ui/core/CircularProgress';\n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\n// Inspired by the former Facebook spinners.\nconst useStylesFacebook = makeStyles((theme) => ({\n    root: {\n        position: 'relative',\n    },\n    bottom: {\n        color: theme.palette.grey[theme.palette.type === 'light' ? 200 : 700],\n        position: 'absolute',\n        left: 0,\n    },\n    top: {\n        color: customApp('ColumnTitleColor'),\n        animationDuration: '550ms',\n        position: 'absolute',\n        left: 0,\n    },\n    circle: {\n        strokeLinecap: 'round',\n    },\n}));\n\nfunction FacebookCircularProgress(props) {\n    const classes = useStylesFacebook();\n\n    return (\n        <div className={classes.root}\n            style={{\n                width: props.size ? props.size : '25px',\n                height: props.size ? props.size : '25px',\n            }}>\n            <CircularProgress\n                variant=\"determinate\"\n                className={classes.bottom}\n                size={props.size ? props.size : 25}\n                thickness={4}\n                {...props}\n                value={100}\n            />\n            <CircularProgress\n                variant=\"indeterminate\"\n                disableShrink\n                className={classes.top}\n                classes={{\n                    circle: classes.circle,\n                }}\n                size={props.size ? props.size : 25}\n                thickness={4}\n                {...props}\n            />\n        </div>\n    );\n}\n\nexport default FacebookCircularProgress","import React from \"react\";\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport reduxStore from \"store/\"\n\n//@MATERIALS\nimport Backdrop from \"@material-ui/core/Backdrop\"\n\n//COMPONENTS\nimport CustomButton from \"components/Buttons/custom\"\n\n//FUNTIONS\nimport { customApp, translate } from \"functions/\";\n\n\nexport default function PolicyAndTerms(props) {\n  const [consent, setConsent] = React.useState(reduxStore.getState().session.consent ? true : false)\n  const [privacy, setPrivacy] = React.useState(false)\n  const [terms, setTerms] = React.useState(false)\n  const [loading, setLoading] = React.useState(true)\n\n  React.useEffect(() => {\n    setTimeout(() => {\n      setLoading(false)\n    }, 6000)\n  }, [privacy])\n\n  const updateConsent = async () => {\n    setLoading(true)\n    setTerms(true)\n    let consent = {\n      accepted_at: `${moment().unix(\"X\")}`,\n      privacy: \"Data de criação: 31 de dezembro de 2021, Última atualização: 06 de janeiro de 2022\",\n      terms: \"Data de criação: 31 de dezembro de 2021, Última atualização: 06 de janeiro de 2022\",\n    }\n    const { socket } = reduxStore.getState().functions\n    socket.emit(\"data\", {\n      module: \"user\",\n      method: \"post\",\n      action: \"consent\"\n    }, {\n      version: JSON.stringify(consent)\n    })\n  }\n\n  if (terms)\n    return (<React.Fragment></React.Fragment>)\n\n  return (\n    <div id={`policyAndTermsConsent`}\n\n    >\n      <Backdrop\n        // className={classes.backdrop}\n        style={{\n          zIndex: 30000,\n          backdropFilter: \"blur(7px) sepia(90%)\",\n          display: \"flex\",\n          alignItems: \"center\",\n          justifyContent: \"center\"\n        }}\n        open={!consent} onClick={(e) => {\n          // close()\n        }}>\n        <div\n          style={{\n            position: \"fixed\",\n            ...window.innerWidth > 600 ? {\n              top: 77,\n              left: 77,\n              right: 77,\n              bottom: 77,\n            } : {\n              top: 50,\n              left: 7,\n              right: 7,\n              bottom: 7,\n            },\n            ...window.innerWidth > 600 ? {\n              zIndex: 3,\n            } : {\n              zIndex: 6000,\n            },\n            boxShadow: \"0px 0px 10px 3px rgba(0,0,0,0.2)\",\n            borderRadius: \"15px\",\n            overflow: 'hidden',\n            backgroundColor: \"#FFFFFF\"\n          }}\n        >\n          <div style={{\n            position: \"absolute\",\n            top: 0,\n            left: 0,\n            right: 0,\n            height: 40,\n            background: customApp('ColumnTitleColor'),\n            display: \"flex\",\n            alignItems: \"center\",\n            // textAlign: \"center\",\n            justifyContent: \"center\",\n            color: customApp(\"color\"),\n            fontWeight: \"bold\"\n          }}>\n            {translate(`$__TermsOfUseAndPrivacyPolicy`)}\n          </div>\n          <div style={{\n            position: \"absolute\",\n            top: 40,\n            left: 0,\n            right: 0,\n            bottom: 0,\n            display: \"flex\",\n            alignItems: \"center\",\n            justifyContent: \"center\"\n          }}>\n            {!privacy ?\n              <iframe\n                id=\"policy\"\n                style={{\n                  position: \"absolute\",\n                  top: 0,\n                  left: 0,\n                  right: 0,\n                  bottom: 40,\n                  width: \"100%\",\n                  height: \"calc(100% - 40px)\",\n                }}\n                width={\"100%\"}\n                height={\"100%\"}\n                onScroll={() => {\n                  console.log(\"scroll\")\n                }}\n                src=\"https://sonne.global/SONNE-Politica-de-Privacidade-2022-01-07.pdf\"\n              />\n              :\n              <iframe\n                id=\"terms\"\n                style={{\n                  position: \"absolute\",\n                  top: 0,\n                  left: 0,\n                  right: 0,\n                  bottom: 40,\n                  width: \"100%\",\n                  height: \"calc(100% - 40px)\",\n                }}\n                width={\"100%\"}\n                height={\"100%\"}\n                src=\"https://sonne.global/SONNE-Termos-de-Servicos-2022-01-07.pdf\"\n              />\n            }\n          </div>\n          <div\n            style={{\n              position: \"absolute\",\n              bottom: 0,\n              left: 0,\n              right: 0,\n              height: 40,\n              display: \"flex\",\n              justifyContent: \"center\"\n            }}\n          >\n            <div\n              style={{\n                display: \"flex\",\n                alignItems: \"center\",\n                justifyContent: \"space-between\",\n                marginLeft: 33\n              }}\n            >\n              <CustomButton\n                id={`policyButtonConsent`}\n                title={translate(!privacy ? `$__IReadAndIAgree` : `$__accepted`, \"*\")}\n                text={!privacy ? translate(`$__IReadAndIAgree`, \"*\") : null}\n                color={!privacy ? customApp(\"menu\") : \"green\"}\n                icon={\"verified\"}\n                onClick={!privacy ? () => {\n                  setPrivacy(true)\n                } : null}\n                size={\"25px\"}\n              // transparent\n              />\n              {privacy ?\n                translate(`$__PrivacyPolicy`, \"*\")\n                : <React.Fragment></React.Fragment>\n              }\n            </div>\n            {privacy && !loading ?\n              <div\n                style={{\n                  display: \"flex\",\n                  alignItems: \"center\",\n                  justifyContent: \"space-between\",\n                }}\n              >\n                <CustomButton\n                  id={`termsofuseButtonConsent`}\n                  title={translate(`$__IReadAndIAgreeTheTermsOfUse`, \"*\")}\n                  text={translate(`$__IReadAndIAgreeTheTermsOfUse`, \"*\")}\n                  color={customApp(\"menu\")}\n                  icon={\"verified\"}\n                  onClick={() => {\n                    updateConsent()\n                  }}\n                  size={\"25px\"}\n                />\n              </div>\n              : <React.Fragment></React.Fragment>\n            }\n          </div>\n        </div>\n\n      </Backdrop>\n\n    </div>\n  );\n}\n","import React from \"react\";\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//@MATERIALS\nimport Backdrop from \"@material-ui/core/Backdrop\"\n\n//COMPONENTS\nimport CustomButton from \"components/Buttons/custom\"\n\n//FUNTIONS\nimport { customApp, translate } from \"functions/\";\n\nfunction LicensingAgreement(props) {\n  const { session } = reduxStore.getState()\n  // const [terms, setTerms] = React.useState(false)\n  const [loading, setLoading] = React.useState(true)\n  const AgreeRef = React.useRef()\n\n  React.useEffect(() => {\n    return () => {\n\n    }\n  }, [])\n\n  if (session && (!session.require || (session.require && !session.require.licensingAgreement)))\n    return (<React.Fragment></React.Fragment>)\n\n\n  const agree = async () => {\n    setLoading(true)\n    let consent = {\n      accepted_at: `${moment().unix(\"X\")}`,\n      version: \"2022-10-24\",\n    }\n    const { socket } = reduxStore.getState().functions\n    socket.emit(\"data\", {\n      module: \"account\",\n      method: \"post\",\n      action: \"agreement\"\n    }, {\n      version: JSON.stringify(consent)\n    })\n  }\n\n  const setScrollFunction = () => {\n    console.log(AgreeRef.current, AgreeRef.current.contentWindow.window)\n    // if (AgreeRef && AgreeRef.current && AgreeRef.current.contentWindow)\n    //   AgreeRef.current.contentWindow.addEventListener(\"onScroll\", () => {\n    //     console.log(\"ssssssssssssssss\")\n    //   })\n  }\n\n  return (\n    <div id={`licensingAgreement`}\n\n    >\n      <Backdrop\n        style={{\n          zIndex: 30000,\n          backdropFilter: \"blur(7px) sepia(90%)\",\n          display: \"flex\",\n          alignItems: \"center\",\n          justifyContent: \"center\"\n        }}\n        open={true}\n      >\n        <div\n          style={{\n            position: \"fixed\",\n            ...window.innerWidth > 600 ? {\n              top: 77,\n              left: 77,\n              right: 77,\n              bottom: 77,\n            } : {\n              top: 50,\n              left: 7,\n              right: 7,\n              bottom: 7,\n            },\n            ...window.innerWidth > 600 ? {\n              zIndex: 3,\n            } : {\n              zIndex: 6000,\n            },\n            boxShadow: \"0px 0px 10px 3px rgba(0,0,0,0.2)\",\n            borderRadius: \"15px\",\n            overflow: 'hidden',\n            backgroundColor: \"#FFFFFF\"\n          }}\n        >\n          <div style={{\n            position: \"absolute\",\n            top: 0,\n            left: 0,\n            right: 0,\n            height: 40,\n            background: customApp('ColumnTitleColor'),\n            display: \"flex\",\n            alignItems: \"center\",\n            justifyContent: \"center\",\n            color: customApp(\"color\"),\n            fontWeight: \"bold\"\n          }}>\n            {translate(`$__licensingAgreement`)}\n          </div>\n          <div style={{\n            position: \"absolute\",\n            top: 40,\n            left: 0,\n            right: 0,\n            bottom: 0,\n            display: \"flex\",\n            alignItems: \"center\",\n            justifyContent: \"center\"\n          }}>\n            <iframe\n              id=\"licensing\"\n              ref={AgreeRef}\n              onLoad={() => {\n                setScrollFunction()\n                console.log(\"licensing\")\n              }}\n              style={{\n                position: \"absolute\",\n                top: 0,\n                left: 0,\n                right: 0,\n                bottom: 40,\n                width: \"100%\",\n                height: \"calc(100% - 40px)\",\n              }}\n              width={\"100%\"}\n              height={\"100%\"}\n              src=\"https://machen.ai/contracts/MACHEN-Termos-e-Condicoes-Gerais-de-Uso-de-Software-2022-10-24.pdf\"\n            />\n          </div>\n          <div\n            style={{\n              position: \"absolute\",\n              bottom: 0,\n              left: 0,\n              right: 0,\n              height: 40,\n              display: \"flex\",\n              justifyContent: \"center\"\n            }}\n          >\n            <div\n              style={{\n                display: \"flex\",\n                alignItems: \"center\",\n                justifyContent: \"space-between\",\n                marginLeft: 33\n              }}\n            >\n              <CustomButton\n                id={`agreementButtonConsent`}\n                title={translate(`$__IReadAndIAgree`, \"*\")}\n                text={translate(`$__IReadAndIAgree`, \"*\")}\n                color={customApp(\"menu\")}\n                icon={\"verified\"}\n                onClick={() => {\n                  agree()\n                }}\n                size={\"25px\"}\n              // transparent\n              />\n            </div>\n          </div>\n        </div>\n\n      </Backdrop>\n\n    </div>\n  );\n}\n\n//REACT\nconst mapStateToProps = (store) => ({\n  session: store.session\n})\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\nexport default connect(\n  mapStateToProps,\n  mapDispatchToProps\n)(LicensingAgreement)\n","import React from \"react\";\r\n\r\nimport { translate } from \"functions/\"\r\n\r\nclass ErrorBoundary extends React.Component {\r\n    constructor(props) {\r\n        super(props);\r\n        this.state = {\r\n            hasError: false,\r\n            error: null,\r\n            errorInfo: null\r\n        };\r\n    }\r\n\r\n    static getDerivedStateFromError(error) {\r\n        // Update state so the next render will show the fallback UI.\r\n        return { hasError: true };\r\n    }\r\n\r\n    componentDidCatch(error, errorInfo) {\r\n        // You can also log the error to an error reporting service\r\n        // logErrorToMyService(error, errorInfo);\r\n        this.setState({\r\n            error: error,\r\n            errorInfo: errorInfo\r\n        })\r\n        console.log(window.location.hostname.indexOf('sonne.machen'), window.location.hostname.indexOf('software.machen'))\r\n        if (window.location.hostname.indexOf('sonne.machen') === -1\r\n            && window.location.hostname.indexOf('software.machen') === -1\r\n        )\r\n            console.log(error, errorInfo)\r\n    }\r\n\r\n    render() {\r\n        if (this.state.hasError) {\r\n            return (\r\n                <div>\r\n                    {translate(\"$__ComponentErrorRefreshOrSupportMessage\")}\r\n                </div>\r\n            )\r\n        }\r\n\r\n        return this.props.children;\r\n    }\r\n}\r\n\r\nexport default ErrorBoundary;","import {\r\n  grayColor,\r\n  roseColor,\r\n  primaryColor,\r\n  infoColor,\r\n  successColor,\r\n  warningColor,\r\n  dangerColor,\r\n  whiteColor,\r\n  blackColor,\r\n  twitterColor,\r\n  facebookColor,\r\n  googleColor,\r\n  linkedinColor,\r\n  pinterestColor,\r\n  youtubeColor,\r\n  tumblrColor,\r\n  behanceColor,\r\n  dribbbleColor,\r\n  redditColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport { customApp } from \"functions/\";\r\n\r\nconst buttonStyle = {\r\n  button: {\r\n    minHeight: \"auto\",\r\n    minWidth: \"auto\",\r\n    backgroundColor: grayColor[0],\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(grayColor[0]) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(grayColor[0]) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(grayColor[0]) +\r\n      \", 0.12)\",\r\n    border: \"none\",\r\n    borderRadius: \"3px\",\r\n    position: \"relative\",\r\n    padding: \"12px 30px\",\r\n    margin: \".3125rem 1px\",\r\n    fontSize: \"12px\",\r\n    fontWeight: \"400\",\r\n    textTransform: \"uppercase\",\r\n    letterSpacing: \"0\",\r\n    willChange: \"box-shadow, transform\",\r\n    transition:\r\n      \"box-shadow 0.2s cubic-bezier(0.4, 0, 1, 1), background-color 0.2s cubic-bezier(0.4, 0, 0.2, 1)\",\r\n    lineHeight: \"1.42857143\",\r\n    textAlign: \"center\",\r\n    whiteSpace: \"nowrap\",\r\n    verticalAlign: \"middle\",\r\n    touchAction: \"manipulation\",\r\n    cursor: \"pointer\",\r\n    \"&:hover,&:focus\": {\r\n      color: whiteColor,\r\n      backgroundColor: grayColor[0],\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(grayColor[0]) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(grayColor[0]) +\r\n        \", 0.2)\"\r\n    },\r\n    \"& .fab,& .fas,& .far,& .fal,& .material-icons\": {\r\n      position: \"relative\",\r\n      display: \"inline-block\",\r\n      top: \"0\",\r\n      marginTop: \"-1em\",\r\n      marginBottom: \"-1em\",\r\n      fontSize: \"1.1rem\",\r\n      marginRight: \"4px\",\r\n      verticalAlign: \"middle\"\r\n    },\r\n    \"& svg\": {\r\n      position: \"relative\",\r\n      display: \"inline-block\",\r\n      top: \"0\",\r\n      width: \"18px\",\r\n      height: \"18px\",\r\n      marginRight: \"4px\",\r\n      verticalAlign: \"middle\"\r\n    },\r\n    \"&$justIcon\": {\r\n      \"& .fab,& .fas,& .far,& .fal,& .material-icons\": {\r\n        marginTop: \"0px\",\r\n        position: \"absolute\",\r\n        width: \"100%\",\r\n        transform: \"none\",\r\n        left: \"0px\",\r\n        top: \"0px\",\r\n        height: \"100%\",\r\n        lineHeight: \"41px\",\r\n        fontSize: \"20px\"\r\n      }\r\n    }\r\n  },\r\n  fullWidth: {\r\n    width: \"100%\"\r\n  },\r\n  custom_color: {\r\n    backgroundColor: customApp('color'),\r\n    boxShadow:\r\n      \"0 2px 2px 0 \" +\r\n      customApp('color', 0.14) +\r\n      \", 0 3px 1px -2px \" +\r\n      customApp('color', 0.2) +\r\n      \", 0 1px 5px 0 rgba(\" +\r\n      customApp('color', 0.12),\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: customApp('color'),\r\n      boxShadow:\r\n        \"0 14px 26px -12px \" +\r\n        customApp('color', 0.42) +\r\n        \", 0 4px 23px 0px \" +\r\n        customApp('color', 0.12) +\r\n        \", 0 8px 10px -5px rgba(\" +\r\n        customApp('color', 0.2)\r\n    }\r\n  },\r\n  custom_menuColor: {\r\n    backgroundColor: customApp('menu'),\r\n    boxShadow:\r\n      \"0 2px 2px 0 \" +\r\n      customApp('menu', 0.14) +\r\n      \", 0 3px 1px -2px \" +\r\n      customApp('menu', 0.2) +\r\n      \", 0 1px 5px 0 rgba(\" +\r\n      customApp('menu', 0.12),\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: customApp('menu'),\r\n      boxShadow:\r\n        \"0 14px 26px -12px \" +\r\n        customApp('menu', 0.42) +\r\n        \", 0 4px 23px 0px \" +\r\n        customApp('menu', 0.12) +\r\n        \", 0 8px 10px -5px rgba(\" +\r\n        customApp('menu', 0.2)\r\n    }\r\n  },\r\n  custom_mediumColor: {\r\n    backgroundColor: customApp('medium'),\r\n    boxShadow:\r\n      \"0 2px 2px 0 \" +\r\n      customApp('medium', 0.14) +\r\n      \", 0 3px 1px -2px \" +\r\n      customApp('medium', 0.2) +\r\n      \", 0 1px 5px 0 rgba(\" +\r\n      customApp('medium', 0.12),\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: customApp('medium'),\r\n      boxShadow:\r\n        \"0 14px 26px -12px \" +\r\n        customApp('medium', 0.42) +\r\n        \", 0 4px 23px 0px \" +\r\n        customApp('medium', 0.12) +\r\n        \", 0 8px 10px -5px rgba(\" +\r\n        customApp('medium', 0.2)\r\n    }\r\n  },\r\n  primary: {\r\n    backgroundColor: primaryColor[0],\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(primaryColor[0]) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(primaryColor[0]) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(primaryColor[0]) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: primaryColor[0],\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(primaryColor[0]) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(primaryColor[0]) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  info: {\r\n    backgroundColor: infoColor[0],\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(infoColor[0]) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(infoColor[0]) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(infoColor[0]) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: infoColor[0],\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(infoColor[0]) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(infoColor[0]) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  success: {\r\n    backgroundColor: successColor[0],\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(successColor[0]) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(successColor[0]) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(successColor[0]) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: successColor[0],\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(successColor[0]) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(successColor[0]) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  warning: {\r\n    backgroundColor: warningColor[0],\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(warningColor[0]) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(warningColor[0]) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(warningColor[0]) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: warningColor[0],\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(warningColor[0]) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(warningColor[0]) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  danger: {\r\n    backgroundColor: dangerColor[0],\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(dangerColor[0]) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(dangerColor[0]) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(dangerColor[0]) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: dangerColor[0],\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(dangerColor[0]) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(dangerColor[0]) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  rose: {\r\n    backgroundColor: roseColor[0],\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(roseColor[0]) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(roseColor[0]) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(roseColor[0]) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: roseColor[0],\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(roseColor[0]) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(roseColor[0]) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  white: {\r\n    \"&,&:focus,&:hover\": {\r\n      backgroundColor: whiteColor,\r\n      color: grayColor[0]\r\n    }\r\n  },\r\n  twitter: {\r\n    backgroundColor: twitterColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(twitterColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(twitterColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(twitterColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus,&:visited\": {\r\n      backgroundColor: twitterColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(twitterColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(twitterColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  facebook: {\r\n    backgroundColor: facebookColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(facebookColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(facebookColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(facebookColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: facebookColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(facebookColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(facebookColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  google: {\r\n    backgroundColor: googleColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(googleColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(googleColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(googleColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: googleColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(googleColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(googleColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  linkedin: {\r\n    backgroundColor: linkedinColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(linkedinColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(linkedinColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(linkedinColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: linkedinColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(linkedinColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(linkedinColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  pinterest: {\r\n    backgroundColor: pinterestColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(pinterestColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(pinterestColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(pinterestColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: pinterestColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(pinterestColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(pinterestColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  youtube: {\r\n    backgroundColor: youtubeColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(youtubeColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(youtubeColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(youtubeColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: youtubeColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(youtubeColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(youtubeColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  tumblr: {\r\n    backgroundColor: tumblrColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(tumblrColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(tumblrColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(tumblrColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: tumblrColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(tumblrColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(tumblrColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  github: {\r\n    backgroundColor: grayColor[7],\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(grayColor[6]) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(grayColor[6]) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(grayColor[6]) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: grayColor[7],\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(grayColor[6]) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(grayColor[6]) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  behance: {\r\n    backgroundColor: behanceColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(behanceColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(behanceColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(behanceColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: behanceColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(behanceColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(behanceColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  dribbble: {\r\n    backgroundColor: dribbbleColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(dribbbleColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(dribbbleColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(dribbbleColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: dribbbleColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(dribbbleColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(dribbbleColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  reddit: {\r\n    backgroundColor: redditColor,\r\n    color: whiteColor,\r\n    boxShadow:\r\n      \"0 2px 2px 0 rgba(\" +\r\n      hexToRgb(redditColor) +\r\n      \", 0.14), 0 3px 1px -2px rgba(\" +\r\n      hexToRgb(redditColor) +\r\n      \", 0.2), 0 1px 5px 0 rgba(\" +\r\n      hexToRgb(redditColor) +\r\n      \", 0.12)\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: redditColor,\r\n      color: whiteColor,\r\n      boxShadow:\r\n        \"0 14px 26px -12px rgba(\" +\r\n        hexToRgb(redditColor) +\r\n        \", 0.42), 0 4px 23px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.12), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(redditColor) +\r\n        \", 0.2)\"\r\n    }\r\n  },\r\n  simple: {\r\n    \"&,&:focus,&:hover\": {\r\n      color: whiteColor,\r\n      background: \"transparent\",\r\n      boxShadow: \"none\"\r\n    },\r\n    \"&$primary\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: primaryColor[0]\r\n      }\r\n    },\r\n    \"&$info\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: infoColor[0]\r\n      }\r\n    },\r\n    \"&$success\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: successColor[0]\r\n      }\r\n    },\r\n    \"&$warning\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: warningColor[0]\r\n      }\r\n    },\r\n    \"&$rose\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: roseColor[0]\r\n      }\r\n    },\r\n    \"&$danger\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: dangerColor[0]\r\n      }\r\n    },\r\n    \"&$twitter\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: twitterColor\r\n      }\r\n    },\r\n    \"&$facebook\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: facebookColor\r\n      }\r\n    },\r\n    \"&$google\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: googleColor\r\n      }\r\n    },\r\n    \"&$linkedin\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: linkedinColor\r\n      }\r\n    },\r\n    \"&$pinterest\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: pinterestColor\r\n      }\r\n    },\r\n    \"&$youtube\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: youtubeColor\r\n      }\r\n    },\r\n    \"&$tumblr\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: tumblrColor\r\n      }\r\n    },\r\n    \"&$github\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: grayColor[7]\r\n      }\r\n    },\r\n    \"&$behance\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: behanceColor\r\n      }\r\n    },\r\n    \"&$dribbble\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: dribbbleColor\r\n      }\r\n    },\r\n    \"&$reddit\": {\r\n      \"&,&:focus,&:hover,&:visited\": {\r\n        color: redditColor\r\n      }\r\n    }\r\n  },\r\n  transparent: {\r\n    \"&,&:focus,&:hover\": {\r\n      color: \"inherit\",\r\n      background: \"transparent\",\r\n      boxShadow: \"none\"\r\n    }\r\n  },\r\n  disabled: {\r\n    opacity: \"0.65\",\r\n    pointerEvents: \"none\"\r\n  },\r\n  lg: {\r\n    \"&$justIcon\": {\r\n      \"& .fab,& .fas,& .far,& .fal,& svg,& .material-icons\": {\r\n        marginTop: \"-4px\"\r\n      }\r\n    },\r\n    padding: \"1.125rem 2.25rem\",\r\n    fontSize: \"12px\",\r\n    lineHeight: \"1.333333\",\r\n    borderRadius: \"0.2rem\"\r\n  },\r\n  sm: {\r\n    \"&$justIcon\": {\r\n      \"& .fab,& .fas,& .far,& .fal,& svg,& .material-icons\": {\r\n        marginTop: \"1px\"\r\n      }\r\n    },\r\n    padding: \"0.40625rem 1.25rem\",\r\n    fontSize: \"0.6875rem\",\r\n    lineHeight: \"1.5\",\r\n    borderRadius: \"0.2rem\"\r\n  },\r\n  round: {\r\n    borderRadius: \"30px\"\r\n  },\r\n  block: {\r\n    width: \"100% !important\"\r\n  },\r\n  link: {\r\n    \"&,&:hover,&:focus\": {\r\n      backgroundColor: \"transparent\",\r\n      color: grayColor[0],\r\n      boxShadow: \"none\"\r\n    }\r\n  },\r\n  justIcon: {\r\n    paddingLeft: \"12px\",\r\n    paddingRight: \"12px\",\r\n    fontSize: \"20px\",\r\n    height: \"41px\",\r\n    minWidth: \"41px\",\r\n    width: \"41px\",\r\n    \"& .fab,& .fas,& .far,& .fal,& svg,& .material-icons\": {\r\n      marginRight: \"0px\"\r\n    },\r\n    \"&$lg\": {\r\n      height: \"57px\",\r\n      minWidth: \"57px\",\r\n      width: \"57px\",\r\n      lineHeight: \"56px\",\r\n      \"& .fab,& .fas,& .far,& .fal,& .material-icons\": {\r\n        fontSize: \"32px\",\r\n        lineHeight: \"56px\"\r\n      },\r\n      \"& svg\": {\r\n        width: \"32px\",\r\n        height: \"32px\"\r\n      }\r\n    },\r\n    \"&$sm\": {\r\n      height: \"30px\",\r\n      minWidth: \"30px\",\r\n      width: \"30px\",\r\n      \"& .fab,& .fas,& .far,& .fal,& .material-icons\": {\r\n        fontSize: \"12px\",\r\n        lineHeight: \"29px\"\r\n      },\r\n      \"& svg\": {\r\n        width: \"16px\",\r\n        height: \"16px\"\r\n      }\r\n    }\r\n  }\r\n};\r\n\r\nexport default buttonStyle;\r\n","import React from \"react\";\nimport classNames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\n//MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport Button from \"@material-ui/core/Button\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/buttonStyle.js\";\n\nconst useStyles = makeStyles(styles);\n\nconst RegularButton = React.forwardRef((props, ref) => {\n  const classes = useStyles();\n  const {\n    color,\n    round,\n    children,\n    fullWidth,\n    disabled,\n    simple,\n    size,\n    block,\n    link,\n    justIcon,\n    className,\n    muiClasses,\n    ...rest\n  } = props;\n  const btnClasses = classNames({\n    [classes.button]: true,\n    [classes[size]]: size,\n    [classes[color]]: color,\n    [classes.round]: round,\n    [classes.fullWidth]: fullWidth,\n    [classes.disabled]: disabled,\n    [classes.simple]: simple,\n    [classes.block]: block,\n    [classes.link]: link,\n    [classes.justIcon]: justIcon,\n    [className]: className\n  });\n  return (\n    <Button {...rest} ref={ref} classes={muiClasses} className={btnClasses}>\n      {children}\n    </Button>\n  );\n});\n\nRegularButton.propTypes = {\n  color: PropTypes.oneOf([\n    \"primary\",\n    \"info\",\n    \"custom_color\",\n    \"custom_menuColor\",\n    \"custom_mediumColor\",\n    \"success\",\n    \"warning\",\n    \"danger\",\n    \"rose\",\n    \"white\",\n    \"twitter\",\n    \"facebook\",\n    \"google\",\n    \"linkedin\",\n    \"pinterest\",\n    \"youtube\",\n    \"tumblr\",\n    \"github\",\n    \"behance\",\n    \"dribbble\",\n    \"reddit\",\n    \"transparent\"\n  ]),\n  size: PropTypes.oneOf([\"sm\", \"lg\"]),\n  simple: PropTypes.bool,\n  round: PropTypes.bool,\n  fullWidth: PropTypes.bool,\n  disabled: PropTypes.bool,\n  block: PropTypes.bool,\n  link: PropTypes.bool,\n  justIcon: PropTypes.bool,\n  className: PropTypes.string,\n  muiClasses: PropTypes.object,\n  children: PropTypes.node\n};\n\nexport default RegularButton;\n","import {\r\n  container,\r\n  defaultFont,\r\n  primaryColor,\r\n  defaultBoxShadow,\r\n  infoColor,\r\n  successColor,\r\n  warningColor,\r\n  dangerColor,\r\n  boxShadow,\r\n  drawerWidth,\r\n  transition,\r\n  whiteColor,\r\n  grayColor,\r\n  blackColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst pagesHeaderStyle = theme => ({\r\n  appBar: {\r\n    backgroundColor: \"transparent\",\r\n    boxShadow: \"none\",\r\n    borderBottom: \"0\",\r\n    marginBottom: \"0\",\r\n    position: \"absolute\",\r\n    width: \"100%\",\r\n    paddingTop: \"10px\",\r\n    zIndex: \"1029\",\r\n    color: grayColor[6],\r\n    border: \"0\",\r\n    borderRadius: \"3px\",\r\n    padding: \"10px 0\",\r\n    transition: \"all 150ms ease 0s\",\r\n    minHeight: \"50px\",\r\n    display: \"block\"\r\n  },\r\n  container: {\r\n    ...container,\r\n    minHeight: \"50px\"\r\n  },\r\n  flex: {\r\n    flex: 1\r\n  },\r\n  title: {\r\n    ...defaultFont,\r\n    lineHeight: \"30px\",\r\n    fontSize: \"18px\",\r\n    borderRadius: \"3px\",\r\n    textTransform: \"none\",\r\n    color: whiteColor,\r\n    letterSpacing: \"unset\",\r\n    \"&:hover,&:focus\": {\r\n      background: \"transparent\",\r\n      color: whiteColor\r\n    }\r\n  },\r\n  appResponsive: {\r\n    top: \"8px\"\r\n  },\r\n  primary: {\r\n    backgroundColor: primaryColor[0],\r\n    color: whiteColor,\r\n    ...defaultBoxShadow\r\n  },\r\n  info: {\r\n    backgroundColor: infoColor[0],\r\n    color: whiteColor,\r\n    ...defaultBoxShadow\r\n  },\r\n  success: {\r\n    backgroundColor: successColor[0],\r\n    color: whiteColor,\r\n    ...defaultBoxShadow\r\n  },\r\n  warning: {\r\n    backgroundColor: warningColor[0],\r\n    color: whiteColor,\r\n    ...defaultBoxShadow\r\n  },\r\n  danger: {\r\n    backgroundColor: dangerColor[0],\r\n    color: whiteColor,\r\n    ...defaultBoxShadow\r\n  },\r\n  list: {\r\n    ...defaultFont,\r\n    fontSize: \"12px\",\r\n    margin: 0,\r\n    marginRight: \"-15px\",\r\n    paddingLeft: \"0\",\r\n    listStyle: \"none\",\r\n    color: whiteColor,\r\n    paddingTop: \"0\",\r\n    paddingBottom: \"0\"\r\n  },\r\n  listItem: {\r\n    float: \"left\",\r\n    position: \"relative\",\r\n    display: \"block\",\r\n    width: \"auto\",\r\n    margin: \"0\",\r\n    padding: \"0\",\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      zIndex: \"999\",\r\n      width: \"100%\",\r\n      paddingRight: \"15px\"\r\n    }\r\n  },\r\n  navLink: {\r\n    color: whiteColor,\r\n    margin: \"0 5px\",\r\n    paddingTop: \"15px\",\r\n    paddingBottom: \"15px\",\r\n    fontWeight: \"500\",\r\n    fontSize: \"12px\",\r\n    textTransform: \"uppercase\",\r\n    borderRadius: \"3px\",\r\n    lineHeight: \"20px\",\r\n    position: \"relative\",\r\n    display: \"block\",\r\n    padding: \"10px 15px\",\r\n    textDecoration: \"none\",\r\n    \"&:hover,&:focus\": {\r\n      color: whiteColor,\r\n      background: \"rgba(\" + hexToRgb(grayColor[17]) + \", 0.2)\"\r\n    }\r\n  },\r\n  listItemIcon: {\r\n    marginTop: \"-3px\",\r\n    top: \"0px\",\r\n    position: \"relative\",\r\n    marginRight: \"3px\",\r\n    width: \"20px\",\r\n    height: \"20px\",\r\n    verticalAlign: \"middle\",\r\n    color: \"inherit\",\r\n    display: \"inline-block\"\r\n  },\r\n  listItemText: {\r\n    flex: \"none\",\r\n    padding: \"0\",\r\n    minWidth: \"0\",\r\n    margin: 0,\r\n    display: \"inline-block\",\r\n    position: \"relative\",\r\n    whiteSpace: \"nowrap\"\r\n  },\r\n  navLinkActive: {\r\n    backgroundColor: \"rgba(\" + hexToRgb(whiteColor) + \", 0.1)\"\r\n  },\r\n  drawerPaper: {\r\n    border: \"none\",\r\n    bottom: \"0\",\r\n    transitionProperty: \"top, bottom, width\",\r\n    transitionDuration: \".2s, .2s, .35s\",\r\n    transitionTimingFunction: \"linear, linear, ease\",\r\n    ...boxShadow,\r\n    width: drawerWidth,\r\n    ...boxShadow,\r\n    position: \"fixed\",\r\n    display: \"block\",\r\n    top: \"0\",\r\n    height: \"100vh\",\r\n    right: \"0\",\r\n    left: \"auto\",\r\n    visibility: \"visible\",\r\n    overflowY: \"visible\",\r\n    borderTop: \"none\",\r\n    textAlign: \"left\",\r\n    paddingRight: \"0px\",\r\n    paddingLeft: \"0\",\r\n    ...transition,\r\n    \"&:before,&:after\": {\r\n      position: \"absolute\",\r\n      zIndex: \"3\",\r\n      width: \"100%\",\r\n      height: \"100%\",\r\n      content: '\"\"',\r\n      display: \"block\",\r\n      top: \"0\"\r\n    },\r\n    \"&:after\": {\r\n      background: blackColor,\r\n      opacity: \".8\"\r\n    }\r\n  },\r\n  sidebarButton: {\r\n    \"&,&:hover,&:focus\": {\r\n      color: whiteColor\r\n    },\r\n    top: \"-2px\"\r\n  }\r\n});\r\n\r\nexport default pagesHeaderStyle;\r\n","import React from \"react\";\nimport cx from \"classnames\";\nimport PropTypes from \"prop-types\";\n\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport AppBar from \"@material-ui/core/AppBar\";\nimport Toolbar from \"@material-ui/core/Toolbar\";\nimport Hidden from \"@material-ui/core/Hidden\";\nimport Drawer from \"@material-ui/core/Drawer\";\nimport List from \"@material-ui/core/List\";\n\n// @material-ui/icons\nimport Menu from \"@material-ui/icons/Menu\";\n\n// core components\nimport Button from \"components/CustomButtons/Button\";\n\nimport styles from \"assets/jss/material-dashboard-pro-react/components/authNavbarStyle.js\";\nimport logoMachen from \"assets/img/logoMachen.svg\"\n\nimport { customApp } from \"functions\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function AuthNavbar(props) {\n  const [open, setOpen] = React.useState(false);\n  const handleDrawerToggle = () => {\n    setOpen(!open);\n  };\n  // verifies if routeName is the one active (in browser input)\n  const activeRoute = routeName => {\n    return window.location.href.indexOf(routeName) > -1 ? true : false;\n  };\n  const classes = useStyles();\n  const { color, brandText } = props;\n  const appBarClasses = cx({\n    [\" \" + classes[color]]: color\n  });\n  var list = (\n    <List className={classes.list}>\n      {/* <ListItem className={classes.listItem}>\n        <NavLink to={\"/d\"} className={classes.navLink}>\n          <Dashboard className={classes.listItemIcon} />\n          <ListItemText\n            primary={\"Dashboard\"}\n            disableTypography={true}\n            className={classes.listItemText}\n          />\n        </NavLink>\n      </ListItem>\n      <ListItem className={classes.listItem}>\n        <NavLink\n          to={\"/pricing-page\"}\n          className={cx(classes.navLink, {\n            [classes.navLinkActive]: activeRoute(\"/pricing-page\")\n          })}\n        >\n          <MonetizationOn className={classes.listItemIcon} />\n          <ListItemText\n            primary={\"Pricing\"}\n            disableTypography={true}\n            className={classes.listItemText}\n          />\n        </NavLink>\n      </ListItem> */}\n      {/* <ListItem className={classes.listItem}>\n        <NavLink\n          to={\"/register-page\"}\n          className={cx(classes.navLink, {\n            [classes.navLinkActive]: activeRoute(\"/register-page\")\n          })}\n        >\n          <PersonAdd className={classes.listItemIcon} />\n          <ListItemText\n            primary={\"Register\"}\n            disableTypography={true}\n            className={classes.listItemText}\n          />\n        </NavLink>\n      </ListItem> */}\n      {/* <ListItem className={classes.listItem}>\n        <NavLink\n          to={\"/login\"}\n          className={cx(classes.navLink, {\n            [classes.navLinkActive]: activeRoute(\"/login\")\n          })}\n        >\n          <Fingerprint className={classes.listItemIcon} />\n          <ListItemText\n            primary={\"Login\"}\n            disableTypography={true}\n            className={classes.listItemText}\n          />\n        </NavLink>\n      </ListItem> */}\n      {/* <ListItem className={classes.listItem}>\n        <NavLink\n          to={\"/lock-screen-page\"}\n          className={cx(classes.navLink, {\n            [classes.navLinkActive]: activeRoute(\"/lock-screen-page\")\n          })}\n        >\n          <LockOpen className={classes.listItemIcon} />\n          <ListItemText\n            primary={\"Lock\"}\n            disableTypography={true}\n            className={classes.listItemText}\n          />\n        </NavLink>\n      </ListItem> */}\n    </List>\n  );\n  return (\n    <AppBar position=\"static\" className={classes.appBar + appBarClasses}>\n      <Toolbar >\n        <div style={{ display: \"flex\", justifyContent: \"center\", width: \"100%\" }}>\n          <div style={{ maxWidth: \"222px\" }}>\n            <img src={customApp(\"customLogo\")} alt=\"logo\"\n              style={{\n                width: \"100%\",\n              }}\n            />\n          </div>\n        </div>\n        {/* <Hidden smDown>{list}</Hidden>\n        <Hidden mdUp>\n          <Button\n            className={classes.sidebarButton}\n            color=\"transparent\"\n            justIcon\n            aria-label=\"open drawer\"\n            onClick={handleDrawerToggle}\n          >\n            <Menu />\n          </Button>\n        </Hidden>\n        <Hidden mdUp>\n          <Hidden mdUp>\n            <Drawer\n              variant=\"temporary\"\n              anchor={\"right\"}\n              open={open}\n              classes={{\n                paper: classes.drawerPaper\n              }}\n              onClose={handleDrawerToggle}\n              ModalProps={{\n                keepMounted: true // Better open performance on mobile.\n              }}\n            >\n              {list}\n            </Drawer>\n          </Hidden>\n        </Hidden> */}\n      </Toolbar>\n    </AppBar>\n  );\n}\n\nAuthNavbar.propTypes = {\n  color: PropTypes.oneOf([\"primary\", \"info\", \"success\", \"warning\", \"danger\"]),\n  brandText: PropTypes.string\n};\n","import {\r\n  defaultFont,\r\n  container,\r\n  containerFluid,\r\n  primaryColor,\r\n  whiteColor,\r\n  grayColor\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst footerStyle = {\r\n  block: {},\r\n  left: {\r\n    float: \"left!important\",\r\n    display: \"block\"\r\n  },\r\n  right: {\r\n    margin: \"0\",\r\n    fontSize: \"12px\",\r\n    float: \"right!important\",\r\n    padding: \"15px\"\r\n  },\r\n  footer: {\r\n    bottom: \"0\",\r\n    borderTop: \"1px solid \" + grayColor[15],\r\n    padding: \"15px 0\",\r\n    ...defaultFont,\r\n    zIndex: 4\r\n  },\r\n  container: {\r\n    zIndex: 3,\r\n    ...container,\r\n    position: \"relative\"\r\n  },\r\n  containerFluid: {\r\n    zIndex: 3,\r\n    ...containerFluid,\r\n    position: \"relative\"\r\n  },\r\n  a: {\r\n    color: primaryColor[0],\r\n    textDecoration: \"none\",\r\n    backgroundColor: \"transparent\"\r\n  },\r\n  list: {\r\n    marginBottom: \"0\",\r\n    padding: \"0\",\r\n    marginTop: \"0\"\r\n  },\r\n  inlineBlock: {\r\n    display: \"inline-block\",\r\n    padding: \"0\",\r\n    width: \"auto\"\r\n  },\r\n  whiteColor: {\r\n    \"&,&:hover,&:focus\": {\r\n      color: whiteColor\r\n    }\r\n  }\r\n};\r\nexport default footerStyle;\r\n","/*eslint-disable*/\nimport React from \"react\";\nimport PropTypes from \"prop-types\";\nimport cx from \"classnames\";\n\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport List from \"@material-ui/core/List\";\nimport ListItem from \"@material-ui/core/ListItem\";\n\nimport styles from \"assets/jss/material-dashboard-pro-react/components/footerStyle.js\";\n\nimport { translate } from \"functions/\"\n\nconst useStyles = makeStyles(styles);\n\nexport default function Footer(props) {\n  const classes = useStyles();\n  const { fluid, white, rtlActive } = props;\n  var container = cx({\n    [classes.container]: !fluid,\n    [classes.containerFluid]: fluid,\n    [classes.whiteColor]: white\n  });\n  var anchor =\n    classes.a +\n    cx({\n      [\" \" + classes.whiteColor]: white\n    });\n  var block = cx({\n    [classes.block]: true,\n    [classes.whiteColor]: white\n  });\n  return (\n    <footer className={classes.footer}>\n      <div className={container} style={{\n        display: \"flex\",\n        justifyContent: \"center\"\n      }}>\n        <div className={classes.left}>\n          <List className={classes.list}>\n            {/* <ListItem className={classes.inlineBlock}>\n              <a href=\"#home\" className={block}>\n                {rtlActive ? \"الصفحة الرئيسية\" : \"Home\"}\n              </a>\n            </ListItem>\n            <ListItem className={classes.inlineBlock}>\n              <a href=\"#company\" className={block}>\n                {rtlActive ? \"شركة\" : \"Company\"}\n              </a>\n            </ListItem>\n            <ListItem className={classes.inlineBlock}>\n              <a href=\"#portfolio\" className={block}>\n                {rtlActive ? \"بعدسة\" : \"Portfolio\"}\n              </a>\n            </ListItem>\n            <ListItem className={classes.inlineBlock}>\n              <a href=\"#blog\" className={block}>\n                {rtlActive ? \"مدونة\" : \"Blog\"}\n              </a>\n            </ListItem> */}\n          </List>\n        </div>\n        <p className={classes.center}>\n          &copy; {1900 + new Date().getYear()}{\" \"}\n          <a\n            href=\"https://sonne.global\"\n            className={anchor}\n            target=\"_blank\"\n          >\n            {\"SONNE GLOBAL\"}\n          </a>\n          {` | ${translate(\"$__footerDescription\", 1) !== '$__footerDescription' ? translate(\"$__footerDescription\", 1) : ``}`}\n        </p>\n      </div>\n    </footer>\n  );\n}\n\nFooter.propTypes = {\n  fluid: PropTypes.bool,\n  white: PropTypes.bool,\n  rtlActive: PropTypes.bool\n};\n","//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = theme => ({\r\n    backdrop: {\r\n        zIndex: 4000,\r\n    },\r\n    header: {\r\n        position: 'absolute', top: '0px', left: '0px', right: '0px', height: '50px'\r\n    },\r\n    btClose: {\r\n        position: 'absolute', right: '15px', top: '15px'\r\n    },\r\n    content: {\r\n        position: 'absolute',\r\n        top: '50px',\r\n        bottom: '50px',\r\n        left: '30px',\r\n        right: '30px',\r\n        display: 'flex',\r\n        justifyContent: 'center',\r\n        alignItems: 'center'\r\n    },\r\n    loader: {\r\n        position: 'absolute', top: 'calc(50% - 20px)', left: 'calc(50% - 20px)', width: '40px', height: '40px',\r\n        '& .MuiCircularProgress-root': {\r\n            color: `${customApp('color')} !important`,\r\n        },\r\n    },\r\n    img: {\r\n        position: 'absolute',\r\n        top: '0px',\r\n        left: '0px',\r\n        right: '0px',\r\n        bottom: '0px',\r\n        backgroundRepeat: 'no-repeat',\r\n        backgroundSize: 'contain',\r\n        backgroundPosition: 'center center',\r\n        display: 'flex',\r\n        alignItems: 'center',\r\n        justifyContent: 'center',\r\n        '& img': {\r\n            width: 'auto',\r\n            height: 'auto',\r\n            maxWidth: '100%',\r\n            maxHeight: '100%'\r\n        }\r\n    },\r\n    movie: {\r\n        position: 'absolute',\r\n        width: '-webkit-fill-available',\r\n        height: '-webkit-fill-available',\r\n    },\r\n    embed: {\r\n        position: 'absolute',\r\n        width: '-webkit-fill-available',\r\n        height: '-webkit-fill-available',\r\n    },\r\n    leftButtom: {\r\n        position: 'absolute',\r\n        top: '50px',\r\n        bottom: '50px',\r\n        left: '0px',\r\n        width: '30px',\r\n        display: 'flex',\r\n        alignItems: 'center'\r\n    },\r\n    rightButtom: {\r\n        position: 'absolute',\r\n        top: '50px',\r\n        bottom: '50px',\r\n        width: '30px',\r\n        right: '0px',\r\n        display: 'flex',\r\n        alignItems: 'center'\r\n    },\r\n    footer: {\r\n        position: 'absolute',\r\n        bottom: '0px',\r\n        left: '0px',\r\n        right: '0px',\r\n        height: '50px',\r\n        display: 'flex',\r\n        alignItems: 'center',\r\n        justifyContent: 'center'\r\n    }\r\n})\r\n\r\nexport default style;","//CORE\nimport React from \"react\"\nimport Swipe from \"react-easy-swipe\"\nimport { PDFReader } from \"reactjs-pdf-reader\"\nimport ReactAudioPlayer from \"react-audio-player\"\nimport { decode as base64_decode, encode as base64_encode } from 'base-64';\nimport DocViewer from \"react-doc-viewer\";\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport CircularProgress from \"@material-ui/core/CircularProgress\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\nimport Backdrop from \"@material-ui/core/Backdrop\"\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/LightBox.js\"\n\n//IMAGES\nimport SVGIcon from \"assets/icons/svg.png\"\nimport ErrorBoundary from \"components/ErrorBoundary\";\n\nfunction Component(props) {\n    const { classes } = props\n    const { db, lightBox } = reduxStore.getState()\n    const [mounted, setMounted] = React.useState(false);\n    const [loader, setLoader] = React.useState(false)\n    const [sideChange, setsideChange] = React.useState(false)\n    const [activeFile, setActiveFile] = React.useState(null)\n    const [path, setPath] = React.useState(null)\n    const [originalPath, setOriginalPath] = React.useState(null)\n    const [pdfLoader, setPDFLoader] = React.useState(true)\n    const [pdfScale, setPdfScale] = React.useState(0.5)\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true);\n            window.addEventListener(\"keydown\", (e) => { interaction(e) }, false)\n        }\n    })\n\n    React.useEffect(() => {\n        if (lightBox.open && lightBox.files.length > 0 && lightBox.file && lightBox.file !== activeFile) {\n            setLoader(true)\n            setActiveFile(lightBox.file)\n            const file = reduxStore.getState().lightBox.files.filter(a => a._id === lightBox.file)[0]\n            const name = file && file.name ? file.name.split(\".\") : null\n            const path = file && file.file ? `https://machen.azureedge.net/${encodeURIComponent(file.file)}` : null\n            const pathOriginal = file && file.file ? `https://machen.azureedge.net/${file.file}` : null\n            const ext = name.length > 0 ? name[name.length - 1] : null\n            const viewer = ext ? db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0 ? db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].viewer : \"file\" : null\n\n            if (viewer === 'pdf') {\n                setPDFLoader(true)\n                setPath(path)\n            }\n            let img = path\n            if (db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0) {\n                img = db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0 && db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].icon ? db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].icon : `https://machen.azureedge.net/${file.file}`\n            }\n            setTimeout(() => {\n                setLoader(false)\n                setPath(path)\n                setOriginalPath(pathOriginal)\n            }, 1000)\n        }\n    }, [lightBox])\n\n    const interaction = (e) => {\n        if (\n            (\n                e.keyCode !== 39\n                && e.keyCode !== 40\n                && e.keyCode !== 37\n                && e.keyCode !== 38\n                && e.keyCode !== 27\n            )\n            ||\n            (\n                reduxStore.getState().lightBox.files.length === 1\n                && e.keyCode !== 27\n            )\n        )\n            return false\n        if (reduxStore.getState().lightBox.open) {\n            let active\n            reduxStore.getState().lightBox.files.map((f, i) => {\n                if (f._id === reduxStore.getState().lightBox.file)\n                    active = i\n            })\n            if (\n                e.keyCode === 39\n                ||\n                e.keyCode === 40\n            ) { //>>>>\n                if (active + 1 === reduxStore.getState().lightBox.files.length) {\n                    active = 0\n                } else {\n                    active = active + 1\n                }\n                changeFile(\"R\")\n            } else if (e.keyCode === 37 || e.keyCode === 38) { //<<<<\n                if (active === 0) {\n                    active = reduxStore.getState().lightBox.files.length - 1\n                } else {\n                    active = active - 1\n                }\n                changeFile(\"L\")\n            } else if (e.keyCode === 27) { //ESC\n                close()\n                return\n            } else {\n                return false\n            }\n            setLoader(true)\n            setTimeout(() => {\n                setLoader(false)\n            }, 1000)\n        }\n    }\n\n    const close = () => {\n        setTimeout(() => {\n            props.reduxFunction(\"ASYNC\", \"LIGHTBOX_CLOSE\")\n        }, 500)\n        window.removeEventListener(\"keydown\", (e) => { interaction(e) }, false)\n    }\n\n    const onSwipeMove = (position, event) => {\n        if (position.x > 100) {\n            setsideChange(\"L\")\n        } else if (position.x < -100) {\n            setsideChange(\"R\")\n        } else if (position.y < -100) {\n            close()\n        }\n    }\n\n    const onSwipeEnd = (event) => {\n        if (sideChange !== false) {\n            changeFile()\n        }\n    }\n    const changeFile = (side = null) => {\n        if (reduxStore.getState().lightBox.open) {\n            setLoader(true)\n            let active\n            reduxStore.getState().lightBox.files.map((f, i) => {\n                if (f._id === reduxStore.getState().lightBox.file)\n                    active = i\n            })\n            if (sideChange === \"R\" || side === \"R\") {\n                if (active + 1 === reduxStore.getState().lightBox.files.length) {\n                    active = 0\n                } else {\n                    active = active + 1\n                }\n            } else if (sideChange === \"L\" || side === \"L\") {\n                if (active === 0) {\n                    active = reduxStore.getState().lightBox.files.length - 1\n                } else {\n                    active = active - 1\n                }\n            }\n            if (reduxStore.getState().lightBox.files.length > 0 && reduxStore.getState().lightBox.files[active])\n                props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n                    ...reduxStore.getState().lightBox,\n                    file: reduxStore.getState().lightBox.files[active]._id\n                })\n            setTimeout(() => {\n                setLoader(false)\n                setsideChange(false)\n            }, 700)\n        }\n    }\n\n\n    if (!reduxStore.getState().lightBox.open && reduxStore.getState().lightBox.files.length === 0)\n        return null\n\n    const file = reduxStore.getState().lightBox.files.filter(a => a._id === activeFile)[0]\n    if (!file || !file.file)\n        return (<React.Fragment></React.Fragment>)\n    const name = file && file.name ? file.name.split(\".\") : null\n    const ext = name.length > 0 ? name[name.length - 1] : null\n    const viewer = ext ? db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0 ? db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].viewer : \"file\" : null\n\n    let img = path\n    const downloadPath = file && file.file ? `https://fl.machen.ai/?arq=${file.file.replace('&', '||MCH-ECOM||')}&name=${file.name.replace('&', '||MCH-ECOM||')}` : null\n\n    let variables = {\n        arq: file.file,\n        name: file.name,\n    }\n\n    // console.log(variables, JSON.stringify(variables), base64_encode(JSON.stringify(variables)))\n\n    // console.log(variables, JSON.stringify(variables))\n\n    const newDownloadPath = `https://fls.machen.ai/${encodeURIComponent(file.file)}/name/${encodeURIComponent(file.name)}`\n    console.log(newDownloadPath)\n\n\n    if (db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0) {\n        img = db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0 && db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].icon ? db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].icon : `https://machen.azureedge.net/${file.file}`\n    }\n\n    return (\n        <Swipe\n            onSwipeMove={onSwipeMove}\n            onSwipeEnd={onSwipeEnd}>\n            <Backdrop className={classes.backdrop} open={reduxStore.getState().lightBox.open} onClick={(e) => {\n                close()\n            }}>\n                <div\n                    id=\"lightBox\"\n                    className={classes.header}\n                    onClick={(e) => {\n                        close()\n                        e.stopPropagation()\n                    }}>\n                    <div className={classes.btClose}>\n                        <Icon title={translate(\"$__close\", \"*\")} color={customApp(\"light\")} onClick={() => { close() }}>close</Icon>\n                    </div>\n                </div>\n                <div style={{ display: \"flex\", justifyContent: \"center\", alignItems: \"center\" }}>\n                    <div\n                        className={classes.content}\n                        style={{ zIndex: 1000 }}\n                        onClick={(e) => {\n                            e.stopPropagation()\n                        }}>\n                        {loader ?\n                            <div className={classes.loader}>\n                                <CircularProgress />\n                            </div>\n                            : viewer === \"img\" ?\n                                <div\n                                    className={classes.img}\n                                >\n                                    {(typeof path === \"string\" && (path.indexOf(\"https://\") === -1 || path.indexOf(\"svg\") > -1)) ?\n                                        <React.Fragment>\n                                            {(viewer === \"img\" && img && img.indexOf(\"svg\") > -1) &&\n                                                <a href={downloadPath}>\n                                                    <div\n                                                        style={{ color: \"#FFFFFF\", fontWeight: \"bolder\", fontSize: \"22px\" }}\n                                                    >\n                                                        <img\n                                                            src={SVGIcon}\n                                                            style={\n                                                                {\n                                                                    borderRadius: \"15px\",\n                                                                    boxShadow: `0 1px 2px 2px rgba(0,0,0,0.1)`,\n                                                                    maxWidth: \"100%\",\n                                                                    height: \"100%\",\n                                                                    maxHeight: \"100px\"\n                                                                }}\n                                                        />\n                                                        {translate(\"$__clickHereToDownload\", 1)}\n                                                    </div>\n                                                </a>\n                                            }\n                                        </React.Fragment>\n                                        :\n                                        <img src={`${img}`}\n                                            onError={(e) => e.target.src = img}\n                                        />\n                                    }\n                                </div>\n                                : !loader && viewer === \"movie\" ?\n                                    <video\n                                        className={classes.movie}\n                                        src={path} controls></video>\n                                    : !loader && viewer === \"microsoft\" ?\n                                        <React.Fragment>\n                                            {/* {console.log(`https://view.officeapps.live.com/op/embed.aspx?src=${newDownloadPath}`)} */}\n                                            <ErrorBoundary>\n                                                <embed\n                                                    className={classes.embed}\n                                                    id=\"embed-docs\"\n                                                    onLoad={(e) => {\n                                                        e.target.style.display = \"none\"\n                                                        e.target.style.display = \"flex\"\n                                                    }}\n                                                    onError={(e) => {\n                                                        e.target.style.display = \"none\"\n                                                        e.target.style.display = \"flex\"\n                                                    }}\n                                                    src={`https://view.officeapps.live.com/op/embed.aspx?src=${newDownloadPath}`}\n                                                />\n                                            </ErrorBoundary>\n                                        </React.Fragment>\n                                        : !loader && viewer === \"text\" ?\n                                            <React.Fragment>\n                                                <ErrorBoundary>\n                                                    <embed\n                                                        className={classes.embed}\n                                                        id=\"embed-docs\"\n                                                        style={{\n                                                            backgroundColor: \"#FFFFFF\",\n                                                            padding: 15\n                                                        }}\n                                                        onLoad={(e) => {\n                                                            e.target.style.display = \"none\"\n                                                            e.target.style.display = \"flex\"\n                                                        }}\n                                                        onError={(e) => {\n                                                            e.target.style.display = \"none\"\n                                                            e.target.style.display = \"flex\"\n                                                        }}\n                                                        src={`${newDownloadPath}`}\n                                                    />\n                                                </ErrorBoundary>\n                                            </React.Fragment>\n                                            : !loader && viewer === \"pdf\" && path ?\n                                                <div className={classes.embed}>\n                                                    {pdfLoader &&\n                                                        <div className={classes.loader}>\n                                                            <CircularProgress />\n                                                        </div>\n                                                    }\n                                                    <div className={classes.embed}>\n                                                        <div className={classes.embed}\n                                                            style={{ overflow: 'auto' }}>\n                                                            <div className={classes.embed}\n                                                                style={{ zoom: `${pdfScale * 100}%` }}>\n                                                                <ErrorBoundary>\n                                                                    <embed\n                                                                        className={classes.embed}\n                                                                        id=\"embed-docs\"\n                                                                        onLoad={(e) => {\n                                                                            e.target.style.display = \"none\"\n                                                                            e.target.style.display = \"flex\"\n                                                                        }}\n                                                                        onError={(e) => {\n                                                                            e.target.style.display = \"none\"\n                                                                            e.target.style.display = \"flex\"\n                                                                        }}\n                                                                        src={`${newDownloadPath}`}\n                                                                        d\n                                                                    />\n\n                                                                </ErrorBoundary>\n                                                            </div>\n                                                        </div>\n                                                    </div>\n                                                </div>\n                                                : !loader && viewer === \"audio\" ? (\n                                                    <ReactAudioPlayer\n                                                        src={path}\n                                                        autoPlay\n                                                        controls\n                                                    />\n                                                )\n                                                    : !loader && viewer === \"file\" ? (\n                                                        <a href={downloadPath}>\n                                                            <div\n                                                                style={{ color: \"#FFFFFF\", fontWeight: \"bolder\", fontSize: \"22px\" }}\n                                                            >\n                                                                {translate(\"$__clickHereToDownload\", 1)}\n                                                            </div>\n                                                        </a>\n                                                    )\n                                                        : !loader ?\n                                                            <embed\n                                                                className={classes.embed}\n                                                                id=\"embed-pdf\"\n                                                                onLoad={(e) => {\n                                                                    e.target.style.display = \"none\"\n                                                                    e.target.style.display = \"flex\"\n                                                                }}\n                                                                onError={(e) => {\n                                                                    e.target.style.display = \"none\"\n                                                                    e.target.style.display = \"flex\"\n                                                                }}\n                                                                src={`https://drive.google.com/viewerng/viewer?embedded=true&url=${path}`}\n                                                            />\n                                                            : null\n                        }\n                    </div>\n                    {reduxStore.getState().lightBox.files.length > 1 &&\n                        <React.Fragment>\n                            <div className={classes.leftButtom}>\n                                <Icon title={translate(\"$__previous\", \"*\")} color={customApp(\"light\")} size=\"33px\" onClick={() => { changeFile(\"L\") }}>keyboard_arrow_left</Icon>\n                            </div>\n                            <div className={classes.rightButtom}>\n                                <Icon title={translate(\"$__next\", \"*\")} color={customApp(\"light\")} size=\"33px\" onClick={() => { changeFile(\"R\") }}>keyboard_arrow_right</Icon>\n                            </div>\n                        </React.Fragment>\n                    }\n                    <div className={classes.footer} onClick={(e) => {\n                        e.stopPropagation()\n                    }}>\n                        <a href={downloadPath}>\n                            <Icon title={translate(\"$__download\", \"*\")} color={customApp(\"light\")} size=\"33px\"\n                            >get_app</Icon>\n                        </a>\n                    </div>\n                </div>\n            </Backdrop >\n        </Swipe >\n    )\n}\n\n//REACT\nconst mapStateToProps = (store) => ({\n    store: {\n        lightbox: store.lightBox\n    }\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component))","import React from \"react\";\nimport styled from \"styled-components\";\n\n//@MATERIALS\nimport CircularProgress from '@material-ui/core/CircularProgress';\nimport { makeStyles } from '@material-ui/core/styles';\n\nconst PreLoaderContent = styled.div`\n  position: relative;\n  width: 100%;\n  height: 100%;\n  padding-top: 20px;\n  padding-bottom: 20px;\n`;\n\nconst Escurecer = styled.div`\n  position: fixed;\n  top: 0;\n  left: 0;\n  right: 25%;\n  width: 100%;\n  height: 100%;\n  background-color: #ffffffeb;\n  z-index: 7000;\n`;\n\nexport default function CircularIndeterminate(props) {\n\n  return (\n    <div id={`preloaderComponent`}>\n      {!props.fullScreen ? (\n        <PreLoaderContent>\n          <CircularProgress />\n        </PreLoaderContent>\n      ) : (\n          <Escurecer>\n            <CircularProgress size={props.size | 50} />\n          </Escurecer>\n        )}\n    </div>\n  );\n}\n","//CORE\r\nimport React from 'react'\r\n\r\n//COMPONENTES\r\nimport PreLoader from \"components/PreLoader\";\r\nimport { translate } from 'functions';\r\n\r\nfunction Component(props) {\r\n    return (\r\n        <div style={{\r\n            position: 'absolute',\r\n            top: '0px',\r\n            left: '0px',\r\n            right: '0px',\r\n            bottom: '0px',\r\n            display: 'flex',\r\n            alignItems: 'center',\r\n            justifyContent: 'center',\r\n            height: '100%'\r\n        }}>\r\n            <div\r\n                style={{\r\n                    width: \"100%\",\r\n                    maxWidth: \"250px\",\r\n                    height: \"150px\",\r\n                    display: 'flex',\r\n                    alignItems: 'center',\r\n                    justifyContent: 'center',\r\n                }}>\r\n                <PreLoader />\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\n\r\nexport default Component\r\n","import {\r\n  defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst buttonStyle = {\r\n  button: {\r\n    ...defaultFont,\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\",\r\n    cursor: \"pointer\",\r\n    // width: 'fit-content',\r\n    userSelect: \"none\",\r\n    \"&$reverse\": {},\r\n  },\r\n  buttonText: {\r\n    ...defaultFont,\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\",\r\n    // marginLeft: \"7px\",\r\n    cursor: \"pointer\",\r\n    width: 'fit-content',\r\n    userSelect: \"none\",\r\n    \"&$reverse\": {},\r\n    \"& :hover\": {\r\n      //backgroundColor: 'rgba(0,0,0,0.1)'\r\n    }\r\n  },\r\n  reverse: {\r\n    flexDirection: \"row-reverse\",\r\n  },\r\n  iconButton: {\r\n    width: \"21px\",\r\n    height: \"21px\",\r\n    display: \"flex\",\r\n    justifyContent: \"center\",\r\n    alignItems: \"center\",\r\n    borderRadius: \"10%\",\r\n  },\r\n  icon: {\r\n    fontSize: \"21px\"\r\n  },\r\n  onlyIcon: {\r\n    fontSize: \"21px\"\r\n  },\r\n  text: {\r\n    marginLeft: \"7px\",\r\n    marginRight: \"7px\"\r\n  }\r\n};\r\n\r\nexport default buttonStyle;\r\n","import React from \"react\";\nimport classNames from \"classnames\";\n\n// material-ui components\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport Icon from \"components/Icon/Badge\";\nimport styles from \"assets/jss/material-dashboard-pro-react/components/iconButtonStyle.js\";\n\n//FUNCTIONS\nimport { customApp } from \"functions/\"\n\nconst useStyles = makeStyles(styles);\n\nconst RegularButton = React.forwardRef((props, ref) => {\n    const classes = useStyles();\n    const { reverse, text } = props;\n    const btnClasses = classNames({\n        [classes.button]: true,\n        [classes.reverse]: props.reverse ? true : false,\n    });\n\n    const btnClassesText = classNames({\n        [classes.buttonText]: true,\n        [classes.reverse]: props.reverse ? true : false,\n    });\n    return (\n        <div className={props.text ? btnClassesText : btnClasses} onClick={() => props.onClick ? props.onClick() : null}\n            style={{\n                ...props.style\n            }}\n        >\n            <div\n                className={classes.iconButton}\n                style={{\n                    color: props.iconColor ? customApp(props.iconColor) : customApp('color'),\n                    backgroundColor: props.iconBackground ? customApp(props.iconBackground) : 'none',\n                }}>{\n                    props.icon ?\n                        <Icon\n                            className={props.iconBackground ? classes.icon : classes.onlyIcon}\n                            size={props.size ? props.size : null}\n                            icon={props.icon} color={props.iconColor}\n                            title={props.title || null}\n                            onClick={() => props.onClick ? props.onClick() : null}\n                            style={{\n                                ...props.style ? props.style : {}\n                            }}\n                        />\n                        :\n                        <Icon\n                            className={props.iconBackground ? classes.icon : classes.onlyIcon}\n                            icon={'stop_circle'}\n                            color={props.iconColor}\n                            title={props.title || null}\n                            onClick={() => props.onClick ? props.onClick() : null}\n                            style={{\n                                ...props.style ? props.style : {}\n                            }}\n                        />\n                }\n            </div>\n            {text &&\n                <div className={classes.text} style={{ color: props.textColor ? customApp(props.textColor) : customApp('medium') }}>{text}</div>\n            }\n        </div>\n    );\n});\n\nexport default RegularButton;\n","import React from \"react\"\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport IconButton from \"components/CustomButtons/IconButton\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport { makeStyles } from '@material-ui/core/styles';\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n} from \"functions/\"\n\n//IMAGES\nimport defaultAvatar from \"assets/img/fundo-sonne.png\"\n\nconst useStyles = makeStyles({\n    users: {\n        position: 'relative',\n        bottom: '0px',\n        right: '2px',\n        fontSize: '10px',\n        '& .MuiAvatarGroup-root': {\n            justifyContent: 'flex-end',\n        },\n        '& .MuiAvatar-root': {\n            width: '25px',\n            height: '25px',\n            fontSize: '10px',\n        }\n    }\n});\n\nconst Component = (props) => {\n    const { session, functions } = reduxStore.getState();\n    const { socket } = functions;\n    const [data, setData] = React.useState(props.data)\n    const classes = useStyles();\n\n    React.useEffect(() => {\n        setData(props.data)\n    }, [props.data])\n\n    const reactThis = async (react, d) => {\n        socket.emit(\"data\", {\n            module: \"social\",\n            method: \"post\",\n            action: \"interact\"\n        }, {\n            react: react,\n            user: session._id,\n            nodeId: props.data._id,\n            message: props.data._id,\n            delete: d\n        })\n\n        let newData = data\n        if (newData && newData._reactions && Object.keys(newData._reactions).length > 0)\n            Object.keys(newData._reactions).filter(r => r !== react).map(r => {\n                if (newData._reactions[r][session._id])\n                    delete newData._reactions[r][session._id]\n            })\n\n        if (d && data && data._reactions && data._reactions[react] && data._reactions[react][session._id]) {\n            let newData = data\n            delete newData._reactions[react][session._id]\n            setData(newData)\n        } else {\n            setData({\n                ...data,\n                _reactions: {\n                    ...data._reactions,\n                    [react]: {\n                        [session._id]: {\n                            ...session.displayName ? { displayName: session.displayName } : {},\n                            ...session.name ? { name: session.name } : {},\n                            ...session.image ? { image: session.image } : {},\n                            reactDate: { low: moment().tz('America/Sao_Paulo').unix('X') }\n                        }\n                    }\n                }\n            })\n        }\n    }\n\n    let reaction\n    if (data._reactions && Object.keys(data._reactions).length > 0)\n        Object.keys(data._reactions).map(re => {\n            if (Object.keys(data._reactions[re]).length > 0)\n                Object.keys(data._reactions[re]).map(us => {\n                    if (us === session._id)\n                        reaction = re\n                })\n        })\n\n    const ReactionComp = ({ react, color, primaryIcon, secondaryIcon }) => {\n        if (props.hideDisables\n            && data && react\n            && data._reactions\n            &&\n            (\n                !data._reactions[react]\n                || (\n                    data._reactions[react]\n                    && Object.keys(data._reactions[react]).length === 0\n                )\n            )\n        )\n            return (<React.Fragment></React.Fragment>)\n\n        return (\n            <IconButton\n                icon={data._reactions && data._reactions[react] && data._reactions[react][session._id] ? primaryIcon : secondaryIcon ? secondaryIcon : primaryIcon}\n                iconColor={data._reactions && data._reactions[react] && data._reactions[react][session._id] ? color ? color : customApp(\"menu\") : \"lightgray\"}\n                size={\"18px\"}\n                onClick={() => {\n                    reactThis(react, data._reactions && data._reactions[react] && data._reactions[react][session._id] ? true : false)\n                }}\n                title={data._reactions && data._reactions[react] && Object.keys(data._reactions[react]).length > 0 ?\n                    <React.Fragment>\n                        <div style={{\n                            position: \"relative\",\n                            width: \"100%\",\n                            paddingBottom: 3,\n                            borderBottom: \"1px solid lightgray\",\n                            marginBottom: \"7px\",\n                        }}>{translate(`$__${react}`, 1)}</div>\n                        <div className={classes.users}>\n                            {Object.keys(data._reactions[react])\n                                .sort((a, b) => {\n                                    if (\n                                        data._reactions[react][a].reactDate\n                                        && String(data._reactions[react][a].reactDate.low)\n                                        && data._reactions[react][b].reactDate\n                                        && String(data._reactions[react][b].reactDate.low)\n                                        && parseInt(data._reactions[react][a].reactDate.low) < parseInt(data._reactions[react][b].reactDate.low)\n                                    ) {\n                                        return -1\n                                    } else if (\n                                        data._reactions[react][a].reactDate\n                                        && String(data._reactions[react][a].reactDate.low)\n                                        && data._reactions[react][b].reactDate\n                                        && String(data._reactions[react][b].reactDate.low)\n                                        && parseInt(data._reactions[react][a].reactDate.low) > parseInt(data._reactions[react][b].reactDate.low)\n                                    ) {\n                                        return 1\n                                    } else {\n                                        return 0\n                                    }\n                                })\n                                .map((a, i) => {\n                                    return (\n                                        <div key={a} style={{ position: \"relative\", display: \"flex\", alignItems: \"center\", }}>\n                                            <Avatar alt={data._reactions[react][a].name} src={data._reactions[react][a].image || defaultAvatar} />\n                                            <span style={{ paddingLeft: \"7px\" }}>\n                                                {data._reactions[react][a].displayName ? data._reactions[react][a].displayName : data._reactions[react][a].name}{data._reactions[react][a].reactDate && data._reactions[react][a].reactDate.low && ` (${moment(data._reactions[react][a].reactDate.low * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")})`}\n                                            </span>\n                                        </div>\n                                    )\n                                }\n                                )}\n                        </div>\n                    </React.Fragment>\n                    :\n                    translate(`$__${react}`, 1)\n                }\n            />\n        )\n    }\n\n    return (\n        <div\n            onClick={(e) => {\n                e.stopPropagation()\n            }}\n        >\n            <div\n                style={{\n                    display: \"flex\",\n                    minWidth: \"fit-content\",\n                    justifyContent: \"center\"\n                }}\n            >\n                <ReactionComp react=\"like\" primaryIcon=\"thumb_up\" secondaryIcon=\"thumb_up_off_alt\" />\n                <ReactionComp react=\"nolike\" primaryIcon=\"thumb_down\" secondaryIcon=\"thumb_down_off_alt\" />\n                <ReactionComp react=\"love\" primaryIcon=\"favorite\" secondaryIcon=\"favorite_border\" color=\"red\" />\n                <ReactionComp react=\"approve\" primaryIcon=\"verified\" color=\"green\" />\n                <ReactionComp react=\"attention\" primaryIcon=\"report_problem\" color=\"red\" />\n                {props.children &&\n                    <React.Fragment>\n                        {props.children}\n                    </React.Fragment>\n                }\n            </div>\n        </div>\n\n    );\n}\n\nexport default Component","import React, { memo } from \"react\";\n\n//COMPONENTS\nimport Icon from \"components/Icon/\";\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\";\nimport Badge from '@material-ui/core/Badge';\nimport Button from '@material-ui/core/Button';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport Grow from '@material-ui/core/Grow';\nimport IconButton from '@material-ui/core/IconButton';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport MenuList from '@material-ui/core/MenuList';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport Tooltip from \"@material-ui/core/Tooltip\";\nimport { makeStyles } from '@material-ui/core/styles';\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\";\n\n\nconst useStyles = makeStyles((props) => ({\n    iconButtonStyleTransaparent: {\n        padding: \"3px\",\n        margin: 0,\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        },\n        ...props.buttonStyle ? props.buttonStyle : {}\n    },\n    iconButtonStyleWhite: {\n        padding: \"3px\",\n        margin: 0,\n        backgroundColor: '#FFFFFF',\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        },\n        ...props.buttonStyle ? props.buttonStyle : {}\n    },\n}));\n\nfunction Comp(props) {\n    const classes = useStyles();\n    const [open, setOpen] = React.useState(false);\n    const anchorRef = React.useRef(null)\n\n    const handleClose = (event) => {\n        event.preventDefault()\n        event.stopPropagation()\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n\n        setOpen(false);\n        if (props.onClose)\n            props.onClose()\n    };\n\n    function handleListKeyDown(event) {\n        if (event.key === 'Tab') {\n            event.preventDefault();\n            setOpen(false);\n            if (props.onClose)\n                props.onClose()\n        }\n    }\n\n    if (!props.options || props.options.length === 0)\n        return (<React.Fragment></React.Fragment>)\n\n    return (\n        <div style={{ zIndex: \"100 !important\", ...props.style ? props.style : {} }}>\n            <Tooltip\n                title={props.title ? props.title : translate(`$__options`, 1)}\n            >\n                {!props.text ?\n\n                    <IconButton\n                        ref={anchorRef}\n                        aria-controls={open ? 'menu-list-grow' : undefined}\n                        aria-haspopup=\"true\"\n                        aria-label=\"menu\"\n                        onClick={(e) => {\n                            setOpen((prevOpen) => !prevOpen);\n                            if (!open && props.onOpen)\n                                props.onOpen()\n                            if (open && props.onClose)\n                                props.onClose()\n                            e.stopPropagation()\n                        }}\n                        className={!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}\n                    >\n                        <Icon\n                            count={props.count ? props.count : null}\n                            usePropagation\n                            size={!props.size ? \"20px\" : props.size}\n                            color={props.btColor ? props.btColor : customApp('menu')}\n                            icon={props.icon ? props.icon : !props.horizontalButton ? 'more_vert' : 'more_horiz'}\n                        />\n                    </IconButton>\n                    :\n                    <Button\n                        ref={anchorRef}\n                        aria-controls={open ? 'menu-list-grow' : undefined}\n                        aria-haspopup=\"true\"\n                        aria-label=\"menu\"\n                        onClick={(e) => {\n                            setOpen((prevOpen) => !prevOpen);\n                            if (!open && props.onOpen)\n                                props.onOpen()\n                            if (open && props.onClose)\n                                props.onClose()\n                            e.stopPropagation()\n                        }}\n                        className={!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}\n                    >\n                        <React.Fragment>\n                            <span\n                                style={{\n                                    marginRight: '15px',\n                                    color: props.textColor ? props.textColor : props.color ? props.color : customApp('menu'),\n                                    overflow: \"hidden\",\n                                    textOverflow: \"ellipsis\",\n                                    width: \"90%\",\n                                    maxWidth: props.maxWidth ? props.maxWidth : \"90%\",\n                                    whiteSpace: \"nowrap\"\n                                }}>{props.text}</span>\n                            <Icon\n                                count={props.count ? props.count : null}\n                                usePropagation\n                                size={!props.size ? \"20px\" : props.size}\n                                color={props.btColor ? props.btColor : customApp('menu')}\n                                icon={props.icon ? props.icon : !props.horizontalButton ? 'more_vert' : 'more_horiz'}\n                            />\n                        </React.Fragment>\n                    </Button>\n                }\n            </Tooltip >\n            <Popper\n                open={open}\n                anchorEl={anchorRef.current}\n                role={undefined}\n                transition\n                style={{ zIndex: \"100 !important\" }}\n            >\n                {({ TransitionProps, placement }) => (\n                    <Grow\n                        {...TransitionProps}\n                        style={{\n                            transformOrigin: 'right center',\n                            zIndex: \"100 !important\"\n                        }}\n                    >\n                        <Paper>\n                            <ClickAwayListener onClickAway={handleClose}>\n                                <MenuList\n                                    autoFocusItem={open}\n                                    id=\"menu-list-grow\"\n                                    onKeyDown={handleListKeyDown}\n                                    style={{ zIndex: \"100 !important\" }}\n                                >\n                                    {props.options\n                                        .filter(a => a && !a.hide)\n                                        .map((a, i) =>\n                                            <MenuItem\n                                                key={i}\n                                                style={{\n                                                    color: a && a.color ? a.color : customApp('menu'),\n                                                    padding: \"12px 7px\"\n                                                }}\n                                                onClick={(e) => {\n                                                    if (!props.forceStopPropagation)\n                                                        setOpen(false);\n                                                    if (props.onClose)\n                                                        props.onClose()\n                                                    if (a.onClick)\n                                                        a.onClick()\n                                                    e.preventDefault()\n                                                    e.stopPropagation()\n                                                }}\n                                                disabled={a.disabled ? true : false}\n                                            >\n                                                {a.render ?\n                                                    a.render\n                                                    : a.avatar ?\n                                                        <Avatar\n                                                            alt={a.name} src={a.avatar || null}\n                                                            style={{\n                                                                width: !props.size ? \"20px\" : props.size,\n                                                                height: !props.size ? \"20px\" : props.size\n                                                            }}>\n                                                            {a.name.substr(0, 1)}\n                                                        </Avatar>\n                                                        :\n                                                        <Badge\n                                                            overlap=\"rectangular\"\n                                                            badgeContent={a.count ? a.count : null}\n                                                            color=\"secondary\"\n                                                        >\n                                                            <Icon\n                                                                usePropagation\n                                                                icon={a.icon}\n                                                                style={{ margin: 'none !important' }}\n                                                                color={a.iconColor ? a.iconColor : a.color ? a.color : customApp('menu')} />\n                                                        </Badge>\n                                                }\n                                                {!a.render &&\n                                                    <span style={{ marginLeft: '7px' }}>\n                                                        {translate(a.name, 1)}\n                                                    </span>\n                                                }\n                                            </MenuItem>\n                                        )\n                                    }\n                                </MenuList>\n                            </ClickAwayListener>\n                        </Paper>\n                    </Grow>\n                )}\n            </Popper>\n        </div>\n    )\n}\nexport default memo(Comp);","import React from 'react';\nimport IconButton from '@material-ui/core/IconButton';\nimport Menu from '@material-ui/core/Menu';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport DateRange from '@material-ui/icons/DateRange';\n\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//FUNCTIONS\nimport { translate } from \"functions/\";\nimport { pageLoadCards } from \"functions/loadData\"\n\nconst options = [\n    '$__last7Days',\n    '$__last15Days',\n    '$__last30Days',\n    '$__last60Days',\n    '$__last90Days',\n    '$__last180Days',\n    '$__last365Days',\n];\n\nconst ITEM_HEIGHT = 48;\n\nconst mapStateToProps = (store) => ({\n    store: {\n        session: store.session\n    }\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\n\nfunction LongMenu(props) {\n    const { session } = reduxStore.getState()\n    const [anchorEl, setAnchorEl] = React.useState(null);\n    const open = Boolean(anchorEl);\n\n    React.useEffect(() => {\n        return () => {\n            props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                ...reduxStore.getState().session,\n                period: \"$__last7Days\",\n                dashboard: {\n                    ...reduxStore.getState().session,\n                    period: \"$__last7Days\"\n                }\n            })\n        }\n    }, [])\n\n    const handleClick = (event) => {\n        setAnchorEl(event.currentTarget);\n    };\n\n    const handleClose = async (option) => {\n        // console.log(option)\n        setAnchorEl(null);\n        if (typeof option === 'string') {\n            props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                ...reduxStore.getState().session,\n                period: option,\n                dashboard: {\n                    ...reduxStore.getState().session,\n                    period: option\n                }\n            })\n            let subtractDays = String(option).replace('$__last', '')\n            subtractDays = subtractDays.replace('Days', '')\n            await pageLoadCards(props, subtractDays)\n        }\n    };\n\n    return (\n        <div>\n            <IconButton\n                aria-label=\"more\"\n                aria-controls=\"long-menu\"\n                aria-haspopup=\"true\"\n                onClick={handleClick}\n                style={{ ...props.style ? props.style : {} }}\n            >\n                <DateRange />\n            </IconButton>\n            <Menu\n                id=\"long-menu\"\n                anchorEl={anchorEl}\n                keepMounted\n                open={open}\n                onClose={handleClose}\n                PaperProps={{\n                    style: {\n                        maxHeight: ITEM_HEIGHT * 4.5,\n                        width: '20ch',\n                    },\n                }}\n            >\n                {options.map((option) => (\n                    <MenuItem\n                        key={option}\n                        selected={option === session.dashboard.period}\n                        onClick={(e) => handleClose(option)}\n                    >\n                        {translate(option, 1)}\n                    </MenuItem>\n                ))}\n            </Menu>\n        </div>\n    );\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps)(LongMenu)","import React from \"react\"\n\n//@MATERIAL \nimport TF from '@material-ui/core/TextField';\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\n//STYLES\nimport {\n    defaultFont,\n} from \"assets/jss/material-dashboard-pro-react.js\";\n\nconst TextField = React.forwardRef((props, ref) => {\n    const styles = {\n        root: {\n            ...defaultFont,\n            color: customApp('mediumText'),\n            padding: 0,\n            width: \"100%\",\n            marginTop: \"7px\",\n            marginBottom: \"7px\",\n            '& .invalid': {\n                borderBottom: 'solid 2px red !important',\n            },\n            '& .MuiOutlinedInput-input': {\n                padding: \"11px 11px\",\n                fontSize: \"12px\",\n            },\n            '& label': {\n                marginTop: \"-10px\",\n                fontSize: \"12px\"\n            },\n            '& label.MuiFormLabel-filled': {\n                color: customApp('mediumText'), //customApp\n                marginTop: customApp('fieldVariant') === 'standard' ? \"-10px\" : customApp('fieldVariant') === 'filled' ? \"-10px\" : 0\n            },\n            '& label.Mui-focused': {\n                color: customApp('mediumText'), //customApp\n                marginTop: customApp('fieldVariant') === 'standard' ? \"-10px\" : customApp('fieldVariant') === 'filled' ? \"-10px\" : 0\n            },\n            '& .MuiInput-underline:after': {\n                borderBottomColor: customApp('line'), //customApp\n            },\n            '& .MuiOutlinedInput-root': {\n                borderRadius: customApp('fieldRadius'),\n                '& fieldset': {\n                    borderColor: customApp('line'), //customApp\n                },\n                '&.Mui-focused fieldset': {\n                    borderColor: customApp('line'), //customApp\n                },\n            },\n            '& .MuiFilledInput-root': {\n                borderRadius: customApp('fieldRadius'),\n                '& fieldset': {\n                    borderColor: customApp('line'), //customApp\n                },\n                '&::before': {\n                    borderBottomColor: customApp('line')\n                },\n                '&::after': {\n                    borderBottomColor: customApp('line')\n                },\n                '&.Mui-focused': {\n                    borderBottomColor: customApp('line'), //customApp\n                    '&::before': {\n                        borderBottomColor: customApp('line')\n                    },\n                    '&::after': {\n                        borderBottomColor: customApp('line')\n                    },\n                },\n            },\n            '& .MuiInputLabel-outlined': {\n                marginTop: '0px',\n                '&.Mui-focused': {\n                    marginTop: '0px',\n                },\n                '&.MuiFormLabel-filled': {\n                    marginTop: '0px',\n                }\n            },\n            '& .MuiInputBase-root': {\n                marginTop: customApp('fieldVariant') === 'standard' ? 0 : customApp('fieldVariant') === 'filled' ? \"-15px\" : 0,\n                borderRadius: customApp('fieldRadius'),\n                '& fieldset': {\n                    borderColor: customApp('line'), //customApp\n                },\n                '&::before': {\n                    borderBottomColor: customApp('line')\n                },\n                '&::after': {\n                    borderBottomColor: customApp('line')\n                },\n                '&.Mui-focused': {\n                    borderBottomColor: customApp('line'), //customApp\n                    '&::before': {\n                        borderBottomColor: customApp('line')\n                    },\n                    '&::after': {\n                        borderBottomColor: customApp('line')\n                    },\n                },\n            },\n        },\n    }\n    const useStyles = makeStyles(styles);\n    const classes = useStyles();\n\n    return (<TF {...props} ref={ref} className={classes.root} />)\n})\n\nexport default TextField","import React from \"react\";\n\n//REDUX\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport ColorPicker from \"components/ColorPicker\";\nimport CustomButton from \"components/Buttons/custom\";\nimport Icon from \"components/Icon\";\nimport MoreMenu from \"components/MoreMenu/\";\nimport NotificationCount from \"components/NotificationsV2/count\";\nimport PeriodFilter from \"components/Filter/period\";\nimport TextField from \"components/TextField\";\n\n\n//@MATERIAL\nimport IconButton from \"@material-ui/core/IconButton\";\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport Badge from \"components/Icon/Badge\";\nimport Tooltip from \"@material-ui/core/Tooltip\";\n\n//FUNCTIONS\nimport { translate, customApp, Highlighted } from \"functions/\";\n\nconst useStyles = makeStyles((theme) => ({\n    header: {\n        display: \"flex\",\n        width: \"100%\",\n        justifyContent: \"space-between\"\n    },\n    content: {\n        position: \"relative\",\n        width: \"100%\",\n        height: \"100%\",\n        display: \"flex\",\n        alignItems: \"center\"\n    },\n    contentWithExpand: {\n        position: \"relative\",\n        width: \"calc(100% - 7px)\",\n        height: \"100%\",\n        display: \"flex\",\n        paddingLeft: \"5px\",\n        paddingTop: \"5px\",\n        alignItems: \"center\",\n        justifyContent: \"center\"\n    },\n    info: {\n        display: \"flex\",\n        width: \"100%\",\n        alignItems: \"center\"\n    },\n    headerIcon: {\n        display: \"contents\",\n        alignItems: \"center\",\n    },\n    headerTitle: {\n        width: \"100%\",\n        overflowX: \"hidden\",\n        overflowY: \"hidden\",\n        fontWeight: \"bold\",\n    },\n    actionButtons: {\n        position: \"absolute\",\n        height: \"24px\",\n        right: \"3px\",\n        display: \"flex\",\n    },\n    cancelButton: {\n        right: \"4px\",\n        position: \"absolute\",\n        cursor: \"pointer\",\n    },\n    saveButton: {\n        right: \"33px\",\n        position: \"absolute\",\n        cursor: \"pointer\",\n    },\n    button: {\n        padding: \"3px auto\",\n        cursor: \"pointer\",\n        alignItems: \"center\",\n        display: \"flex\",\n        opacity: 1,\n    },\n    parent: {\n        width: \"100%\",\n        padding: \"0 5px\",\n        \"& .title\": {\n            color: customApp(\"medium\"),\n            fontSize: \"10px\",\n            textTransform: \"uppercase\"\n        },\n        \"& .info\": {\n            marginTop: \"-8px\",\n            color: customApp(\"colorText\"),\n            fontWeight: \"500\",\n            alignItems: \"center\",\n        }\n    },\n    iconButtonStyle: {\n        margin: 0,\n        backgroundColor: \"#FFFFFF\",\n        \"&:hover\": {\n            backgroundColor: \"rgba(250,250,250,0.9)\"\n        },\n        padding: \"3px\"\n    },\n}));\n\nfunction Component(props) {\n    const { session, functions, db } = reduxStore.getState()\n    const { socket } = functions\n    const classes = useStyles();\n    const [mounted, setMounted] = React.useState(false)\n    const [name, setName] = React.useState(props.title.trim() || null)\n    const [editing, setEditing] = React.useState(false)\n    const [showPrivateCard, setShowPrivateCard] = React.useState(false)\n\n    React.useEffect(() => {\n        return () => {\n            // return false\n        }\n    }, [])\n\n    React.useEffect(() => {\n        if (String(props.unlockedPrivates) === \"0\" && showPrivateCard) {\n            setShowPrivateCard(false)\n        }\n    }, [props.unlockedPrivates])\n\n\n\n    React.useEffect(() => {\n        if (!props.title && props.editable) {\n            setEditing(true)\n        }\n    }, [props.title])\n\n    const stripHtml = (html) => {\n        let tmp = document.createElement(\"DIV\");\n        tmp.innerHTML = html;\n        return tmp.textContent || tmp.innerText || \"\";\n    }\n\n    const saveData = async (newData) => {\n        try {\n            if (props._id) {\n                socket.emit(\"data\", {\n                    module: \"node\",\n                    method: \"put\",\n                    action: \"update\",\n                    noLog: true\n                }, {\n                    _id: props._id,\n                    ...newData,\n                })\n            }\n            if (props.onEdit)\n                props.onEdit(name, props._id ? props._id : null)\n        } catch (e) {\n            console.log(e)\n        }\n        setEditing(false)\n    }\n\n    return (\n        <div\n            className={classes.header}\n            style={{\n                minHeight: props.style && props.style.minHeight ? props.style.minHeight : \"30px\",\n                ...props.style,\n                ...props.backClick ? { cursor: \"pointer\" } : {}\n            }}\n\n        >\n            <div className={!props.onExpanding || editing ? classes.content : classes.contentWithExpand}>\n                <div className={classes.info}                >\n\n                    {props.private && !reduxStore.getState().controls.lockPrivate && !showPrivateCard ?\n                        <React.Fragment>\n                            <div className={classes.headerIcon} style={{\n                                color: \"lightgray\"\n                            }}>\n                                <Badge\n                                    overlap=\"rectangular\"\n                                    size={`calc(${props.fontSize} + 4px)` || \"22px\"}\n                                    icon={'private_connectivity'}\n                                    color={\"parent\"}\n                                    title={props.iconTitle ? props.iconTitle.substring(0, 1).toUpperCase().concat(props.iconTitle.substring(1)) : \"\"}\n                                />\n                            </div>\n                            <div style={{\n                                marginLeft: \"7px\",\n                                fontSize: 12,\n                                color: \"lightgray\"\n                            }}>\n                                {props.privateTitle ? props.privateTitle : translate(\"$__privateActivity\")}\n                            </div>\n                        </React.Fragment>\n                        :\n                        <React.Fragment>\n                            {props.icon &&\n                                <div className={classes.headerIcon} style={{\n                                    color: props.color ? props.color : customApp(\"colorText\"),\n                                    ...props.backClick ? { cursor: \"pointer\" } : {}\n                                }}>\n                                    <Badge\n                                        overlap=\"rectangular\"\n                                        size={`calc(${props.fontSize} + 4px)` || \"22px\"}\n                                        icon={props.icon}\n                                        color={\"parent\"}\n                                        title={props.iconTitle ? props.iconTitle.substring(0, 1).toUpperCase().concat(props.iconTitle.substring(1)) : \"\"}\n                                    />\n                                </div>\n                            }\n                            {props.searchText ?\n                                <div style={{\n                                    marginLeft: \"7px\",\n                                    ...props.searchTextStyle ? props.searchTextStyle : {}\n                                }}>\n                                    {Highlighted(props.title ? props.title : \"\", props.searchText, props.dark ? true : false)}\n                                </div>\n                                :\n                                <div\n                                    className={classes.headerTitle}\n                                    style={{\n                                        fontSize: props.fontSize ? props.fontSize : \"14px\",\n                                        color: props.color ? props.color : customApp(\"colorText\"),\n                                        marginLeft: props.icon ? \"7px\" : \"none\",\n                                        ...props.textStyle ? props.textStyle : {},\n                                        ...props.backClick ? { cursor: \"pointer\" } : {}\n                                    }}\n                                    onClick={props.backClick ? (e) => {\n                                        // e.preventDefault()\n                                        props.backClick()\n                                        e.stopPropagation()\n                                    } : null}\n                                >\n                                    {editing ?\n                                        <div\n                                            style={{\n                                                position: \"relative\",\n                                                float: \"left\",\n                                                width: \"100%\",\n                                                paddingTop: \"10px\",\n                                                paddingLeft: \"7px\",\n                                                display: \"flex\",\n                                                alignItems: \"center\",\n                                                justifyContent: \"space-between\",\n                                                ...props.inputStyle ? props.inputStyle : {}\n                                            }}\n                                            onClick={(e) => {\n                                                e.stopPropagation()\n                                            }}\n                                        >\n                                            <TextField\n                                                style={{ width: \"calc(100% - 60px)\" }}\n                                                label={props.fieldName ? props.fieldName : translate(\"$__nameOfCard\", 1)}\n                                                variant={customApp(\"fieldVariant\")}\n                                                name={\"name\"}\n                                                InputLabelProps={{\n                                                    shrink: true,\n                                                }}\n                                                InputProps={{\n                                                    autoComplete: \"new-password\",\n                                                    onChange: (d) => {\n                                                        setName(d.target.value)\n                                                    },\n                                                    onKeyDown: (e) => {\n                                                        if (e.keyCode === 13 && name)\n                                                            saveData({\n                                                                name\n                                                            })\n                                                        if (e.keyCode === 27) {\n                                                            setEditing(false);\n                                                            setName(props.value ? props.value : props.title ? props.title.trim() : \"\")\n                                                        }\n                                                    }\n                                                }}\n                                                value={name}\n                                                placeholder={translate(\"$__titleOfCard_placeholder\", 1)}\n                                                autoFocus={props.noAutoFocus ? false : true}\n                                                multiline={props.multiline ? true : false}\n                                            />\n                                            <Badge color={customApp(\"medium\")}\n                                                onClick={() => editing ? setEditing(false) : props.onCancel()}\n                                                icon={\"cancel\"} title={translate(\"$__close\", \"*\")} size={props.actionsSize || \"25px\"}\n                                            />\n                                            <Badge\n                                                overlap=\"rectangular\"\n                                                color={'green'} icon={\"save\"} onClick={() => {\n                                                    if (editing) {\n                                                        saveData({\n                                                            name\n                                                        })\n                                                    } else {\n                                                        props.onSave()\n                                                    }\n                                                }} title={translate(\"$__save\", \" * \")} size={props.actionsSize || \"25px\"} />\n                                        </div>\n                                        :\n                                        <Tooltip\n                                            title={props.title ? props.title : \"\"}\n                                        >\n                                            <div style={{\n                                                ...!props.expanded ? {\n                                                    width: \"100%\",\n                                                    textOverflow: \"ellipsis\",\n                                                    overflow: \"hidden\",\n                                                    whiteSpace: props.viewAllName && props.viewAllName === true ? `` : \"nowrap\",\n                                                }\n                                                    : {\n                                                        width: \"100%\",\n                                                    }\n                                            }}\n                                                onDoubleClick={() => {\n                                                    if (props.onEdit && props.editable) {\n                                                        setName(props.value ? props.value : props.title ? props.title.trim() : \"\");\n                                                        setEditing(true);\n                                                    }\n                                                }\n                                                }\n                                            >\n                                                {`${props.showOrder ? `${props.showOrder}. ` : ``}${props.title && props.title.indexOf(\"$__\") > -1 ? translate(props.title, 1) : props.title ? stripHtml(props.title) : \"\"}`}\n                                            </div>\n                                        </Tooltip>\n                                    }\n                                </div>\n                            }\n                        </React.Fragment>\n                    }\n\n                </div>\n                {props.periodFilter && session && session.period &&\n                    <div style={{ position: \"absolute\", right: 0, textAlign: \"right\", color: \"#FFFFFF\", display: \"flex\", alignItems: \"center\", whiteSpace: \"nowrap\" }}>{translate(session.period)}<PeriodFilter style={{ color: \"#FFFFFF\", height: \"20px\", width: \"20px\" }} /></div>\n                }\n            </div >\n            {\n                (!editing) &&\n                <div style={{\n                    position: \"absolute\",\n                    right: 7,\n                    padding: '3px 0px',\n                    display: \"flex\",\n                    alignItems: \"center\",\n                    borderRadius: 7,\n                    backgroundColor: \"rgba(250,250,250,0.7)\"\n                }}\n                    onClick={(e) => {\n                        e.preventDefault()\n                        e.stopPropagation()\n                    }}\n                >\n                    {!props.moreButton &&\n                        <NotificationCount nodeId={props._id} />\n                    }\n                    {props.moreButton &&\n                        <div style={{\n                            position: \"absolute\",\n                            top: 0,\n                            right: 0,\n                            display: \"flex\",\n                            alignItems: \"center\",\n                        }}\n                            onClick={(e) => {\n                                e.stopPropagation()\n                            }}\n                        >\n                            {props.private && !reduxStore.getState().controls.lockPrivate && !showPrivateCard ?\n                                <React.Fragment>\n                                    <CustomButton\n                                        title={translate(`$__showPrivateActivity`, '*')}\n                                        color={'lightGray'}\n                                        icon={\"lock_open\"}\n                                        onClick={() => {\n                                            setShowPrivateCard(prev => !prev)\n                                            if (props.setPrivate)\n                                                props.setPrivate(!showPrivateCard)\n                                        }}\n                                        size={'21px'}\n                                        style={{ padding: \"0px !important\" }}\n                                    />\n                                </React.Fragment>\n                                :\n                                <React.Fragment>\n                                    {props.colorPicker &&\n                                        <div style={{\n                                            zIndex: 1000\n                                        }}>\n                                            <ColorPicker\n                                                color={props._id && db.cards[props._id] && db.cards[props._id].color ? db.cards[props._id].color : null}\n                                                _id={props._id}\n                                                onChange={(c) => {\n                                                    props.colorPicker(c)\n                                                }}\n                                                style={{\n                                                    zIndex: 5000\n                                                }}\n                                            />\n                                        </div>\n                                    }\n                                    {props.options && props.options.length > 0 && props.options.filter(a => {\n                                        if (a\n                                            && a.name\n                                            &&\n                                            (\n                                                a.name === \"$__removeSelection\"\n                                                || a.name === \"$__selectThis\"\n                                            )\n                                        )\n                                            return true\n                                    }).length > 0\n                                        &&\n                                        <Tooltip\n                                            title={translate(props.options.filter(a => {\n                                                if (a && a.name && (a.name === \"$__removeSelection\" || a.name === \"$__selectThis\")) return true\n                                            })[0].name)}\n                                        >\n                                            <IconButton\n                                                onClick={(e) => {\n                                                    props.options.filter(a => {\n                                                        if (a && a.name && (a.name === \"$__removeSelection\" || a.name === \"$__selectThis\")) return true\n                                                    })[0].onClick()\n                                                }}\n                                                className={classes.iconButtonStyle}\n                                            >\n                                                <Icon\n                                                    size={\"22px\"}\n                                                    color={customApp(\"menu\")}\n                                                    icon={props.options.filter(a => {\n                                                        if (a && a.name && (a.name === \"$__removeSelection\" || a.name === \"$__selectThis\")) return true\n                                                    })[0].icon}\n                                                    usePropagation\n                                                />\n                                            </IconButton>\n                                        </Tooltip>\n                                    }\n                                    {props.options && props.options.filter(a => a && a.show && a.show === 'fixed').length > 0 ?\n                                        props.options.filter(a => a && a.show && a.show === 'fixed').map((b, i) => {\n                                            return (<Tooltip\n                                                key={`opt${i}`}\n                                                title={translate(b.name)}\n                                            >\n                                                <IconButton\n                                                    onClick={() => b.onClick()}\n                                                    className={classes.iconButtonStyle}\n                                                >\n                                                    <Icon\n                                                        size={\"22px\"}\n                                                        color={b.color || customApp(\"menu\")}\n                                                        icon={b.icon}\n                                                        usePropagation\n                                                    />\n                                                </IconButton>\n                                            </Tooltip>\n                                            )\n                                        }\n                                        ) : <React.Fragment></React.Fragment>}\n                                    {!props.noExpanding && props.onExpanding &&\n                                        <Tooltip\n                                            title={translate(!props.isExpanded ? `$__expand` : `$__collapse`)}\n                                        >\n                                            <IconButton\n                                                onClick={(e) => {\n                                                    props.onExpanding()\n                                                }}\n                                                className={classes.iconButtonStyle}\n                                            >\n                                                <Icon\n                                                    size={\"22px\"}\n                                                    color={customApp(\"menu\")}\n                                                    icon={!props.isExpanded ? \"expand_more\" : \"expand_less\"}\n                                                    usePropagation\n                                                />\n                                            </IconButton>\n                                        </Tooltip>\n                                    }\n                                    {props.options && props.options.length > 0 &&\n                                        <MoreMenu\n                                            noButton={true}\n                                            options={[\n                                                ...props.options,\n                                                ...props.private && showPrivateCard ? [{\n                                                    color: \"lightblue\",\n                                                    icon: \"lock\",\n                                                    name: \"$__lockThisPrivateCard\",\n                                                    onClick: () => {\n                                                        setShowPrivateCard(prev => !prev)\n                                                        if (props.setPrivate)\n                                                            props.setPrivate(!showPrivateCard)\n                                                    },\n                                                    show: \"hover\",\n                                                }] : []\n                                            ]}\n                                            {...props.optionsProps ? props.optionsProps : {}}\n                                        />\n                                    }\n\n                                </React.Fragment>\n                            }\n\n                        </div>\n                    }\n                </div>\n            }\n\n        </div >\n    );\n}\n\nexport default Component;\n","import React from \"react\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\n\n//@MATERIAL\nimport Tooltip from \"@material-ui/core/Tooltip\";\nimport IconButton from '@material-ui/core/IconButton';\nimport { makeStyles } from '@material-ui/core/styles';\n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\n\nconst useStyles = makeStyles((theme) => ({\n    iconButtonStyle: {\n        margin: 0,\n        backgroundColor: '#FFFFFF',\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        }\n    },\n}));\n\n\nexport default function CustomButton(props) {\n    const classes = useStyles();\n    return (\n        <Tooltip\n            title={props.title ? props.title : ''}\n        >\n            <IconButton\n                onClick={props.onClick ? (e) => {\n                    props.onClick()\n                } : null}\n                className={classes.iconButtonStyle}\n                style={props.style || {}}\n            >\n                <Icon\n                    usePropagation\n                    size={props.size ? props.size : \"20px\"}\n                    color={props.color ? props.color : customApp('menu')}\n                    icon={props.icon ? props.icon : 'circle'} />\n            </IconButton>\n        </Tooltip>\n    )\n}","import { customApp } from \"functions/\";\r\n\r\n// export default {\r\n//     control: {\r\n//         fontSize: 14,\r\n//         fontWeight: 'normal',\r\n//         border: 'none',\r\n//     },\r\n//     '&input::placeholder': {\r\n//         color: 'rgba(0,0,0,0.2)',\r\n//         fontSize: '11px'\r\n//     },\r\n\r\n//     '&multiLine': {\r\n//         control: {\r\n//             border: 'none',\r\n//             '&::placeholder': {\r\n//                 color: 'rgba(0,0,0,0.3)'\r\n//             },\r\n//             backgroundColor: 'transparent',\r\n//         },\r\n//         highlighter: {\r\n//             backgroundColor: 'transparent'\r\n//         },\r\n//         input: {\r\n//             backgroundColor: 'transparent',\r\n//             borderColor: 'transparent',\r\n//             // padding: '0px ​100px 0px 0px',\r\n//             marginBottom: '7px',\r\n//             '&::placeholder': {\r\n//                 color: 'rgba(0,0,0,0.2)'\r\n//             },\r\n//         },\r\n//     },\r\n//     '&singleLine': {\r\n//         display: 'inline-block',\r\n//         width: '100%',\r\n//         highlighter: {\r\n//             padding: 1,\r\n//             border: '2px inset transparent',\r\n//         },\r\n//         input: {\r\n//             padding: 1,\r\n//             border: '2px inset',\r\n//         },\r\n//     },\r\n//     suggestions: {\r\n//         position: 'absolute',\r\n//         list: {\r\n//             backgroundColor: 'white',\r\n//             border: '1px solid rgba(0,0,0,0.15)',\r\n//             borderRadius: '7px 7px',\r\n//             boxShadow: '0 0 3px 5px rgba(0,0,0,0.05)',\r\n//             fontSize: 14,\r\n//             zIndex: 200,\r\n//             maxHeight: '151px !important',\r\n//             overflow: 'auto !important'\r\n//         },\r\n//         item: {\r\n//             padding: '5px 15px',\r\n//             borderBottom: '1px solid rgba(0,0,0,0.15)',\r\n//             '&focused': {\r\n//                 backgroundColor: customApp('color'),\r\n//             },\r\n//         },\r\n//         zIndex: 500,\r\n//         bottom: '100%',\r\n//         top: 'none',\r\n//         left: '33px',\r\n//         height: 'auto',\r\n//         maxHeight: '151px !important',\r\n//         overflow: 'auto !important'\r\n//     }\r\n// }\r\nexport default {\r\n    control: {\r\n        backgroundColor: '#fff',\r\n        fontSize: 14,\r\n        fontFamily: \"Roboto\",\r\n        fontWeight: 'normal',\r\n        lineHeight: '17px',\r\n    },\r\n\r\n    '&multiLine': {\r\n        control: {\r\n            fontFamily: 'Roboto',\r\n            // minHeight: 63,\r\n        },\r\n        highlighter: {\r\n            padding: 9,\r\n            border: '1px solid transparent',\r\n            boxSizing: 'border-box',\r\n            overflow: 'hidden',\r\n            maxHeight: 150,\r\n        },\r\n        input: {\r\n            padding: 9,\r\n            border: '1px solid silver',\r\n            overflow: 'auto',\r\n            maxHeight: 150,\r\n            borderColor: 'transparent',\r\n        },\r\n    },\r\n\r\n    '&singleLine': {\r\n        display: 'inline-block',\r\n        width: 180,\r\n        lineHeight: '17px',\r\n        highlighter: {\r\n            lineHeight: '17px',\r\n            padding: 1,\r\n            border: '2px inset transparent',\r\n        },\r\n        input: {\r\n            border: 'none',\r\n            lineHeight: '17px',\r\n            padding: 1,\r\n            border: '2px inset',\r\n        },\r\n    },\r\n\r\n    suggestions: {\r\n        position: 'absolute',\r\n        list: {\r\n            backgroundColor: 'white',\r\n            border: '1px solid rgba(0,0,0,0.15)',\r\n            borderRadius: '7px 7px',\r\n            boxShadow: '0 0 3px 5px rgba(0,0,0,0.05)',\r\n            fontSize: 14,\r\n            zIndex: 200,\r\n            maxHeight: '151px !important',\r\n            overflow: 'auto !important'\r\n        },\r\n        item: {\r\n            padding: '5px 15px',\r\n            borderBottom: '1px solid rgba(0,0,0,0.15)',\r\n            '&focused': {\r\n                backgroundColor: customApp('color'),\r\n            },\r\n        },\r\n        zIndex: 500,\r\n        bottom: '100%',\r\n        top: 'none',\r\n        left: '33px',\r\n        height: 'auto',\r\n        maxHeight: '151px !important',\r\n        overflow: 'auto !important'\r\n    },\r\n}","import {\r\n  infoColor,\r\n  primaryColor,\r\n  successColor,\r\n  dangerColor,\r\n  warningColor,\r\n  whiteColor,\r\n  blackColor,\r\n  grayColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport {\r\n  defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport { customApp } from \"functions/\";;\r\nconst timelineStyle = theme => ({\r\n  root: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n  },\r\n  rootRelative: {\r\n    position: 'relative',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n  },\r\n  content: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    overflowY: 'auto',\r\n    backgroundColor: 'rgba(249,249,249,1)'\r\n  },\r\n  timeline: {\r\n    listStyle: \"none\",\r\n    padding: \"0\",\r\n    position: \"absolute\",\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    display: 'flex',\r\n    width: '100%',\r\n    '& .file-drop-target': {\r\n      width: '100%',\r\n      display: 'flex',\r\n      position: 'absolute',\r\n      bottom: '0px',\r\n      left: '0px',\r\n      right: '0px',\r\n      height: 'auto'\r\n    }\r\n  },\r\n  scrollEnd: {\r\n    marginTop: '160px',\r\n    position: 'relative',\r\n    width: '100%',\r\n    height: '0px',\r\n    marginBottom: '-100px'\r\n  },\r\n  timelineSimple: {\r\n    position: 'relative',\r\n    // overflowX: 'auto',\r\n    overflow: \"hidden\",\r\n    marginTop: \"0px\",\r\n    padding: \"0 0 20px\",\r\n    width: '-webkit-fill-available',\r\n    \"&:before\": {\r\n      left: \"15px\"\r\n    },\r\n  },\r\n  item: {\r\n    marginBottom: \"5px\",\r\n    position: \"relative\",\r\n    width: 'calc(100% - 15px)',\r\n    \"&:before,&:after\": {\r\n      content: '\" \"',\r\n      display: \"table\"\r\n    },\r\n    \"&:after\": {\r\n      clear: \"both\"\r\n    }\r\n  },\r\n  timelineBadge: {\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      left: \"30px !important\"\r\n    },\r\n    color: whiteColor,\r\n    width: \"30px\",\r\n    height: \"30px\",\r\n    lineHeight: \"25px\",\r\n    fontSize: \"12px\",\r\n    textAlign: \"center\",\r\n    position: \"absolute\",\r\n    bottom: \"23px\",\r\n    left: \"50%\",\r\n    marginLeft: \"-24px\",\r\n    zIndex: \"1\",\r\n    borderTopRightRadius: \"50%\",\r\n    borderTopLeftRadius: \"50%\",\r\n    borderBottomRightRadius: \"50%\",\r\n    borderBottomLeftRadius: \"50%\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\"\r\n\r\n  },\r\n  timelineSimpleBadge: {\r\n    left: \"30px\"\r\n  },\r\n  custom: {\r\n    backgroundColor: customApp('color'),\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.4)\"\r\n  },\r\n  info: {\r\n    backgroundColor: infoColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(infoColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  success: {\r\n    backgroundColor: successColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(successColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  danger: {\r\n    backgroundColor: dangerColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(dangerColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  warning: {\r\n    backgroundColor: warningColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(warningColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  primary: {\r\n    backgroundColor: primaryColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(primaryColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  badgeIcon: {\r\n    width: \"14px\",\r\n    height: \"14px\"\r\n  },\r\n  timelinePanel: {\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      float: \"right !important\",\r\n      width: \"calc(100% - 60px) !important\",\r\n      \"&:before\": {\r\n        borderLeftWidth: \"0 !important\",\r\n        borderRightWidth: \"15px !important\",\r\n        left: \"-20px !important\",\r\n        right: \"auto !important\"\r\n      },\r\n      \"&:after\": {\r\n        borderLeftWidth: \"0 !important\",\r\n        borderRightWidth: \"14px !important\",\r\n        left: \"-19px !important\",\r\n        right: \"auto !important\"\r\n      }\r\n    },\r\n    width: \"45%\",\r\n    float: \"left\",\r\n    padding: \"7px\",\r\n    marginBottom: \"5px\",\r\n    position: \"relative\",\r\n    boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n    borderRadius: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n    background: whiteColor,\r\n    \"&:before\": {\r\n      position: \"absolute\",\r\n      bottom: \"16px\",\r\n      right: \"-15px\",\r\n      display: \"inline-block\",\r\n      borderTop: \"15px solid transparent\",\r\n      borderLeft: \"15px solid \" + grayColor[10],\r\n      borderRight: \"0 solid \" + grayColor[10],\r\n      borderBottom: \"15px solid transparent\",\r\n      content: '\" \"'\r\n    },\r\n    \"&:after\": {\r\n      position: \"absolute\",\r\n      bottom: \"16px\",\r\n      right: \"-14px\",\r\n      display: \"inline-block\",\r\n      borderTop: \"14px solid transparent\",\r\n      borderLeft: \"14px solid \" + whiteColor,\r\n      borderRight: \"0 solid \" + whiteColor,\r\n      borderBottom: \"14px solid transparent\",\r\n      content: '\" \"'\r\n    }\r\n  },\r\n  timelineSimplePanel: {\r\n    width: \"calc(100% - 60px)\"\r\n  },\r\n  timelinePanelInverted: {\r\n    [theme.breakpoints.up(\"sm\")]: {\r\n      float: \"right\",\r\n      backgroundColor: whiteColor,\r\n      \"&:before\": {\r\n        borderLeftWidth: \"0\",\r\n        borderRightWidth: \"15px\",\r\n        left: \"-15px\",\r\n        right: \"auto\"\r\n      },\r\n      \"&:after\": {\r\n        borderLeftWidth: \"0\",\r\n        borderRightWidth: \"14px\",\r\n        left: \"-14px\",\r\n        right: \"auto\"\r\n      }\r\n    }\r\n  },\r\n  timelineHeading: {\r\n    marginBottom: \"0px\"\r\n  },\r\n  timelineBody: {\r\n    fontSize: \"12px\",\r\n    lineHeight: \"21px\"\r\n  },\r\n  timelineFooter: {\r\n    zIndex: \"1\",\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    width: '100%',\r\n    display: \"inline-flex\",\r\n    justifyContent: \"space-between\"\r\n  },\r\n  footerUser: {\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    fontSize: '12px',\r\n    fontWeight: 'bold',\r\n    color: customApp('medium')\r\n  },\r\n  footerLine: {\r\n    position: 'relative',\r\n    marginTop: \"10px\",\r\n    marginBottom: \"5px\"\r\n  },\r\n  dropFile: {\r\n    display: 'none',\r\n  },\r\n  onDropFile: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    zIndex: '5',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    justifyContent: 'center',\r\n    color: '#FFFFFF',\r\n    backgroundColor: 'rgba(0,0,0,0.77)',\r\n    zIndex: 11,\r\n  },\r\n  editor: {\r\n    position: 'absolute',\r\n    bottom: '0px',\r\n    // minHeight: '50px',\r\n    height: 'auto',\r\n    width: 'calc(100% - 0px)',\r\n    zIndex: 10,\r\n  },\r\n  editorRelative: {\r\n    position: 'relative',\r\n    bottom: '0px',\r\n    minHeight: '50px',\r\n    height: 'auto',\r\n    width: 'calc(100% - 0px)',\r\n    zIndex: 10,\r\n  },\r\n  files: {\r\n    display: 'inline-table',\r\n    position: 'absolute',\r\n    // backgroundColor: 'rgba(250,250,250,0.95)',\r\n    width: '100%',\r\n    bottom: 0,\r\n  },\r\n  textEditor: {\r\n    zIndex: 100\r\n  },\r\n  textEditorIcon: {\r\n    cursor: 'pointer',\r\n    color: customApp('color'),\r\n  },\r\n  progressBar: {\r\n    backgroundColor: `${customApp('color', '0.1')} !important`,\r\n    '& .MuiLinearProgress-indeterminate': {\r\n      backgroundColor: `${customApp('color')} !important`\r\n    },\r\n    '& .MuiLinearProgress-bar': {\r\n      backgroundColor: `${customApp('color')} !important`\r\n    },\r\n  },\r\n  actionButton: {\r\n    alignItems: 'center',\r\n    cursor: 'pointer',\r\n    float: 'left',\r\n    height: '20px',\r\n    position: 'relative',\r\n    textAlign: 'center',\r\n    width: '30px',\r\n  },\r\n  sendingMessage: {\r\n    width: '100%'\r\n  },\r\n  valuePositive: {\r\n    positive: 'relative',\r\n    float: 'left',\r\n    color: 'blue',\r\n  },\r\n  valueNegative: {\r\n    positive: 'relative',\r\n    float: 'left',\r\n    color: 'red',\r\n  },\r\n  lastValue: {\r\n    positive: 'relative',\r\n    float: 'right',\r\n    color: 'grey',\r\n  },\r\n  timeInfo: {\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    color: 'grey',\r\n    width: '100%',\r\n    position: 'relative',\r\n    float: 'left',\r\n    marginBottom: '7px',\r\n    '& .text': {\r\n      marginLeft: '7px',\r\n    }\r\n  },\r\n  urlPreview: {\r\n    position: 'absolute',\r\n    width: '100%',\r\n    top: '-90px',\r\n    maxHeight: '120px',\r\n    background: 'linear-gradient(60deg, rgba(250,250,250,1), rgba(250,250,250,0.9))',\r\n    padding: '7px',\r\n    display: 'flex',\r\n    overflow: 'auto',\r\n    alignItems: 'center',\r\n    '& img': {\r\n      maxWidth: '20%',\r\n      height: 'auto',\r\n      position: 'relative',\r\n      float: 'left',\r\n      marginTop: '0px',\r\n      marginRight: '7px'\r\n    },\r\n    '& .data': {\r\n      position: 'relative',\r\n      float: 'left',\r\n      width: '75%',\r\n      '& .title': {\r\n        fontSize: '16px',\r\n        fontWeight: 'bold',\r\n      },\r\n      '& .siteName': {\r\n        fontSize: '14px',\r\n        fontWeight: 'bold',\r\n        color: '#909090'\r\n      },\r\n      '& .contentSnippet': {\r\n        fontSize: '12px',\r\n        color: '#909090'\r\n      }\r\n    }\r\n  },\r\n  mentionInput: {\r\n    ...defaultFont,\r\n    '& textarea': {\r\n      ...defaultFont,\r\n      padding: '7px',\r\n      borderRadius: '7px',\r\n      fontSize: '16px',\r\n      width: 'calc(100% - 14px)',\r\n      minHeight: '38px',\r\n      border: 'solid 1px rgba(0,0,0,0.1)'\r\n    },\r\n    '& .sugestions': {\r\n      top: 'none !important',\r\n      bottom: '40px',\r\n      border: 'solid 10px red'\r\n    },\r\n    '& textarea::placeholder': {\r\n      color: 'rgba(0,0,0,0.2)',\r\n    }\r\n  },\r\n  mentionWrapper: {\r\n    width: '100%',\r\n    background: 'transparent',\r\n    fontSize: '0.9rem',\r\n    color: ' #a9b5c4',\r\n    '&&.mentionWrapper__control': {\r\n      borderRadius: '25px',\r\n      border: '1px solid #3a546f',\r\n      minHeight: '45px',\r\n      '&& .mentionWrapper__highlighter': {\r\n        padding: '0.7rem 1rem',\r\n      },\r\n      '&& .mentionWrapper__input': {\r\n        padding: '0.7rem 1rem',\r\n        outline: 0,\r\n        border: 0,\r\n        resize: 'none',\r\n        outline: 'none',\r\n        fontSize: '0.9rem',\r\n        color: '#7288a3',\r\n        borderColor: ' #3a546f',\r\n        overflow: 'hidden',\r\n        '&& :: placeholder': {\r\n          color: '#7288a3',\r\n        }\r\n      }\r\n    },\r\n  },\r\n})\r\n\r\nexport default timelineStyle;\r\n","//REDUX\r\nimport reduxStore from \"store/\";\r\n\r\n//FUNCTIONS\r\nimport api from \"api/\";\r\nimport apims from \"apims\";\r\nimport { upload } from \"functions/upload.js\";\r\nimport { cardAccessUpdate } from \"functions/cards\";\r\n\r\n\r\nconst save = async (props) => {\r\n    let socket\r\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\r\n        socket = reduxStore.getState().functions.socket\r\n    } else {\r\n        socket = reduxStore.getState().functions.socket\r\n    }\r\n    const { sideModule } = reduxStore.getState();\r\n    const newData = sideModule.data\r\n    const oldData = reduxStore.getState().db[sideModule.db][sideModule.id] || {}\r\n    let diff = false\r\n    let uploadReq = false\r\n\r\n    console.log(newData)\r\n\r\n\r\n    //HASHS\r\n    let hashs = window.location.hash.split('/')\r\n    hashs[0] = hashs[0].replace('#', '')\r\n\r\n    if (JSON.stringify(oldData) !== JSON.stringify(newData))\r\n        diff = true\r\n\r\n    if (newData.type === 'user')\r\n        if (hashs && hashs.length > 2 && hashs[2] && hashs[2].length === 36) {\r\n            newData.type = 'user'\r\n            newData._parent = hashs[2]\r\n        }\r\n\r\n    Object.keys(newData).map(f => {\r\n        if (f === 'file') {\r\n            uploadReq = true\r\n            diff = true\r\n        }\r\n\r\n        if ((oldData && oldData[f] && newData[f] !== oldData[f]) || (!oldData && newData)) {\r\n            diff = true\r\n        }\r\n        if ((newData[f] && newData[f].low) || (newData[f] && newData[f].low && String(newData[f].low) === '0'))\r\n            newData[f] = newData[f].low\r\n    })\r\n    let file = newData.file || null\r\n    delete newData.file\r\n\r\n\r\n    if (newData._id === 'new' || !newData._id) {\r\n        try {\r\n            socket.emit(\"data\", {\r\n                module: \"user\",\r\n                method: \"post\",\r\n                action: \"add\"\r\n            }, {\r\n                ...newData,\r\n                oldData: oldData,\r\n            }, async (response) => {\r\n                newData._id = response.id\r\n                newData._token = {\r\n                    _id: response.tokenId\r\n                }\r\n                let imageResult = file ? await upload(newData._id, file) : newData.image\r\n                newData.image = imageResult\r\n                socket.emit(\"data\", {\r\n                    module: \"user\",\r\n                    method: \"put\",\r\n                    action: \"update\"\r\n                }, {\r\n                    ...newData,\r\n                    image: imageResult,\r\n                    oldData: oldData\r\n                })\r\n\r\n                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\r\n                    ...reduxStore.getState().sideModule,\r\n                    id: response.id,\r\n                    data: {\r\n                        ...reduxStore.getState().sideModule.data,\r\n                        _id: response.id,\r\n                    }\r\n                });\r\n                // dbUpdateUser(props, {\r\n                //     _id: response.id,\r\n                //     data: {\r\n                //         [response.id]: {\r\n                //             ...newData,\r\n                //             image: imageResult,\r\n                //         }\r\n                //     }\r\n                // })\r\n            })\r\n            return true\r\n        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    } else {\r\n        let imageResult = file ? await upload(newData._id, file) : newData.image\r\n        if (\r\n            (file && imageResult)\r\n            || !file\r\n        )\r\n            socket.emit(\"data\", {\r\n                module: \"user\",\r\n                method: \"put\",\r\n                action: \"update\"\r\n            }, {\r\n                ...newData,\r\n                image: imageResult,\r\n                oldData: oldData\r\n            }, async (response) => {\r\n\r\n            })\r\n        return true\r\n    }\r\n}\r\n\r\nconst saveAccess = async (props) => {\r\n    let socket\r\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\r\n        socket = reduxStore.getState().functions.socket\r\n    } else {\r\n        socket = reduxStore.getState().functions.socket\r\n    }\r\n    const { sideModule } = reduxStore.getState()\r\n    const { data } = sideModule\r\n\r\n    socket.emit(\"data\", {\r\n        module: \"user\",\r\n        method: \"post\",\r\n        action: \"access\"\r\n    }, {\r\n        _id: data._id,\r\n        email: data.email,\r\n        name: data.name,\r\n        access: data._access,\r\n        safety: data._safety\r\n    }, async (response) => {\r\n        socket.emit('user.ACCESS', {\r\n            _id: data._id,\r\n            [data._id]: {\r\n                ...data,\r\n            },\r\n        })\r\n    })\r\n    return true\r\n}\r\nconst dbUpdateUser = (props, data) => {\r\n    let user = {\r\n        ...data[data._id] ? data[data._id] : {}\r\n    }\r\n    if (reduxStore.getState().db.users[data._id])\r\n        user = {\r\n            ...reduxStore.getState().db.users[data._id],\r\n            ...user\r\n        }\r\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n        ...reduxStore.getState().db,\r\n        users: {\r\n            ...reduxStore.getState().db.users,\r\n            [data._id]: {\r\n                ...user,\r\n            },\r\n        }\r\n    });\r\n}\r\n\r\nasync function emailExist(email) {\r\n    const { users } = reduxStore.getState().db\r\n    if (Object.keys(users).filter(a => users[a].email === email).length === 1) {\r\n        return true\r\n    } else {\r\n        try {\r\n            await apims.get(`/M_User_Verify_MailExist/?email=${email}`)\r\n            return false\r\n        } catch (e) {\r\n            return true\r\n        }\r\n    }\r\n    return false\r\n}\r\n\r\nasync function emailExistDB(email) {\r\n    try {\r\n        const verify = await apims.get(`/M_User_Verify_MailExist/?email=${email}`)\r\n        if (verify)\r\n            return false\r\n    } catch (e) {\r\n        return true\r\n    }\r\n}\r\n\r\nasync function validateEmailToken(token, email) {\r\n    try {\r\n        const verify = await api.post(`user/email-token-validate`, {\r\n            token: token,\r\n            email: email\r\n        })\r\n        if (verify)\r\n            return true\r\n    } catch (e) {\r\n        return false\r\n    }\r\n}\r\nasync function emailTokenGenerate(name, email) {\r\n    try {\r\n        const verify = await api.post(`user/email-token-generate`, {\r\n            name: name,\r\n            email: email\r\n        })\r\n        if (verify)\r\n            return true\r\n    } catch (e) {\r\n        return false\r\n    }\r\n}\r\n\r\nconst cardsAccess = (props, userId, access, nodeId, userData) => {\r\n\r\n    let user = reduxStore.getState().db.users[userId] ? reduxStore.getState().db.users[userId] : userData\r\n\r\n    let socket\r\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\r\n        socket = reduxStore.getState().functions.socket\r\n    } else {\r\n        socket = reduxStore.getState().functions.socket\r\n    }\r\n    const { db } = reduxStore.getState()\r\n\r\n    cardAccessUpdate(props, {\r\n        cardId: nodeId,\r\n        userId: userId,\r\n        access: access,\r\n        userData: {\r\n            _id: userId,\r\n            name: user.name,\r\n            image: user.image ? user.image : null,\r\n        }\r\n    })\r\n    socket.emit(\"data\", {\r\n        module: \"cards\",\r\n        method: \"post\",\r\n        action: \"access\"\r\n    }, {\r\n        cardType: db.cards[nodeId].type,\r\n        cardId: nodeId,\r\n        parentUser: db.cards[nodeId]._parent,\r\n        userId: userId,\r\n        access: access,\r\n        userData: {\r\n            _id: userId,\r\n            name: user.name,\r\n            image: user.image ? user.image : null,\r\n        }\r\n    }, async (response) => {\r\n        // console.log(response)\r\n    })\r\n    return true\r\n}\r\n\r\nconst groupAccess = async (props, groupId, cardId) => {\r\n    api.post(\"/card/groupAccess\", {\r\n        groupId,\r\n        cardId\r\n    })\r\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n        ...reduxStore.getState().db,\r\n        cards: {\r\n            ...reduxStore.getState().db.cards,\r\n            [cardId]: {\r\n                ...reduxStore.getState().db.cards[cardId],\r\n                _groups: {\r\n                    ...reduxStore.getState().db.cards[cardId]._groups || {},\r\n                    [groupId]: {\r\n                        _id: groupId\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    })\r\n\r\n}\r\n\r\nconst groupAccessRemove = async (props, groupId, cardId) => {\r\n    api.post(\"/card/groupAccessRemove\", {\r\n        groupId,\r\n        cardId\r\n    })\r\n    let groups = reduxStore.getState().db.cards[cardId]._groups\r\n    delete groups[groupId]\r\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n        ...reduxStore.getState().db,\r\n        cards: {\r\n            ...reduxStore.getState().db.cards,\r\n            [cardId]: {\r\n                ...reduxStore.getState().db.cards[cardId],\r\n                _groups: groups\r\n            }\r\n        }\r\n    })\r\n}\r\n\r\nconst transferResponse = async (props, data) => {\r\n\r\n}\r\n\r\nconst isResponsible = async (props, data) => {\r\n    let socket\r\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\r\n        socket = reduxStore.getState().functions.socket\r\n    } else {\r\n        socket = reduxStore.getState().functions.socket\r\n    }\r\n    // const { socket } = reduxStore.getState().functions\r\n    const { db } = reduxStore.getState()\r\n\r\n    // console.log(data)\r\n\r\n    socket.emit(\"data\", {\r\n        module: \"cards\",\r\n        method: \"post\",\r\n        action: \"userResponsible\"\r\n    }, {\r\n        ...data\r\n    }, async (response) => {\r\n\r\n    })\r\n    return true\r\n}\r\n\r\nexport const userParam = async (props, data) => {\r\n    let socket\r\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\r\n        socket = reduxStore.getState().functions.socket\r\n    } else {\r\n        socket = reduxStore.getState().functions.socket\r\n    }\r\n    // const { socket } = reduxStore.getState().functions\r\n    const { db } = reduxStore.getState()\r\n\r\n    // console.log(data)\r\n\r\n    socket.emit(\"data\", {\r\n        module: \"cards\",\r\n        method: \"post\",\r\n        action: \"userParam\"\r\n    }, {\r\n        ...data\r\n    }, async (response) => {\r\n\r\n    })\r\n    return true\r\n}\r\n\r\nasync function calcCards(user) {\r\n    try {\r\n        let req = await apims.post(`/M_User_CountCards`, { id: user })\r\n        return false\r\n    } catch (e) {\r\n        return true\r\n    }\r\n}\r\n\r\nconst getAdminList = (options = {}, type) => {\r\n    const { db } = reduxStore.getState()\r\n\r\n    let userList = {\r\n    }\r\n\r\n    Object.keys(db.users).filter(idu => !db.users[idu]._parent && db.users[idu]._access && db.users[idu]._access.admin).map(idu => {\r\n        userList = {\r\n            ...userList,\r\n            [idu]: db.users[idu]\r\n        }\r\n    })\r\n\r\n    // console.log(userList)\r\n\r\n    if ((!options || (options && !options.isArray)) && userList) {\r\n        let result = {}\r\n        Object.keys(userList).map(a => {\r\n            if (!type || (type && type.indexOf(userList[a].type) > -1))\r\n                result = {\r\n                    ...result,\r\n                    [a]: userList[a]\r\n                }\r\n        })\r\n        return result\r\n    } else if (options && options.isArray && userList) {\r\n        let result = []\r\n        Object.keys(userList).map(a => {\r\n            if (!type || (type && type.indexOf(userList[a].type) > -1))\r\n                if (result.filter(us => us._id === a).length === 0)\r\n                    result.push(userList[a])\r\n        })\r\n        return result\r\n    } else {\r\n        return {}\r\n    }\r\n}\r\n\r\nexport {\r\n    calcCards,\r\n    groupAccess,\r\n    groupAccessRemove,\r\n    cardsAccess,\r\n    dbUpdateUser,\r\n    emailExist,\r\n    emailExistDB,\r\n    emailTokenGenerate,\r\n    getAdminList,\r\n    isResponsible,\r\n    save,\r\n    saveAccess,\r\n    transferResponse,\r\n    validateEmailToken,\r\n}","import moment from \"moment-timezone\";\r\nimport { v4 as uuid } from \"uuid\";\r\nimport MD5 from \"crypto-js/md5\";\r\n\r\n//REDUX\r\nimport reduxStore from \"store/\";\r\n\r\nimport apims from \"apims/\";\r\nimport api from \"api/\"\r\n\r\nimport { loadCardsV2 } from \"./loadData\"\r\n\r\nrequire('dotenv').config()\r\n\r\nconst clearReadeds = async (props, d) => {\r\n    const { session, timeline, chat } = reduxStore.getState()\r\n\r\n    let messages = timeline[d.nodeId]\r\n    let nodeId = d.nodeId\r\n    let toDelete = []\r\n\r\n    if (d.chat) {\r\n        nodeId = chat.nodeId\r\n    }\r\n\r\n    if (reduxStore.getState().db.cards[nodeId] && reduxStore.getState().db.cards[nodeId].type !== 'chatGroup' && messages && Object.keys(messages).length > 0) {\r\n        Object.keys(messages)\r\n            .filter(msg =>\r\n                messages[msg]\r\n                && messages[msg].type\r\n                && messages[msg].type === d.type\r\n                && messages[msg].readedBy\r\n                && messages[msg].readedBy[session._id]\r\n            )\r\n            .sort((a, b) => {\r\n                if (parseInt(messages[a].created_at) > parseInt(messages[b].created_at))\r\n                    return -1\r\n                if (parseInt(messages[a].created_at) < parseInt(messages[b].created_at))\r\n                    return 1\r\n                return 0\r\n            })\r\n            .map(msg => {\r\n                if (toDelete.indexOf(msg) === -1)\r\n                    toDelete.push(msg)\r\n            })\r\n    } else if (reduxStore.getState().db.cards[nodeId] && reduxStore.getState().db.cards[nodeId].type === 'chatGroup') {\r\n        Object.keys(messages)\r\n            .filter(msg =>\r\n                messages[msg]\r\n                && messages[msg].readedBy\r\n                && messages[msg].readedBy[session._id]\r\n            )\r\n            .sort((a, b) => {\r\n                if (parseInt(messages[a].created_at) > parseInt(messages[b].created_at))\r\n                    return -1\r\n                if (parseInt(messages[a].created_at) < parseInt(messages[b].created_at))\r\n                    return 1\r\n                return 0\r\n            })\r\n            .map((msg, msgi) => {\r\n                if (msgi > 14 && toDelete.indexOf(msg) === -1)\r\n                    toDelete.push(msg)\r\n            })\r\n    } else if (reduxStore.getState().db.users[nodeId]) {\r\n        // console.log('60')\r\n        // let stories = timeline[nodeId] ? Object.keys(timeline[nodeId]).map(a => timeline[nodeId][a]) : []\r\n        // if (timeline[session._id]) {\r\n        //     Object.keys(timeline[session._id])\r\n        //         .filter(a =>\r\n        //             timeline[session._id]\r\n        //             && timeline[session._id][a]\r\n        //             && timeline[session._id][a].user\r\n        //             && timeline[session._id][a].user._id === nodeId\r\n        //             && stories.filter(s => s._id === a).length === 0\r\n        //         )\r\n        //         .map(a => {\r\n        //             stories.push(timeline[session._id][a])\r\n        //         })\r\n\r\n        //     stories = Object.keys(stories)\r\n        //         .sort((a, b) => {\r\n        //             if (parseInt(stories[a].created_at) < parseInt(stories[b].created_at)) {\r\n        //                 return -1\r\n        //             } else if (parseInt(stories[a].created_at) > parseInt(stories[b].created_at)) {\r\n        //                 return 1\r\n        //             } else {\r\n        //                 return 0\r\n        //             }\r\n        //         })\r\n        //         .filter(a =>\r\n        //             stories[a].user\r\n        //             && stories[a].user._id\r\n        //             && (\r\n        //                 stories[a].user._id === session._id\r\n        //                 ||\r\n        //                 stories[a].user._id === nodeId\r\n        //             )\r\n        //         ).map(a => {\r\n        //             return stories[a]\r\n        //         })\r\n        // }\r\n        // stories.sort((a, b) => {\r\n        //     if (parseInt(a.created_at) > parseInt(b.created_at))\r\n        //         return -1\r\n        //     if (parseInt(a.created_at) < parseInt(b.created_at))\r\n        //         return 1\r\n        //     return 0\r\n        // })\r\n        //     .map((msg, i) => {\r\n        //         if (i > 14 && toDelete.indexOf(msg._id) === -1)\r\n        //             toDelete.push(msg._id)\r\n        //     })\r\n    }\r\n    let newMessages = { ...reduxStore.getState().timeline }\r\n    toDelete.map(msg => {\r\n        Object.keys(newMessages).map(tm => {\r\n            if (newMessages[tm][msg])\r\n                delete newMessages[tm][msg]\r\n        })\r\n    })\r\n    props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", {\r\n        ...newMessages\r\n    });\r\n}\r\n\r\nconst chatReaded = async (props, data) => {\r\n    // console.log(data)\r\n    let newTimeline = {}\r\n    const { db, session } = reduxStore.getState()\r\n    if (\r\n        reduxStore.getState().timeline[data.id]\r\n        || reduxStore.getState().timeline[data.readedBy]\r\n    ) {\r\n        newTimeline = reduxStore.getState().timeline\r\n\r\n        let nodeId = data.id\r\n        let user = {}\r\n        if (data.db !== 'cards') {\r\n            nodeId = newTimeline[data.readedBy] ? data.readedBy : data.id\r\n            user = {\r\n                _id: data.readedBy,\r\n                name: db.users[data.readedBy].name,\r\n                image: db.users[data.readedBy].image\r\n            }\r\n        } else if (db.cards[data.id] && db.cards[data.id]._users && db.cards[data.id]._users[data.readedBy]) {\r\n            user = db.cards[data.id]._users[data.readedBy]\r\n        }\r\n\r\n\r\n        if (newTimeline && newTimeline[nodeId]) {\r\n            Object.keys(newTimeline[nodeId]).filter(m => {\r\n\r\n                if (\r\n                    data\r\n                    && data.type\r\n                    && (\r\n                        (\r\n                            data.type !== \"all\"\r\n                            && newTimeline[nodeId][m].type === data.type\r\n                        )\r\n                        ||\r\n                        (\r\n                            data.type === \"all\"\r\n                        )\r\n                    )\r\n                    && newTimeline[nodeId][m].user._id !== data.readedBy\r\n                    &&\r\n                    (\r\n                        !newTimeline[nodeId][m].readedBy\r\n                        || (\r\n                            session\r\n                            && session._id\r\n                            && newTimeline[nodeId][m].readedBy\r\n                            && !newTimeline[nodeId][m].readedBy[session._id]\r\n                        )\r\n                    )) {\r\n                    return true\r\n                }\r\n\r\n            }).map((m, mi) => {\r\n                newTimeline[nodeId][m] = {\r\n                    ...newTimeline[nodeId][m],\r\n                    readedBy: {\r\n                        ...newTimeline[nodeId][m] && newTimeline[nodeId][m].readedBy ? newTimeline[nodeId][m].readedBy : {},\r\n                        [data.readedBy]: {\r\n                            ...newTimeline[nodeId][m] && newTimeline[nodeId][m].readedBy && newTimeline[nodeId][m].readedBy[data.readedBy] ? newTimeline[nodeId][m].readedBy[data.readedBy] : {},\r\n                            ...user,\r\n                            readedDate: {\r\n                                low: moment().unix('x')\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            })\r\n        }\r\n    }\r\n\r\n    // console.log(\"XXXX\")\r\n    props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", {\r\n        ...newTimeline\r\n    });\r\n\r\n    if (\r\n        reduxStore.getState().db.cards[data.id]\r\n        && data.type\r\n        && reduxStore.getState().db.cards[data.id]._notifications\r\n        && (\r\n            reduxStore.getState().db.cards[data.id]._notifications[data.type]\r\n            || (\r\n                data.type === \"all\"\r\n            )\r\n        )\r\n    ) {\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...reduxStore.getState().db,\r\n            cards: {\r\n                ...reduxStore.getState().db.cards,\r\n                [data.id]: {\r\n                    ...reduxStore.getState().db.cards[data.id],\r\n                    ...data.type === 'all' ? {\r\n                        notifications: {}\r\n                    } : {\r\n                        _notifications: {\r\n                            ...reduxStore.getState().db.cards[data.id] && reduxStore.getState().db.cards[data.id]._notifications ? reduxStore.getState().db.cards[data.id]._notifications : {},\r\n                            [data.type]: 0,\r\n                        }\r\n                    },\r\n\r\n                }\r\n            }\r\n        })\r\n    }\r\n}\r\n\r\nconst interact = async (props, data) => {\r\n    const { db, timeline, session } = reduxStore.getState()\r\n    let user = {}\r\n\r\n    let nodeId = data.nodeId !== session._id ? nodeId = data.nodeId : data.user\r\n\r\n    if (db.users[data.user]) {\r\n        user = db.users[data.user]\r\n    } else if (data.user && db[data.db] && timeline[nodeId] && timeline[nodeId]._users && timeline[nodeId]._users[data.user]) {\r\n        user = timeline[nodeId]._users[data.user]\r\n    }\r\n\r\n    if (nodeId && data.message && timeline && timeline[session._id] && timeline[session._id][data.message])\r\n        nodeId = session._id\r\n\r\n    if (db[data.db] && timeline[nodeId] && timeline[nodeId][data.message]) {\r\n        let reactions = {\r\n            ...timeline[nodeId][data.message]\r\n                && timeline[nodeId][data.message]._reactions\r\n                ? timeline[nodeId][data.message]._reactions\r\n                : {},\r\n            [data.react]: {\r\n                ...timeline[nodeId][data.message]\r\n                    && timeline[nodeId][data.message]._reactions\r\n                    && timeline[nodeId][data.message]._reactions[data.react] ?\r\n                    timeline[nodeId][data.message]._reactions[data.react] : {},\r\n                [data.user]: {\r\n                    ...user,\r\n                    reactDate: {\r\n                        low: moment().tz('America/Sao_Paulo').unix('x')\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        Object.keys(reactions).map(a => {\r\n            if (a !== data.react)\r\n                Object.keys(reactions[a]).map(u => {\r\n                    if (reactions[a][u] && u === data.user)\r\n                        delete reactions[a][u]\r\n                })\r\n        })\r\n        let newData = {\r\n            ...timeline,\r\n            [nodeId]: {\r\n                ...timeline[nodeId],\r\n                [data.message]: {\r\n                    ...timeline[nodeId][data.message],\r\n                    _reactions: reactions\r\n                }\r\n            }\r\n        }\r\n        props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", newData);\r\n    }\r\n}\r\n\r\nexport const timelineComment = async (props, dt) => {\r\n    let verifyReg = await new Promise(async (resolve, reject) => {\r\n        if (dt && dt.db === 'cards' && !reduxStore.getState().db.cards[dt.idRel]) {\r\n            const loadNewCard = await loadCardsV2(props, {\r\n                idRel: dt.idRel,\r\n                cardLoad: \"fullCatenation\",\r\n                ignoreLoader: true\r\n            })\r\n            if (loadNewCard)\r\n                resolve(true)\r\n        } else {\r\n            resolve(true)\r\n        }\r\n\r\n    })\r\n    if (verifyReg) {\r\n        let data = dt\r\n        const { timeline, session } = reduxStore.getState()\r\n        let nodeId = data._parent ? data._parent : data.cardId ? data.cardId : data.node\r\n        if (nodeId === session._id)\r\n            nodeId = data.comment.user._id\r\n\r\n        if (data.to) {\r\n            data.to.map(idUser => {\r\n                let user = reduxStore.getState().db.users[idUser]\r\n                data._toUser = {\r\n                    ...data._toUser ? data._toUser : {},\r\n                    [idUser]: {\r\n                        _id: idUser,\r\n                        name: user.displayName ? user.displayName : user.name,\r\n                        image: user.image ? user.image : null\r\n                    }\r\n                }\r\n            })\r\n            delete data.to\r\n        }\r\n        if (nodeId\r\n            && data.comment\r\n        ) {\r\n            props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", {\r\n                ...reduxStore.getState().timeline,\r\n                [nodeId]: {\r\n                    ...reduxStore.getState().timeline[nodeId],\r\n                    [data.comment._id]: {\r\n                        ...reduxStore.getState().timeline[nodeId] && reduxStore.getState().timeline[nodeId][data.comment._id] ? reduxStore.getState().timeline[nodeId][data.comment._id] : {},\r\n                        ...data.comment,\r\n                        ...data._toUser ? { _toUser: data._toUser } : {},\r\n                        type: reduxStore.getState().timeline[nodeId] && reduxStore.getState().timeline[nodeId][data.comment._id] && reduxStore.getState().timeline[nodeId][data.comment._id].type ? reduxStore.getState().timeline[nodeId][data.comment._id].type : data && data.comment && data.comment.type ? data.comment.type : reduxStore.getState().timeline[nodeId] && reduxStore.getState().timeline[nodeId][data.comment._id] && reduxStore.getState().timeline[nodeId] && reduxStore.getState().timeline[nodeId][data.comment._id].type ? reduxStore.getState().timeline[nodeId] && reduxStore.getState().timeline[nodeId][data.comment._id].type : \"comment\",\r\n                        readedBy: {\r\n                            ...reduxStore.getState().timeline[nodeId] && reduxStore.getState().timeline[nodeId][data.comment._id] && reduxStore.getState().timeline[nodeId][data.comment._id].readedBy ? reduxStore.getState().timeline[nodeId][data.comment._id].readedBy : {},\r\n                            ...data.comment && data.comment.readedBy ? data.comment.readedBy : {},\r\n                        },\r\n                        idRel: null\r\n                    }\r\n                }\r\n            });\r\n        }\r\n        return true\r\n    }\r\n}\r\n\r\nconst loadMessages = async (data) => {\r\n    const { session } = reduxStore.getState()\r\n    let timelines = {}\r\n    try {\r\n        let req = await apims.post(`/Timeline_Get`,\r\n            {\r\n                ...data,\r\n            })\r\n\r\n        let unreadeds = {}\r\n\r\n        let load = await new Promise((resolve, reject) => {\r\n            if (req && req.data && req.data.length > 0) {\r\n                req.data.map((tm, mi) => {\r\n                    let readedBy = {}\r\n                    let reactions = {}\r\n\r\n                    if (tm && tm.params && tm.params.readedBy && tm.params.readedBy.filter(u => u._id).length > 0)\r\n                        tm.params.readedBy.map(u => {\r\n                            readedBy = {\r\n                                ...readedBy,\r\n                                [u._id]: u\r\n                            }\r\n                        })\r\n\r\n                    if (tm && tm.params && tm.params.reactions && tm.params.reactions.filter(u => u._id).length > 0)\r\n                        tm.params.reactions.map(r => {\r\n                            reactions = {\r\n                                ...reactions,\r\n                                [r.type]: {\r\n                                    ...reactions[r.type],\r\n                                    [r._id]: r,\r\n                                }\r\n                            }\r\n                        })\r\n\r\n                    if (parseInt(tm.unreaded) > 0)\r\n                        unreadeds = {\r\n                            ...unreadeds,\r\n                            [tm.nodeId !== session._id ? tm.nodeId : tm.params.user._id]: parseInt(tm.unreaded)\r\n                        }\r\n\r\n                    let timelineId = tm.nodeId !== session._id ? tm.nodeId : tm.params.user._id\r\n\r\n                    timelines = {\r\n                        ...timelines,\r\n                        [timelineId]: {\r\n                            ...timelines && timelines[timelineId] ? timelines[timelineId] : {},\r\n                            [tm.data._id]: {\r\n                                idRel: tm.nodeId,\r\n                                ...tm.data,\r\n                                ...tm.params,\r\n                                readedBy: readedBy,\r\n                                _reactions: reactions,\r\n                                sended: true,\r\n                                ...tm.data && tm.data.filesCount && (!tm.data.files || tm.data.files.length < parseInt(tm.data.filesCount)) && tm.data.localFiles ? { localFiles: JSON.parse(tm.data.localFiles), sendedFiles: false } : { localFiles: [], sendedFiles: true }\r\n                            }\r\n                        }\r\n                    }\r\n                    if (mi + 1 === req.data.length)\r\n                        resolve(true)\r\n                })\r\n            } else {\r\n                resolve(true)\r\n            }\r\n        })\r\n        if (load) {\r\n            return {\r\n                timelines,\r\n                unreadeds\r\n            }\r\n        }\r\n    } catch (e) {\r\n        return {\r\n            timelines: null,\r\n            unreadeds: null\r\n        }\r\n    }\r\n}\r\n\r\nconst loadTimeline = async (props, data) => {\r\n    let lastMessageDate = reduxStore.getState().chat?.lastMessageDate || 0;\r\n    const { ids, db, type, limit = 0, skip = 0, toId = null, ini = false, reqChildrens = false, newUpdates = false, lastDate = null } = data\r\n    const { session } = reduxStore.getState()\r\n\r\n    let nodeId = []\r\n    let nodes = []\r\n    if (typeof ids === 'string') {\r\n        nodes.push(ids)\r\n    } else {\r\n        nodes = ids\r\n    }\r\n\r\n    if (nodes && nodes.length > 0)\r\n        nodes.map(a => {\r\n            if (nodeId.indexOf(a) === -1) {\r\n                nodeId.push(a)\r\n            }\r\n        })\r\n\r\n    if (nodeId.length > 0) {\r\n        const load = await new Promise(async (resolve, reject) => {\r\n            if (nodeId.length > 0) {\r\n                try {\r\n                    let reqTimeline = await apims.post(`/M_Timeline_Get_V3`,\r\n                        {\r\n                            nodesIds: nodeId,\r\n                            db,\r\n                            type: type ? type : 'comment',\r\n                            skip: parseInt(skip),\r\n                            limit: limit,\r\n                            toId,\r\n                            ini,\r\n                            newUpdates,\r\n                            reqChildrens,\r\n                            lastDate: newUpdates ? data.lastDate ? data.lastDate : lastMessageDate : null\r\n                        }\r\n                    )\r\n                    if (reqTimeline && reqTimeline.data && reqTimeline.data.length > 0) {\r\n                        let timelines = { ...reduxStore.getState().timeline }\r\n                        let chatOpenId = null\r\n                        reqTimeline.data.map(tm => {\r\n\r\n                            let readedBy = timelines\r\n                                && timelines[idRel]\r\n                                && timelines[idRel][tm.data._id]\r\n                                && timelines[idRel][tm.data._id].readedBy ? timelines[idRel][tm.data._id].readedBy : {}\r\n\r\n                            let reactions = {}\r\n                            let idRel = tm.nodeId !== session._id ? tm.nodeId : tm.params.user._id\r\n\r\n                            if (tm && tm.params && tm.params.readedBy && tm.params.readedBy.filter(u => u._id).length > 0)\r\n                                tm.params.readedBy.map(u => {\r\n                                    readedBy = {\r\n                                        ...readedBy,\r\n                                        [u._id]: u\r\n                                    }\r\n                                })\r\n\r\n                            if (tm && tm.params && tm.params.reactions && tm.params.reactions.filter(u => u._id).length > 0)\r\n                                tm.params.reactions.map(r => {\r\n                                    reactions = {\r\n                                        ...reactions,\r\n                                        [r.type]: {\r\n                                            ...reactions[r.type],\r\n                                            [r._id]: r,\r\n                                        }\r\n                                    }\r\n                                })\r\n                            let toUsers = {}\r\n                            if (tm && tm.params && tm.params.users && tm.params.users.filter(a => a.name).length > 0)\r\n                                tm.params.users.filter(a => a.name).map(a => {\r\n                                    toUsers = {\r\n                                        ...toUsers,\r\n                                        [a._id]: a\r\n                                    }\r\n                                })\r\n                            if (session && session._id && readedBy && !readedBy[session._id] && timelines[idRel])\r\n                                Object.keys(timelines[idRel]).filter(msg => {\r\n                                    if (\r\n                                        timelines[idRel][msg]\r\n                                        && timelines[idRel][msg].readedBy\r\n                                        && timelines[idRel][msg].readedBy[session._id]\r\n                                        && parseInt(timelines[idRel][msg].created_at) > parseInt(tm.data.created_at)\r\n\r\n                                    )\r\n                                        readedBy = {\r\n                                            ...readedBy,\r\n                                            [session._id]: {\r\n                                                ...timelines[idRel][msg].readedBy[session._id]\r\n                                            }\r\n                                        }\r\n                                })\r\n\r\n                            if (\r\n                                (\r\n                                    data.ini\r\n                                    || data.newUpdates\r\n                                )\r\n                                && parseInt(tm.data.created_at) > parseInt(lastMessageDate)\r\n                            ) {\r\n                                lastMessageDate = parseInt(tm.data.created_at)\r\n                                chatOpenId = idRel\r\n                            }\r\n\r\n                            timelines = {\r\n                                ...timelines,\r\n                                [idRel]: {\r\n                                    ...timelines && timelines[idRel] ? timelines[idRel] : {},\r\n                                    [tm.data._id]: {\r\n                                        ...tm.data,\r\n                                        ...tm.params,\r\n                                        ...tm.data.type === 'timer' && String(tm.data.ini) === \"0\" ? {\r\n                                            manualEntry: true,\r\n                                            ini: parseInt(tm.data.created_at),\r\n                                            fin: parseInt(tm.data.created_at) + parseInt(tm.data.fin),\r\n                                        } : {},\r\n                                        readedBy: readedBy,\r\n                                        _reactions: reactions,\r\n                                        ...toUsers !== {} ? { _toUser: toUsers } : {},\r\n                                    }\r\n                                }\r\n                            }\r\n                        })\r\n                        if (!props.noReg)\r\n                            props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", {\r\n                                ...reduxStore.getState().timeline,\r\n                                ...timelines,\r\n                            });\r\n\r\n                        resolve({\r\n                            result: true,\r\n                            total: reqTimeline.data.length,\r\n                            timelines: timelines,\r\n                            chatOpenId,\r\n                            lastMessageDate\r\n                        })\r\n                    } else {\r\n                        // nodeId.map(x => {\r\n                        //     if (reduxStore.getState().db.cards[x])\r\n                        //         props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                        //             ...reduxStore.getState().db,\r\n                        //             cards: {\r\n                        //                 ...reduxStore.getState().db.cards,\r\n                        //                 [x]: {\r\n                        //                     ...reduxStore.getState().db.cards[x],\r\n                        //                     _loadTimeline: {\r\n                        //                         [type ? type : 'comment']: true\r\n                        //                     }\r\n                        //                 }\r\n                        //             }\r\n                        //         });\r\n                        // })\r\n\r\n                        resolve({\r\n                            result: true,\r\n                            total: reqTimeline.data.length,\r\n                        })\r\n                    }\r\n\r\n                } catch (e) {\r\n                    console.group('loadTimeline::ERR::')\r\n                    console.log(e)\r\n                    console.groupEnd()\r\n                }\r\n            }\r\n        })\r\n        if (\r\n            load\r\n            && (\r\n                load.chatOpenId\r\n                || load.lastMessageDate\r\n            )\r\n        ) {\r\n            props.reduxFunction(\"IMMEDIATE\", \"SET_CHAT\", {\r\n                ...reduxStore.getState().chat,\r\n                ...(data.ini || data.newUpdates) && load.lastMessageDate ? { lastMessageDate: load.lastMessageDate } : {},\r\n                ...data.ini && load.chatOpenId ? { nodeId: load.chatOpenId } : {},\r\n            })\r\n        }\r\n        if (load)\r\n            return load\r\n    } else {\r\n        return {\r\n            result: true,\r\n            total: 0\r\n        }\r\n    }\r\n}\r\n\r\nconst countUnRead = () => {\r\n    const { db, session, timeline } = reduxStore.getState()\r\n    let unReadCount = 0\r\n    let unReadCountGroup = 0\r\n    let unReadCountExternalGroups = 0\r\n    let unReadCountUser = 0\r\n    let unReadCountExternalUser = 0\r\n\r\n    Object.keys(timeline).map(id => {\r\n\r\n        Object.keys(timeline[id]).map(m => {\r\n            if (\r\n                timeline[id]\r\n                && timeline[id][m]\r\n                && !timeline[id][m].deleted\r\n                && timeline[id][m].user\r\n                && timeline[id][m].user._id\r\n                && timeline[id][m].user._id !== session._id\r\n\r\n                && (\r\n                    !timeline[id][m].readedBy\r\n                    || (\r\n                        timeline[id][m].readedBy\r\n                        && !timeline[id][m].readedBy[session._id]\r\n                    )\r\n                )\r\n            ) {\r\n                if (\r\n                    id\r\n                    && db.cards[id]\r\n                    && db.cards[id].type === 'chatGroup'\r\n                )\r\n                    unReadCountGroup = unReadCountGroup + 1\r\n\r\n                if (\r\n                    id\r\n                    && db.users[id]\r\n                    && db.users[id].type === \"user\"\r\n                )\r\n                    unReadCountUser = unReadCountUser + 1\r\n                unReadCount = unReadCount + 1\r\n            }\r\n        })\r\n    })\r\n\r\n    return {\r\n        total: unReadCountGroup + unReadCountUser + unReadCountExternalGroups + unReadCountExternalUser,\r\n        groups: unReadCountGroup,\r\n        externalGroups: unReadCountExternalGroups,\r\n        users: unReadCountUser,\r\n        externalUsers: unReadCountExternalUser\r\n    }\r\n}\r\n\r\nconst deleteMessage = async (props, data) => {\r\n    let socket\r\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\r\n        socket = reduxStore.getState().functions.socket\r\n    } else {\r\n        socket = reduxStore.getState().functions.socket\r\n    }\r\n\r\n    const comm = await new Promise(async (resolve, reject) => {\r\n        socket.emit(\"data\", {\r\n            module: \"chat\",\r\n            method: \"put\",\r\n            action: \"cancel\"\r\n        },\r\n            data,\r\n            (req) => {\r\n                let idRel = data.idRel\r\n                const { session } = reduxStore.getState()\r\n                if (reduxStore.getState().timeline[session._id] && reduxStore.getState().timeline[session._id][data.id]) {\r\n                    idRel = session._id\r\n                }\r\n                props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", {\r\n                    ...reduxStore.getState().timeline,\r\n                    [idRel]: {\r\n                        ...reduxStore.getState().timeline[idRel],\r\n                        [data.id]: {\r\n                            ...reduxStore.getState().timeline && reduxStore.getState().timeline[idRel] && reduxStore.getState().timeline[idRel][data.id],\r\n                            deleted: true,\r\n                            ...data.deletedReason ? { deletedReason: data.deletedReason } : {}\r\n                        }\r\n                    }\r\n                });\r\n                resolve(true)\r\n            })\r\n    })\r\n    if (comm)\r\n        return comm\r\n}\r\n\r\nconst updateTimelineMessage = (props, data) => {\r\n    // console.log(data)\r\n}\r\n\r\nconst forwardMessage = (props, data) => {\r\n    let socket\r\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\r\n        socket = reduxStore.getState().functions.socket\r\n    } else {\r\n        socket = reduxStore.getState().functions.socket\r\n    }\r\n    const { db, session } = reduxStore.getState()\r\n\r\n    let dataMessage = {\r\n        ...data,\r\n        forwardedId: data._id,\r\n        _id: uuid(),\r\n        created_at: `${moment().tz('America/Sao_Paulo').unix('x')}`\r\n    }\r\n\r\n    if (dataMessage._reactions)\r\n        delete dataMessage._reactions\r\n\r\n    if (dataMessage.readedBy)\r\n        delete dataMessage.readedBy\r\n\r\n    if (dataMessage._reactions)\r\n        delete dataMessage._reactions\r\n\r\n    if (dataMessage._toUser)\r\n        delete dataMessage._toUser\r\n\r\n\r\n    data._forwardToId.map(idRel => {\r\n        timelineComment(props, {\r\n            comment: {\r\n                ...dataMessage,\r\n                idRel: idRel,\r\n            },\r\n            node: idRel\r\n        })\r\n\r\n        console.log(dataMessage)\r\n\r\n        api.post(\"timeline/add\", {\r\n            ...dataMessage,\r\n            idRel: idRel\r\n        })\r\n        // socket.emit(\"data\", {\r\n        //     module: \"timeline\",\r\n        //     method: \"post\",\r\n        //     action: \"add\"\r\n        // },\r\n        //     {\r\n        //         ...dataMessage,\r\n        //         idRel: idRel\r\n        //     },\r\n        //     (response) => {\r\n\r\n        //     })\r\n    })\r\n\r\n\r\n}\r\n\r\nexport {\r\n    chatReaded,\r\n    countUnRead,\r\n    forwardMessage,\r\n    deleteMessage,\r\n    interact,\r\n    loadTimeline,\r\n    loadMessages,\r\n    updateTimelineMessage,\r\n    clearReadeds,\r\n}","import React from \"react\";\n// nodejs library to set properties for components\nimport PropTypes from \"prop-types\";\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport Grid from \"@material-ui/core/Grid\";\n\nconst styles = {\n  grid: {\n    margin: \"0\",\n    width: \"100%\"\n    // '&:before,&:after':{\n    //   display: 'table',\n    //   content: '\" \"',\n    // },\n    // '&:after':{\n    //   clear: 'both',\n    // }\n  }\n};\n\nconst useStyles = makeStyles(styles);\n\nexport default function GridContainer(props) {\n  const classes = useStyles();\n  const { children, className, ...rest } = props;\n  return (\n    <Grid container {...rest} className={classes.grid + \" \" + className}>\n      {children}\n    </Grid>\n  );\n}\n\nGridContainer.propTypes = {\n  className: PropTypes.string,\n  children: PropTypes.node\n};\n","import React from \"react\";\n// nodejs library to set properties for components\nimport PropTypes from \"prop-types\";\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport Grid from \"@material-ui/core/Grid\";\n\nconst styles = {\n  grid: {\n    padding: \"0 15px !important\"\n  }\n};\n\nconst useStyles = makeStyles(styles);\n\nexport default function GridItem(props) {\n  const classes = useStyles();\n  const { children, className, ...rest } = props;\n  return (\n    <Grid item {...rest} className={classes.grid + \" \" + className}>\n      {children}\n    </Grid>\n  );\n}\n\nGridItem.propTypes = {\n  className: PropTypes.string,\n  children: PropTypes.node\n};\n","import React from \"react\";\nimport { FileDrop } from \"react-file-drop\";\nimport { MentionsInput, Mention } from 'react-mentions';\nimport { v4 as uuid } from \"uuid\";\nimport Picker from 'emoji-picker-react';\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport CustomIconButton from \"components/CustomButtons/icon\";\nimport CustomButton from \"components/Buttons/custom\";\n\n//DEPENDENCIES\nimport Message from \"./message\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\";\nimport LinearProgress from \"@material-ui/core/LinearProgress\";\nimport Skeleton from '@material-ui/lab/Skeleton';\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport mentionInputStyle from \"assets/jss/material-dashboard-pro-react/components/Mentions-Input\";\nimport styles from \"assets/jss/material-dashboard-pro-react/components/timelineSending.js\";\n\n//FUNCTIONS\nimport { cardsAccess } from \"functions/users\";\nimport { translate, customApp, getAppAccess, appAlert } from \"functions/\";\nimport { upload } from \"functions/upload.js\";\nimport { timelineComment } from \"functions/chat.js\"\nimport apims from \"apims\"\nimport api from \"api\"\n\n//IMAGES\nimport defaultAvatar from \"assets/img/fundo-sonne.png\"\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\n\nconst useStyles = makeStyles(styles)\n\nconst Timeline = (props) => {\n    const { db, session, functions } = reduxStore.getState()\n    const { socket } = functions\n    const [message, setMessage] = React.useState('')\n    const [sending, setSending] = React.useState(false);\n    const [fileDropDrag, setFileDropDrag] = React.useState(false);\n    const [fileList, setFileList] = React.useState([]);\n    const [fileSend, setFileSend] = React.useState([]);\n    const [fileProgress, setFileProgress] = React.useState({})\n    const [fileError, setFileError] = React.useState(null)\n    const [urlPreview, setUrlPreview] = React.useState(null)\n    const [urlPreviewLoad, setUrlPreviewLoad] = React.useState(false)\n    const [urlErrors, setUrlErros] = React.useState([])\n    const [onEmojiPicker, setOnEmojiPicker] = React.useState(false)\n    const [inputHeight, setHeight] = React.useState(58)\n\n    const classes = useStyles()\n    const refFileDrop = React.createRef()\n    const sendingInput = React.createRef()\n\n    let AppAccess = getAppAccess()\n\n    let CardAccess = 0\n\n    if (session._id\n        && db.cards[props.nodeId]\n        && db.cards[props.nodeId]._users\n        && db.cards[props.nodeId]._users[Object.keys(db.cards[props.nodeId]._users).find(a => a.indexOf(session._id) > -1)])\n        CardAccess = db.cards[props.nodeId]._users[Object.keys(db.cards[props.nodeId]._users).find(a => a.indexOf(session._id) > -1)]\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    React.useEffect(() => {\n        let isSubscribed = true\n        if (isSubscribed)\n            if (props.draft && props.draft.message) {\n                setMessage(props.draft.message)\n            } else {\n                setMessage(\"\")\n            }\n        if (props?.draft?.files) {\n            setFileList(props.draft.files)\n        } else {\n            setFileList([])\n        }\n\n        return () => {\n            isSubscribed = false\n            setMessage(\"\")\n        }\n    }, [props.nodeId])\n\n    const textInput = React.createRef()\n\n    React.useEffect(() => {\n        // console.log(props.draft)\n        const inputId = document.getElementById(`sendingInput_${props.nodeId}`)\n        if (props.draft?.reply && inputId)\n            inputId.focus()\n    }, [props.draft])\n\n    // const sendTyping = async () => {\n    //     let ids = []\n    //     let group = null\n    //     if (db.cards[props.nodeId] && db.cards[props.nodeId].type === 'chatGroup') {\n    //         group = props.nodeId\n    //         Object.keys(db.cards[props.nodeId]._users).map(id => {\n    //             if (ids.indexOf(id) === -1)\n    //                 ids.push(id)\n    //         })\n    //         socket.emit(\"timeline.TYPING\", {\n    //             to: ids,\n    //             group: group\n    //         })\n    //     } else {\n    //         ids.push(props.nodeId)\n    //         socket.emit(\"timeline.TYPING\", {\n    //             to: ids\n    //         })\n    //     }\n    // }\n\n    const mentionedUsers = () => {\n        let newText\n        newText = message\n        let usersMentioned = []\n        if (newText) {\n            const test1 = newText.split('@[')\n            if (test1.length > 0)\n                test1.map(a => {\n                    if (a) {\n                        let id = a.split(\"](\")[1]\n                        if (id) {\n                            id = id.split(\")\")[0]\n                            if (id && id.length === 36) {\n                                usersMentioned.push(id)\n                            }\n                        }\n                    }\n                })\n        }\n        return usersMentioned\n    }\n\n    const sendMessage = async () => {\n        let dataMessage = {\n            _id: uuid(),\n            idRel: props.nodeId,\n            replyData: props.draft && props.draft.reply && reduxStore.getState().timeline[props.nodeId][props.draft.reply] ? reduxStore.getState().timeline[props.nodeId][props.draft.reply] : {},\n            reply: props.draft && props.draft.reply ? props.draft.reply : null,\n            message: message,\n            type: 'comment',\n            mentions: mentionedUsers(),\n            notifyUsers: notifyUsers,\n            filesCount: fileList.length > 0 ? fileList.length : 0,\n            _parent: props.nodeId,\n            _client: db.cards[props.nodeId] && db.cards[props.nodeId].client ? db.cards[props.nodeId].client : null,\n            db: props.db ? props.db : 'cards'\n        }\n        if (urlPreview) {\n            dataMessage = { ...dataMessage, urlPreview: JSON.stringify(urlPreview) }\n            setUrlPreview(null)\n        }\n\n        setMessage(\"\")\n        const { socket } = reduxStore.getState().functions\n        setOnEmojiPicker(false)\n        if (fileList.length > 0) setSending(true)\n\n        let notifyUsers = []\n        let mentions = mentionedUsers();\n        if (db.cards[props.nodeId]\n            && db.cards[props.nodeId].type !== 'chatGroup'\n            && db.cards[props.nodeId]._users\n            && Object.keys(db.cards[props.nodeId]._users).length > 0\n        )\n            Object.keys(db.cards[props.nodeId]._users).filter(a => a !== session._id && mentions.indexOf(a) === -1).map(a => {\n                notifyUsers.push(a)\n            })\n\n        if (props.onSending)\n            props.onSending({\n                ...dataMessage,\n                user: {\n                    _id: session._id,\n                    name: db.users[session._id].name,\n                    image: db.users[session._id].image || null,\n                },\n            })\n        let comment = {\n            ...dataMessage,\n            created_at: `${moment().unix('x')}`,\n            user: {\n                _id: session._id,\n                name: db.users[session._id].name,\n                image: db.users[session._id].image || null,\n            },\n        }\n        if (comment.mentions)\n            delete comment.mentions\n\n        if (comment.notifyUsers)\n            delete comment.notifyUsers\n\n        if (comment.db)\n            delete comment.db\n\n        timelineComment({\n            reduxFunction: props.reduxFunction\n        }, {\n            ...dataMessage,\n            comment\n        })\n\n        props.reduxFunction(\"ASYNC\", \"SET_CHATS\", {\n            ...reduxStore.getState().chats,\n            drafts: {\n                ...reduxStore.getState().chats.drafts,\n                [props.nodeId]: {\n                    message: null,\n                    reply: null,\n                    files: null\n                }\n            }\n        })\n        let sendMessage = await api.post(\"timeline/add\", dataMessage)\n\n        if (sendMessage && sendMessage.data) {\n            const response = sendMessage.data\n            if (response._id) {\n                let comment = {\n                    ...response.comment,\n                    _parent: props.nodeId,\n                    _client: db.cards[props.nodeId] && db.cards[props.nodeId].client ? db.cards[props.nodeId].client : null\n                }\n                let userAccessNew = 2\n                if (CardAccess < 2)\n                    userAccessNew = CardAccess\n\n                mentions.map(async a => {\n                    if (db.cards[props.nodeId]\n                        && (\n                            !db.cards[props.nodeId]._users\n                            || (\n                                db.cards[props.nodeId]._users\n                                && !db.cards[props.nodeId]._users[a]\n                            )\n                        )\n                    )\n                        cardsAccess(props, a, userAccessNew, props.nodeId, true)\n                })\n                if (fileList.length > 0) {\n                    sendFiles({ comment, dataMessage });\n                } else {\n                    if (props.onSending)\n                        props.onSending()\n\n                    setFileSend([]);\n                    setFileList([]);\n                    setUrlErros([]);\n                    setUrlPreview(null);\n                    setUrlPreviewLoad(false);\n                    setSending(false)\n                    if (props.onSending) {\n                        props.onSending()\n                    }\n                }\n            }\n        }\n        return false\n    }\n\n    const onUploadProgress = async (event, fi) => {\n        const percentCompleted = Math.round((event.loaded * 100) / event.total);\n        setFileProgress({\n            ...fileProgress,\n            [fi]: percentCompleted\n        })\n    };\n\n    const onUploadError = async (options, fi) => {\n        setFileError({\n            options,\n            fi\n        })\n        setFileProgress({})\n    };\n\n    const sendFiles = async (options, n = 0, sendedList = []) => {\n        const { socket } = reduxStore.getState().functions\n        const { comment, dataMessage } = options\n        let files = Array.from(fileList)\n        files.map(async (f, fi) => {\n            if (fi === n) {\n                const fileUpload = await upload(comment._id, f, true, {\n                    onUploadProgress: (e) => onUploadProgress(e, fi),\n                    onUploadError: (e) => {\n                        onUploadError(options, fi)\n                    }\n                })\n                if (fileUpload) {\n                    let nFilesSend = Array.from(sendedList)\n                    nFilesSend.push(fileUpload)\n                    setFileSend(nFilesSend)\n\n                    if (files.length > n + 1) {\n                        sendFiles(options, n + 1, nFilesSend)\n                    } else if (files.length === n + 1) {\n                        dataMessage.files = nFilesSend\n                        setTimeout(() => {\n                            api.post(\"timeline/add\", dataMessage)\n                            // socket.emit(\"data\", {\n                            //     module: \"timeline\",\n                            //     method: \"post\",\n                            //     action: \"add\"\n                            // },\n                            //     dataMessage,\n                            // )\n                        }, 1000)\n\n                        setFileSend([]);\n                        setFileList([]);\n                        setUrlPreview(null);\n                        setUrlPreviewLoad(false);\n                        setSending(false)\n                        if (props.onSending) {\n                            props.onSending()\n                        }\n                    }\n                }\n            }\n        })\n    }\n\n    const onDropFile = async event => {\n        setFileList([...fileList, ...Object.keys(event).map(file =>\n            event[file]\n        )])\n        props.reduxFunction(\"ASYNC\", \"SET_CHATS\", {\n            ...reduxStore.getState().chats,\n            drafts: {\n                ...reduxStore.getState().chats.drafts,\n                [props.nodeId]: {\n                    ...reduxStore.getState().chats.drafts?.[props.nodeId] || {},\n                    files: [...fileList, ...Object.keys(event).map(file =>\n                        event[file]\n                    )]\n                }\n            }\n        })\n        setFileDropDrag(false)\n    }\n\n    const deleteFile = i => {\n        let files = Array.from(fileList)\n        files.splice(i, 1)\n        setFileList(files)\n    }\n\n    const verifyText = async (f) => {\n        const { socket } = reduxStore.getState().functions\n        setMessage(f)\n        if (f\n\n            && (\n                f.indexOf('http://') > -1\n                ||\n                f.indexOf('https://') > -1\n            )\n        ) {\n            let url = ''\n            let text = []\n            if (f.indexOf(' ') > -1) {\n                text = f.split(' ')\n            } else if (f.indexOf('\\n') > -1) {\n                text = f.split('\\n')\n            } else {\n                text.push(f)\n            }\n            var pattern = new RegExp('^(https?:\\\\/\\\\/)?' + // protocol\n                '((([a-z\\\\d]([a-z\\\\d-]*[a-z\\\\d])*)\\\\.)+[a-z]{2,}|' + // domain name\n                '((\\\\d{1,3}\\\\.){3}\\\\d{1,3}))' + // OR ip (v4) address\n                '(\\\\:\\\\d+)?(\\\\/[-a-z\\\\d%_.~+]*)*' + // port and path\n                '(\\\\?[;&a-z\\\\d%_.~+=-]*)?' + // query string\n                '(\\\\#[-a-z\\\\d_]*)?$', 'i'); // fragment locator\n\n            await text.map(a => {\n                let test = a.replace(':', \"\")\n                if (\n                    (\n                        test.indexOf('http://') > -1\n                        ||\n                        test.indexOf('https://') > -1\n                    )\n                    &&\n                    !!pattern.test(test)) {\n                    url = a\n                }\n            })\n\n            if (\n                (\n                    !urlPreview\n                    && url\n                    && urlErrors.indexOf(url) === -1\n                )\n                ||\n                (\n                    url\n                    && urlPreview\n                    && urlErrors.indexOf(url) === -1\n                    && urlPreview.link !== url\n                )\n            ) {\n                setUrlPreviewLoad(true)\n                if (f.indexOf('youtube.com/watch?') === -1) {\n                    console.log(\"Verificando URL\", url)\n                    try {\n                        let dataUrl = await apims.post(\"/URL_DATA\", {\n                            url\n                        })\n                        if (dataUrl && dataUrl.data) {\n                            let result = dataUrl.data\n\n                            if (result && result.title && result.img && result.contentSnippet) {\n                                setUrlPreview(result)\n                            } else {\n                                setUrlPreviewLoad(false)\n                                setUrlPreview(null)\n                            }\n                        } else {\n                            setUrlPreviewLoad(false)\n                            setUrlPreview(null)\n                        }\n                    } catch (e) {\n                        setUrlPreviewLoad(false)\n                        setUrlPreview(null)\n                        let urlErrorsArray = urlErrors\n                        urlErrorsArray.push(url)\n                        setUrlErros(urlErrorsArray)\n                        appAlert({\n                            message: translate(\"$__couldNotLoadDataFromURL\", 1),\n                            variant: \"warning\",\n                            persist: false,\n                            horizontal: \"center\",\n                        })\n                        console.log(e)\n                    }\n                }\n\n                if (f.indexOf('youtube.com/watch?') > -1)\n                    setUrlPreviewLoad(false)\n            }\n        }\n        if (\n            f.indexOf('youtube.com/watch?') > -1\n        ) {\n            setUrlPreviewLoad(false)\n        }\n    }\n\n    const onEmojiClick = (event, emojiObject) => {\n        setMessage(`${message} ${emojiObject.emoji}`)\n    };\n\n    let usersSuggestion = []\n\n    if (db.cards[props.nodeId] && db.cards[props.nodeId]._users)\n        Object.keys(db.cards[props.nodeId]._users).map(a => {\n            if (a\n                && a !== null\n                && a !== undefined\n                && a !== session._id\n                && db.cards[props.nodeId]._users[a].name\n                && (\n                    !db.users[a]\n                    || (\n                        db.users[a]\n                        && !db.users[a].deleted\n                    )\n                )\n            ) {\n                let id = db.cards[props.nodeId]._users[a]._id\n                let display = db.cards[props.nodeId]._users[a].name ? db.cards[props.nodeId]._users[a].name : db.cards[props.nodeId]._users[a].name.split(' ').length > 0 ? db.cards[props.nodeId]._users[a].name.split(' ')[0] : db.cards[props.nodeId]._users[a].name\n                if (id && Object.keys(usersSuggestion).filter(a => usersSuggestion[a].id === id).length === 0)\n                    usersSuggestion.push({ id: id, display: display })\n            }\n        })\n\n    if (\n        (\n            db.cards[props.nodeId]\n            && !db.cards[props.nodeId].private\n        )\n        &&\n        (\n            (\n                AppAccess\n                && (\n                    AppAccess.owner\n                    || AppAccess.planAdmin\n                    || AppAccess.planModerate\n                )\n            ) ||\n            (\n                CardAccess\n                && CardAccess.access\n                && parseInt(CardAccess.access) > 3\n            )\n        )\n    ) {\n        Object.keys(db.users)\n            .filter(fil => {\n                if (!db.users[fil].deleted && db.users[fil].type === 'user') {\n                    if (\n                        (\n                            db.cards[props.nodeId]\n                            && db.cards[props.nodeId].client\n                            && (\n                                !db.users[fil]._parent\n                                || db.users[fil]._parent === db.cards[props.nodeId].client\n                            )\n                        )\n                        ||\n                        (\n                            db.cards[props.nodeId]\n                            && !db.cards[props.nodeId].client\n                            && db.cards[props.nodeId]._planId\n                            && db.cards[db.cards[props.nodeId]._planId]\n                            && db.cards[db.cards[props.nodeId]._planId].client\n                            && (\n                                !db.users[fil]._parent\n                                || db.users[fil]._parent === db.cards[db.cards[props.nodeId]._planId].client\n                            )\n                        )\n                        ||\n                        (\n                            db.cards[props.nodeId]\n                            && !db.cards[props.nodeId].client\n                            && !db.users[fil]._parent\n                        )\n                    )\n                        return true\n                }\n                return false\n            })\n            .map(a => {\n                if (a\n                    && a !== null\n                    && a !== undefined\n                    && a !== session._id\n                    && Object.keys(usersSuggestion).filter(fs => {\n                        if (usersSuggestion[fs].id === a)\n                            return true\n                    }).length === 0\n                ) {\n                    usersSuggestion.push({\n                        id: a,\n                        display: props.nodeId && db.cards[props.nodeId] && db.cards[props.nodeId]._users && db.cards[props.nodeId]._users[a] && db.cards[props.nodeId]._users[a].name ? db.cards[props.nodeId]._users[a].name : db.users[a].displayName ? db.users[a].displayName : db.users[a].name\n                    })\n                }\n            })\n    }\n\n    if (db.cards[props.nodeId] &&\n        (\n            db.cards[props.nodeId]._parent\n            && db.cards[db.cards[props.nodeId]._parent]\n            && db.cards[db.cards[props.nodeId]._parent]._users\n        )\n    )\n        Object.keys(db.cards[db.cards[props.nodeId]._parent]._users).map(a => {\n            if (a\n                && a !== null\n                && a !== undefined\n                && a !== session._id\n                && Object.keys(usersSuggestion).filter(fs => {\n                    if (usersSuggestion[fs].id === a)\n                        return true\n                }).length === 0\n            ) {\n                usersSuggestion.push({\n                    id: a,\n                    display: db.cards[db.cards[props.nodeId]._parent]._users[a].name,\n                    image: db.cards[db.cards[props.nodeId]._parent]._users[a].image || null\n                })\n            }\n        })\n\n    if (db.cards[props.nodeId] &&\n        (\n            db.cards[props.nodeId]._planId\n            && db.cards[db.cards[props.nodeId]._planId]\n            && db.cards[db.cards[props.nodeId]._planId]._users\n        )\n    )\n        Object.keys(db.cards[db.cards[props.nodeId]._planId]._users).map(a => {\n            if (a\n                && a !== null\n                && a !== undefined\n                && a !== session._id\n                && Object.keys(usersSuggestion).filter(fs => {\n                    if (usersSuggestion[fs].id === a)\n                        return true\n                }).length === 0\n            ) {\n                usersSuggestion.push({\n                    id: a,\n                    display: db.cards[db.cards[props.nodeId]._planId]._users[a].name,\n                    image: db.cards[db.cards[props.nodeId]._planId]._users[a].image || null\n                })\n            }\n        })\n\n\n\n    let heightDiff = 0\n    if (document.getElementById(`sendingInput_${props.nodeId}`) && document.getElementById(`sendingInput_${props.nodeId}`).offsetHeight)\n        heightDiff = document.getElementById(`sendingInput_${props.nodeId}`).offsetHeight\n\n    return (\n        <FileDrop\n            ref={refFileDrop}\n            className={props.relative ? classes.rootRelative : classes.root}\n            onDragOver={\n                () => {\n                    !props.disabledSend &&\n                        setFileDropDrag(true)\n                }\n            }\n            // style={{ zIndex: 50 }}\n            onDrop={onDropFile}\n            accept={\".png, .jpg, .jpeg, .bpm, .svg, .gif, .pdf, .mp4, .3gp, .ts, .mkv, .avi, .mov, .mts,  m2ts, .mxf, .aac,  aiff, .caf, .ogg, .mp3, .wav, .doc, .docx, .xls, .xlsx, .ppt, .pptx, .txt, .zip, .rar\"}\n        >\n            <React.Fragment>\n                {props.nodeId && !props.disabledSend ?\n                    <div className={props.relative ? classes.editorRelative : classes.editor}\n                        style={{\n                            ...props.editorStyle ? props.editorStyle : {},\n                            backgroundColor: \"#F0F0F0\"\n                        }}>\n                        <div className={classes.textEditor}>\n                            {urlPreviewLoad && !urlPreview &&\n                                <div className={classes.urlPreview} style={{ width: '100%', height: '150px' }}>\n                                    <div style={{ display: 'flex' }}>\n                                        <div style={{ marginLeft: '7px', width: '200px', height: '110px', maxWidth: '50%' }}>\n                                            <Skeleton variant=\"rect\" style={{ width: '200px', height: '110px', maxWidth: '100%' }} />\n                                        </div>\n                                        <div style={{ marginLeft: '7px', width: '100%', height: '25px' }}>\n                                            <Skeleton variant=\"text\" height={25} style={{ marginBottom: '7px' }} />\n                                            <Skeleton variant=\"text\" height={10} />\n                                            <Skeleton variant=\"text\" height={10} />\n                                            <Skeleton variant=\"text\" height={10} />\n                                            <Skeleton variant=\"text\" height={10} />\n                                            <Skeleton variant=\"text\" height={10} />\n                                            <Skeleton variant=\"text\" height={10} />\n                                        </div>\n                                    </div>\n                                </div>\n                            }\n                            {(\n                                (props.draft && props.draft.reply)\n                                || (fileList && fileList.length > 0)\n                            ) ?\n                                <div style={{\n                                    position: \"absolute\",\n                                    right: 0,\n                                    left: 0,\n                                    height: \"auto\",\n                                    padding: 7,\n                                    bottom: inputHeight + 4,\n                                    backgroundColor: \"#f0f0f0\",\n                                    display: \"flex\",\n                                    justifyContent: \"space-between\"\n                                }}>\n                                    {props.draft && props.draft.reply ?\n                                        <div\n                                            style={{\n                                                position: \"relative\",\n                                                display: \"flex\",\n                                                justifyContent: \"space-between\",\n                                                alignItems: \"center\"\n                                            }}\n                                        >\n                                            <div style={{\n                                                position: \"relative\",\n                                                display: \"flex\",\n                                                justifyContent: \"space-between\",\n                                                alignItems: \"center\"\n                                            }}>\n\n                                                <div style={{ color: customApp(\"menu\"), display: \"flex\", alignItems: \"center\" }}>\n                                                    <Icon\n                                                        icon='reply'\n                                                        color={customApp('menu')}\n                                                        size={'22px'}\n                                                    /><span style={{ marginLeft: 10 }}>{translate(\"$__reply\")}</span></div>\n\n\n                                            </div>\n\n                                            <div style={{\n                                                display: \"flex\",\n                                                margin: \"auto\",\n                                                padding: 15,\n                                                alignItems: \"center\",\n                                                width: \"77%\",\n                                                backgroundColor: \"rgba(250,250,250,0.33)\",\n                                                borderRadius: 5,\n                                                borderLeft: `5px solid ${customApp(\"menu\")}`\n                                            }}>\n                                                <Message\n                                                    storie={reduxStore.getState().timeline[props.nodeId][props.draft.reply]}\n                                                    hideCards={true}\n                                                    db={props.db}\n                                                    nodeId={props.nodeId}\n                                                    showUserName={true}\n                                                    noReactions={true}\n                                                />\n                                                <div style={{\n                                                    position: \"absolute\",\n                                                    top: 0,\n                                                    right: 0\n                                                }}>\n                                                    <CustomButton\n                                                        title={translate(\"$__cancelReply\")}\n                                                        color=\"red\"\n                                                        icon={\"cancel\"}\n                                                        size={\"17px\"}\n                                                        onClick={() => {\n                                                            props.reduxFunction(\"ASYNC\", \"SET_CHATS\", {\n                                                                ...reduxStore.getState().chats,\n                                                                drafts: {\n                                                                    ...reduxStore.getState().chats.drafts,\n                                                                    [props.nodeId]: {\n                                                                        ...reduxStore.getState().chats.drafts[props.nodeId] || {},\n                                                                        reply: null,\n                                                                    }\n                                                                }\n                                                            })\n                                                        }}\n                                                        transparent\n                                                    />\n                                                </div>\n                                            </div>\n                                        </div> : <React.Fragment></React.Fragment>}\n                                    {fileList && fileList.length > 0 ?\n                                        <div style={{\n                                            position: \"relative\",\n                                            maxHeight: \"100%\",\n                                            width: \"100%\"\n                                        }}>\n                                            <div style={{\n                                                position: \"relative\",\n                                                width: \"100%\",\n                                                float: \"left\",\n                                                padding: 3,\n                                                display: \"flex\",\n                                                justifyContent: \"flex-end\"\n                                            }}\n                                            >\n                                                <CustomButton\n                                                    title={translate(\"$__clearFiles\", 1)}\n                                                    text={translate(\"$__clearFiles\")}\n                                                    color={\"gray\"}\n                                                    icon='clear_all'\n                                                    onClick={() => {\n                                                        appAlert({\n                                                            message: translate(\"$__confirmClearFiles\", 1),\n                                                            variant: \"warning\",\n                                                            persist: false,\n                                                            horizontal: \"right\",\n                                                            confirm: () => {\n                                                                setFileList([])\n                                                                props.reduxFunction(\"ASYNC\", \"SET_CHATS\", {\n                                                                    ...reduxStore.getState().chats,\n                                                                    drafts: {\n                                                                        ...reduxStore.getState().chats.drafts,\n                                                                        [props.nodeId]: {\n                                                                            ...reduxStore.getState().chats.drafts?.[props.nodeId] || {},\n                                                                            files: null\n                                                                        }\n                                                                    }\n                                                                })\n                                                            }\n                                                        })\n\n                                                    }\n                                                    }\n                                                    size={\"25px\"}\n                                                />\n\n                                            </div>\n                                            <div style={{\n                                                position: \"relative\",\n                                                width: \"100%\",\n                                                float: \"left\",\n                                                padding: 3,\n                                                overflow: \"auto\",\n                                                display: \"flex\"\n                                            }}\n                                            >\n                                                {fileList.map((file, i) => {\n                                                    let ext = file.name.split('.')\n                                                    let img = `attachment`\n                                                    if (db.fileExtensions.filter(a => a.ext.indexOf(ext[ext.length - 1].toLowerCase()) > -1).length > 0)\n                                                        img = db.fileExtensions.filter(a => a.ext.indexOf(ext[ext.length - 1].toLowerCase()) > -1)[0].icon || URL.createObjectURL(file)\n                                                    return (\n                                                        <div\n                                                            key={i}\n                                                            title={file.name}\n                                                            style={{\n                                                                position: 'relative',\n                                                                padding: 7,\n                                                                width: \"100px\",\n                                                                justifyContent: \"center\"\n                                                            }}\n                                                        >\n                                                            <div\n                                                                style={{\n                                                                    position: 'relative',\n                                                                    width: '50px',\n                                                                    height: '50px',\n                                                                    margin: 'auto',\n                                                                    display: \"flex\",\n                                                                    justifyContent: \"center\",\n                                                                    alignItems: \"center\"\n                                                                }}\n                                                            >\n                                                                {typeof img === 'string' && img.indexOf('blob:') === -1 && img.indexOf('svg') === -1 ?\n                                                                    <Icon icon={img} size='50px' />\n                                                                    :\n                                                                    <img src={img} style={{ width: '100%', height: '100%' }} />\n                                                                }\n                                                            </div>\n                                                            <div\n\n                                                                style={{\n                                                                    position: \"relative\",\n                                                                    margin: \"auto\",\n                                                                    whiteSpace: \"nowrap\",\n                                                                    textOverflow: \"ellipsis\",\n                                                                    width: \"calc(100% - 30px)\",\n                                                                    overflow: \"hidden\"\n                                                                }}>{file.name}</div>\n                                                            <div style={{\n                                                                position: \"absolute\",\n                                                                top: 0,\n                                                                right: 3,\n                                                                display: \"flex\"\n                                                            }}>\n\n                                                                {fileSend && fileSend.length > 0 && fileSend[i] ?\n                                                                    <Icon icon=\"cloud_done\" color=\"green\" />\n                                                                    : !sending ? <Icon icon=\"delete_forever\" color=\"red\" onClick={() => deleteFile(i)} /> : <React.Fragment></React.Fragment>\n                                                                }\n                                                            </div>\n                                                            {\n                                                                fileError && fileError.fi === i ?\n                                                                    <CustomButton\n                                                                        title={translate(\"$__uploadFiles\", 1)}\n                                                                        text={translate(\"$__fileSendErrorClickToReSend\")}\n                                                                        color={\"red\"}\n                                                                        icon='upload'\n                                                                        onClick={() => {\n                                                                            sendFiles({\n                                                                                comment: fileError.options.comment\n                                                                            }, fileError.fi, fileSend)\n                                                                            setFileError(null)\n                                                                        }\n                                                                        }\n                                                                        size={\"25px\"}\n                                                                    />\n                                                                    : fileProgress && String(fileProgress[i]) && fileProgress[i] < 100 ?\n                                                                        <div style={{ display: \"flex\", alignItems: \"center\" }}>\n\n                                                                            <React.Fragment>\n                                                                                <div style={{ minWidth: 177 }}>\n                                                                                    <LinearProgress variant=\"buffer\" className={classes.progressBar} value={fileProgress[i] < 90 ? fileProgress[i] : 90} valueBuffer={fileProgress[i]} />\n                                                                                </div>\n                                                                                <div style={{ color: customApp(\"color\"), fontSize: 10, marginLeft: 15 }}>{fileProgress[i] < 90 ? fileProgress[i] : 90}%</div>\n                                                                            </React.Fragment>\n                                                                        </div>\n                                                                        : <React.Fragment></React.Fragment>\n                                                            }\n                                                        </div>\n                                                    )\n                                                })}\n                                            </div>\n                                        </div>\n                                        : <React.Fragment></React.Fragment>\n                                    }\n                                </div>\n                                : <React.Fragment></React.Fragment>}\n                            {urlPreview &&\n                                <GridContainer style={{ marginBottom: 15, backgroundColor: \"#f0f0f0\", padding: 7 }}>\n                                    <div style={{ position: \"absolute\", right: \"20px\" }}>\n                                        <CustomButton\n                                            title={translate(\"$__removePreview\")}\n                                            color=\"red\"\n                                            icon={\"delete_forever\"}\n                                            size={\"14px\"}\n                                            onClick={() => {\n                                                setUrlPreview(null);\n                                                setUrlPreviewLoad(false);\n                                            }}\n                                        />\n                                    </div>\n                                    {urlPreview.img &&\n                                        <GridItem\n                                            xs={12}\n                                            sm={6}\n                                            md={4}\n                                            lg={3}\n                                            xl={2}\n                                        >\n                                            <img\n                                                style={{\n                                                    width: \"-webkit-fill-available\"\n                                                }}\n                                                src={`${urlPreview.img ? urlPreview.img : defaultAvatar}`}\n                                                alt={urlPreview.title || urlPreview.link}\n                                            />\n\n                                        </GridItem>\n                                    }\n\n                                    <GridItem\n                                        xs={12}\n                                        sm={6}\n                                        md={8}\n                                        lg={9}\n                                        xl={10}\n                                    >\n\n                                        <div style={{\n                                            fontSize: \"14px\",\n                                            color: customApp(\"menu\"),\n                                            fontWeight: \"bold\"\n                                        }}>{urlPreview.title}</div>\n                                        {urlPreview.site && <div\n                                            style={{\n                                                fontSize: \"12px\",\n                                            }}\n                                        >{urlPreview.site}</div>}\n                                        {urlPreview.contentSnippet && <div\n                                            style={{\n                                                fontSize: \"12px\",\n                                                color: \"gray\",\n                                            }}>{urlPreview.contentSnippet}</div>}\n                                        <a style={{\n                                            marginTop: \"15px\",\n                                            fontWeight: \"bold\",\n                                            fontSize: \"12px\",\n                                        }\n                                        } href={urlPreview.link} target=\"_blank\">{translate(\"$__openLink\", \"*\")}</a>\n\n                                    </GridItem>\n                                </GridContainer>\n                            }\n                            {fileError ?\n                                <div\n                                    style={{\n                                        position: 'relative',\n                                        height: '60px',\n                                        backgroundColor: '#ffffff',\n                                        width: '100%',\n                                        padding: 15,\n                                        textAlign: \"center\",\n                                        display: \"flex\",\n                                        justifyContent: \"center\"\n                                    }}\n                                >\n                                    <CustomButton\n                                        title={translate(\"$__fileSendErrorClickToReSend\", 1)}\n                                        text={translate(\"$__fileSendErrorClickToReSend\")}\n                                        color={\"red\"}\n                                        icon='upload'\n                                        onClick={() => {\n                                            sendFiles({\n                                                comment: fileError.options.comment\n                                            }, fileError.fi, fileSend)\n                                            setFileError(null)\n                                        }\n                                        }\n                                        size={\"25px\"}\n                                    />\n                                </div>\n                                : sending ?\n                                    <div\n                                        style={{\n                                            position: 'relative',\n                                            height: '60px',\n                                            backgroundColor: '#ffffff',\n                                            width: '100%',\n                                            padding: 15\n                                        }}\n                                    >{translate('$__sending', 1)}\n                                        <LinearProgress className={classes.progressBar} /></div>\n                                    :\n                                    <div\n                                        ref={sendingInput}\n                                        style={{\n                                            position: 'relative',\n                                            height: 'auto',\n                                            borderRadius: '7px',\n                                            display: 'flex',\n                                            alignItems: 'center',\n                                            padding: '3px 0px 4px 0px',\n                                        }}>\n                                        <MentionsInput\n                                            id={`sendingInput_${props.nodeId}`}\n                                            value={message.trim().length > 0 ? message : \"\"}\n                                            // ref={textInput}\n                                            onChange={(e) => {\n                                                verifyText(e.target.value)\n                                                // sendTyping()\n                                                if (sendingInput.current && sendingInput.current.clientHeight)\n                                                    setHeight(sendingInput.current.clientHeight)\n                                            }}\n                                            onBlur={(e) => {\n                                                if (e.target.value)\n                                                    props.reduxFunction(\"ASYNC\", \"SET_CHATS\", {\n                                                        ...reduxStore.getState().chats,\n                                                        drafts: {\n                                                            ...reduxStore.getState().chats.drafts,\n                                                            [props.nodeId]: {\n                                                                ...reduxStore.getState().chats.drafts[props.nodeId] || {},\n                                                                message: e.target.value\n                                                            }\n                                                        }\n                                                    })\n                                            }}\n                                            onPaste={(e) => {\n                                                onDropFile(e.clipboardData.files)\n                                            }}\n                                            placeholder={translate('$__writeMessage')}\n                                            style={{\n                                                ...mentionInputStyle,\n                                                position: 'relative',\n                                                width: 'calc(100% - 130px)',\n                                                margin: '7px',\n                                                maxHeight: '150px',\n                                                paddingRight: '7px',\n                                                background: 'none',\n                                                border: 'none',\n                                                overflow: 'auto !important'\n                                            }}\n                                            onKeyDown={(event) => {\n                                                if (event.keyCode == 13) {\n                                                    if (event.shiftKey) {\n                                                        event.stopPropagation();\n                                                    } else if (message.length > 0 && message.trim() && message.trim().length > 0) {\n                                                        sendMessage()\n                                                    } else {\n                                                        setMessage(\"\")\n                                                    }\n                                                }\n                                            }\n                                            }\n                                            autoFocus\n                                            placement=\"top\"\n                                            forceSuggestionsAboveCursor={true}\n                                            autosize={{ minRows: 1, maxRows: 6 }}\n                                        >\n                                            <Mention\n                                                trigger=\"@\"\n                                                data={usersSuggestion}\n                                                renderSuggestion={(suggestion, search, highlightedDisplay) => {\n                                                    let u = db.users[suggestion.id] ? db.users[suggestion.id] : suggestion\n                                                    if (suggestion && suggestion.id)\n                                                        return (\n                                                            <div style={{ display: 'flex', alignItems: 'center', position: \"relative\" }}>\n                                                                <Avatar style={{\n                                                                    position: \"relative\",\n                                                                    width: '25px', height: '25px', marginRight: '7px'\n                                                                }}\n                                                                    // alt={highlightedDisplay}\n                                                                    src={suggestion.image ? suggestion.image :\n                                                                        db.cards &&\n                                                                            props.nodeId &&\n                                                                            db.cards[props.nodeId] &&\n                                                                            db.cards[props.nodeId]._users &&\n                                                                            db.cards[props.nodeId]._users[suggestion.id] &&\n                                                                            db.cards[props.nodeId]._users[suggestion.id].image\n                                                                            ? db.cards[props.nodeId]._users[suggestion.id].image\n                                                                            : db.users[suggestion.id]\n                                                                                && db.users[suggestion.id].image\n                                                                                ? db.users[suggestion.id].image\n                                                                                : null} />\n                                                                <div>\n                                                                    <div\n                                                                    >\n                                                                        {highlightedDisplay}\n                                                                    </div>\n                                                                    {(u && u._parent &&\n                                                                        reduxStore.getState().db.users[u._parent] &&\n                                                                        reduxStore.getState().db.users[u._parent].name) ?\n                                                                        <div\n                                                                            style={{ fontSize: 11, color: \"lightgray\", marginTop: -3 }}\n                                                                        >\n                                                                            {reduxStore.getState().db.users[u._parent].name}\n                                                                        </div>\n                                                                        : <React.Fragment></React.Fragment>\n                                                                    }\n                                                                </div>\n                                                                {(u && u._parent &&\n                                                                    reduxStore.getState().db.users[u._parent] &&\n                                                                    reduxStore.getState().db.users[u._parent].image) ?\n                                                                    <div\n                                                                        style={{\n                                                                            position: \"absolute\",\n                                                                            bottom: 4,\n                                                                            right: -7,\n                                                                            width: 15,\n                                                                            height: 15,\n                                                                            borderRadius: \"50%\",\n                                                                            backgroundImage: `url(${reduxStore.getState().db.users[u._parent].image})`,\n                                                                            backgroundSize: \"cover\",\n                                                                            backgroundRepeat: \"no-repeat\"\n                                                                        }}></div>\n                                                                    : <React.Fragment></React.Fragment>}\n                                                            </div>\n                                                        )\n                                                }\n                                                }\n                                                style={{\n                                                    backgroundColor: customApp('color', 0.5),\n                                                    lineHeight: \"17px\",\n                                                    borderRadius: \"7px\",\n                                                    padding: '3px 2px',\n                                                    marginLeft: '-4px',\n                                                    fontWeight: 'bold',\n                                                    maxHeight: 250,\n                                                    overflow: \"auto\"\n                                                }}\n                                            />\n                                        </MentionsInput>\n\n                                        <div\n                                            style={{\n                                                cursor: 'pointer',\n                                                zIndex: 100,\n                                                display: 'flex',\n                                                alignItems: 'center'\n                                            }}\n                                        >\n                                            <CustomIconButton\n                                                title={translate('$__emojis', 1)}\n                                                icon={onEmojiPicker ? `highlight_off` : `sentiment_very_satisfied`}\n                                                color={customApp('medium')}\n                                                onClick={() => {\n                                                    setOnEmojiPicker(!onEmojiPicker)\n                                                }}\n                                            />\n                                            {!sending &&\n                                                <div className={classes.actionButton}>\n                                                    <input\n                                                        className={\"input-text-timeline\"}\n                                                        style={{\n                                                            position: 'absolute',\n                                                            marginRight: \"3em\",\n                                                            height: \"24px\",\n                                                            fontSize: \"0\",\n                                                            left: '0px',\n                                                            width: \"24px\",\n                                                            cursor: 'pointer',\n                                                            border: 'none',\n                                                            opacity: '0',\n                                                        }} onChange={e =>\n                                                            onDropFile(e.target.files)\n                                                        }\n                                                        multiple\n                                                        type=\"file\"\n                                                        accept={\".png, .jpg, .jpeg, .bpm, .svg, .gif, .pdf, .mp4, .3gp, .ts, .mkv, .avi, .mov, .mts,  m2ts, .mxf, .aac,  aiff, .caf, .ogg, .mp3, .wav, .doc, .docx, .xls, .xlsx, .ppt, .pptx\"} />\n                                                    <Icon\n                                                        icon='attachment'\n                                                        color={customApp('medium')}\n                                                        size={'22px'}\n                                                    />\n                                                </div>\n                                            }\n                                            {(!sending && (message.trim().length > 0 || fileList.length > 0)) &&\n                                                <CustomIconButton\n                                                    title={translate('$__pressENTERtoSendorClickHere', 1)}\n                                                    icon=\"send\"\n                                                    color={customApp('menu')}\n                                                    onClick={() => sendMessage()}\n                                                />\n                                            }\n                                            {props.closeOption &&\n                                                <Icon title={translate('$__pressCRTL+ENTERtoSend', 1)} icon=\"close\" color={customApp('color')} onClick={() => props.onClose()} />\n                                            }\n                                            {onEmojiPicker &&\n                                                <div style={{\n                                                    position: 'absolute',\n                                                    bottom: '44px',\n                                                    right: '40px',\n                                                    zIndex: 100\n                                                }}>\n\n                                                    <Picker\n                                                        onEmojiClick={onEmojiClick}\n                                                        groupVisibility={{\n                                                            recently_used: false\n                                                        }}\n                                                    />\n                                                </div>\n                                            }\n                                        </div>\n                                    </div>\n                            }\n                        </div>\n                    </div>\n                    :\n                    <div\n                        className={props.relative ? classes.editorRelative : classes.editor}\n                        style={{\n                            backgroundColor: '#f0f0f0'\n                        }}\n\n                    >\n                        {translate('$__avaiableForViewingOnly')}\n                    </div>\n                }\n                <div className={fileDropDrag ? classes.onDropFile : classes.dropFile}\n                    onDragLeave={() => {\n                        !props.disabledSend &&\n                            setFileDropDrag(false)\n                    }\n                    }\n                >\n                    {translate(\"$__dropTheFileToAttach\", '*')}\n                </div>\n            </React.Fragment>\n        </FileDrop >\n    );\n}\n//REACT\nconst mapStateToProps = (storie, props) => ({\n    draft: storie.chats && storie.chats.drafts ? storie.chats.drafts[props.nodeId] : {}\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(Timeline)","//CORE\nimport React from 'react';\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport Backdrop from '@material-ui/core/Backdrop';\n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\nconst useStyles = makeStyles((theme) => ({\n    backdrop: {\n        zIndex: theme.zIndex.drawer + 1,\n        color: customApp('medium'),\n    },\n    box: {\n        width: '70vw',\n        height: '80vh',\n        backgroundColor: '#FFFFFF',\n        boxShadow: '0 0 6px rgba(0,0,0,0.3)',\n        padding: '30px',\n        overflowY: 'auto'\n    },\n    title: {\n        fontSize: '20px',\n        fontWeight: 'bold',\n        marginBottom: '7px',\n    },\n    iconList: {\n\n    },\n    list: {\n        position: 'relative',\n        width: '100%',\n        float: 'left',\n        marginBottom: '30px'\n    },\n    icon: {\n        position: 'relative',\n        float: 'left',\n        width: '50px',\n        height: '50px',\n\n    }\n}));\n\nexport default function Component(props) {\n    const classes = useStyles();\n    const [showList, setShowList] = React.useState(false);\n    const [selected, setSelected] = React.useState(props.icon ? props.icon : 'add_photo_alternate')\n\n    React.useEffect(() => {\n        setSelected(props.icon)\n    }, [props.icon])\n    return (\n        <div style={{\n            ...props.style ? props.style : {}\n        }}>\n            {!showList ?\n                <Icon\n                    icon={selected}\n                    color={props.color ? props.color : customApp(\"color\")}\n                    size={props.size || '30px'}\n                    onClick={() => {\n                        if (props.onChange)\n                            setShowList(true)\n                    }}\n                />\n                :\n                <Backdrop className={classes.backdrop} open={showList} onClick={() => setShowList(false)}>\n                    <div className={classes.box}>\n                        {iconList && Object.keys(iconList).map((list, i) => (\n                            <div key={i} className={classes.list} >\n                                <div className={classes.title}>{list}</div>\n                                <div className={classes.iconList}>\n                                    {iconList[list] && iconList[list].map((icon, index) => (\n                                        <div key={index} className={classes.icon}>\n                                            <Icon\n                                                icon={icon}\n                                                size='30px'\n                                                color={props.color ? props.color : customApp('color')}\n                                                onClick={() => {\n                                                    setSelected(icon)\n                                                    setShowList(false)\n                                                    if (props.callBack)\n                                                        props.callBack(icon)\n                                                    if (props.onChange)\n                                                        props.onChange(icon)\n                                                }}\n                                            />\n                                        </div>\n                                    ))}\n                                </div>\n                            </div>\n                        ))}\n                    </div>\n                </Backdrop>\n            }\n        </div>\n    )\n}\n\n\nconst iconList = {\n    'Action': [\n        '3d_rotation',\n        'accessibility',\n        'accessibility_new',\n        'accessible',\n        'accessible_forward',\n        'account_balance',\n        'account_balance_wallet',\n        'account_box',\n        'account_circle',\n        'add_shopping_cart',\n        'addchart',\n        'admin_panel_settings',\n        'alarm',\n        'alarm_add',\n        'alarm_off',\n        'alarm_on',\n        'all_inbox',\n        'all_out',\n        'analytics',\n        'anchor',\n        'android',\n        'announcement',\n        'api',\n        'app_blocking',\n        'arrow_circle_down',\n        'arrow_circle_up',\n        'arrow_right_alt',\n        'article',\n        'aspect_ratio',\n        'assessment',\n        'view_comfy',\n        'view_comfy_ind',\n        'view_comfy_late',\n        'view_comfy_return',\n        'view_comfy_returned',\n        'view_comfy_turned_in',\n        'autorenew',\n        'backup',\n        'backup_table',\n        'batch_prediction',\n        'book',\n        'bookmark',\n        'bookmark_border',\n        'bookmarks',\n        'bug_report',\n        'build',\n        'build_circle',\n        'cached',\n        'calendar_today',\n        'calendar_view_day',\n        'camera_enhance',\n        'cancel_schedule_send',\n        'card_giftcard',\n        'card_membership',\n        'card_travel',\n        'change_history',\n        'check_circle',\n        'check_circle_outline',\n        'chrome_reader_mode',\n        'class',\n        'close_fullscreen',\n        'code',\n        'comment_bank',\n        'commute',\n        'compare_arrows',\n        'contact_support',\n        'contactless',\n        'copyright',\n        'credit_card',\n        'dashboard',\n        'date_range',\n        'delete',\n        'delete_forever',\n        'delete_outline',\n        'description',\n        'dns',\n        'done',\n        'done_all',\n        'done_outline',\n        'donut_large',\n        'donut_small',\n        'drag_indicator',\n        'dynamic_form',\n        'eco',\n        'eject',\n        'euro_symbol',\n        'event',\n        'event_seat',\n        'exit_to_app',\n        'explore',\n        'explore_off',\n        'extension',\n        'face',\n        'fact_check',\n        'favorite',\n        'favorite_border',\n        'feedback',\n        'filter_alt',\n        'find_in_page',\n        'find_replace',\n        'fingerprint',\n        'flaky',\n        'flight_land',\n        'flight_takeoff',\n        'flip_to_back',\n        'flip_to_front',\n        'g_translate',\n        'gavel',\n        'get_app',\n        'gif',\n        'grade',\n        'grading',\n        'group_work',\n        'help',\n        'help_center',\n        'help_outline',\n        'highlight_alt',\n        'highlight_off',\n        'history',\n        'history_toggle_off',\n        'home',\n        'horizontal_split',\n        'hourglass_disabled',\n        'hourglass_empty',\n        'hourglass_full',\n        'http',\n        'https',\n        'important_devices',\n        'info',\n        'input',\n        'integration_instructions',\n        'invert_colors',\n        'label',\n        'label_important',\n        'label_off',\n        'language',\n        'launch',\n        'leaderboard',\n        'line_style',\n        'line_weight',\n        'list',\n        'lock',\n        'lock_open',\n        'login',\n        'loyalty',\n        'markunread_mailbox',\n        'maximize',\n        'mediation',\n        'minimize',\n        'model_training',\n        'next_plan',\n        'not_accessible',\n        'not_started',\n        'note_add',\n        'offline_bolt',\n        'offline_pin',\n        'online_prediction',\n        'opacity',\n        'open_in_browser',\n        'open_in_full',\n        'open_in_new',\n        'open_with',\n        'outlet',\n        'pageview',\n        'pan_tool',\n        'payment',\n        'pending',\n        'pending_actions',\n        'perm_camera_mic',\n        'perm_contact_calendar',\n        'perm_data_setting',\n        'perm_device_information',\n        'perm_identity',\n        'perm_media',\n        'perm_phone_msg',\n        'perm_scan_wifi',\n        'pets',\n        'picture_in_picture',\n        'picture_in_picture_alt',\n        'plagiarism',\n        'play_for_work',\n        'polymer',\n        'power_settings_new',\n        'pregnant_woman',\n        'preview',\n        'print',\n        'privacy_tip',\n        'query_builder',\n        'question_answer',\n        'quickreply',\n        'receipt',\n        'record_voice_over',\n        'redeem',\n        'remove_shopping_cart',\n        'reorder',\n        'report_problem',\n        'restore',\n        'restore_from_trash',\n        'restore_page',\n        'room',\n        'rounded_corner',\n        'rowing',\n        'rule',\n        'schedule',\n        'search',\n        'search_off',\n        'settings',\n        'settings_applications',\n        'settings_backup_restore',\n        'settings_bluetooth',\n        'settings_brightness',\n        'settings_cell',\n        'settings_ethernet',\n        'settings_input_antenna',\n        'settings_input_component',\n        'settings_input_composite',\n        'settings_input_hdmi',\n        'settings_input_svideo',\n        'settings_overscan',\n        'settings_phone',\n        'settings_power',\n        'settings_remote',\n        'settings_voice',\n        'shop',\n        'shop_two',\n        'shopping_bag',\n        'shopping_basket',\n        'shopping_cart',\n        'smart_button',\n        'source',\n        'speaker_notes',\n        'speaker_notes_off',\n        'spellcheck',\n        'star_rate',\n        'stars',\n        'sticky_note_2',\n        'store',\n        'subject',\n        'subtitles_off',\n        'supervised_user_circle',\n        'supervisor_account',\n        'support',\n        'swap_horiz',\n        'swap_horizontal_circle',\n        'swap_vert',\n        'swap_vertical_circle',\n        'sync_alt',\n        'system_update_alt',\n        'tab',\n        'tab_unselected',\n        'table_view',\n        'text_rotate_up',\n        'text_rotate_vertical',\n        'text_rotation_angledown',\n        'text_rotation_angleup',\n        'text_rotation_down',\n        'text_rotation_none',\n        'theaters',\n        'thumb_down',\n        'thumb_up',\n        'thumbs_up_down',\n        'timeline',\n        'toc',\n        'today',\n        'toll',\n        'touch_app',\n        'tour',\n        'track_changes',\n        'translate',\n        'trending_down',\n        'trending_flat',\n        'trending_up',\n        'turned_in',\n        'turned_in_not',\n        'update',\n        'upgrade',\n        'verified',\n        'verified_user',\n        'vertical_split',\n        'view_agenda',\n        'view_array',\n        'view_carousel',\n        'view_column',\n        'view_day',\n        'view_headline',\n        'view_list',\n        'view_module',\n        'view_quilt',\n        'view_sidebar',\n        'view_stream',\n        'view_week',\n        'visibility',\n        'visibility_off',\n        'voice_over_off',\n        'watch_later',\n        'wifi_protected_setup',\n        'work',\n        'work_off',\n        'work_outline',\n        'wysiwyg',\n        'youtube_searched_for',\n        'zoom_in',\n        'zoom_out'\n    ],\n    'Alert': [\n        'add_alert',\n        'auto_delete',\n        'error',\n        'error_outline',\n        'notification_important',\n        'warning'\n    ],\n    'Av': [\n        '4k',\n        '5g',\n        'add_to_queue',\n        'airplay',\n        'album',\n        'art_track',\n        'av_timer',\n        'branding_watermark',\n        'call_to_action',\n        'closed_caption',\n        'closed_caption_disabled',\n        'control_camera',\n        'equalizer',\n        'explicit',\n        'fast_forward',\n        'fast_rewind',\n        'featured_play_list',\n        'featured_video',\n        'fiber_dvr',\n        'fiber_manual_record',\n        'fiber_new',\n        'fiber_pin',\n        'fiber_smart_record',\n        'forward_10',\n        'forward_30',\n        'forward_5',\n        'games',\n        'hd',\n        'hearing',\n        'hearing_disabled',\n        'high_quality',\n        'library_add',\n        'library_add_check',\n        'library_books',\n        'library_music',\n        'loop',\n        'mic',\n        'mic_none',\n        'mic_off',\n        'missed_video_call',\n        'movie',\n        'music_video',\n        'new_releases',\n        'not_interested',\n        'note',\n        'pause',\n        'pause_circle_filled',\n        'pause_circle_outline',\n        'play_arrow',\n        'play_circle_filled',\n        'play_circle_outline',\n        'playlist_add',\n        'playlist_add_check',\n        'playlist_play',\n        'queue',\n        'queue_music',\n        'queue_play_next',\n        'radio',\n        'recent_actors',\n        'remove_from_queue',\n        'repeat',\n        'repeat_one',\n        'replay',\n        'replay_10',\n        'replay_30',\n        'replay_5',\n        'shuffle',\n        'skip_next',\n        'skip_previous',\n        'slow_motion_video',\n        'snooze',\n        'sort_by_alpha',\n        'speed',\n        'stop',\n        'stop_circle',\n        'subscriptions',\n        'subtitles',\n        'surround_sound',\n        'video_call',\n        'video_label',\n        'video_library',\n        'video_settings',\n        'videocam',\n        'videocam_off',\n        'volume_down',\n        'volume_mute',\n        'volume_off',\n        'volume_up',\n        'web',\n        'web_asset'\n    ],\n    'Communication': [\n        'add_ic_call',\n        'alternate_email',\n        'business',\n        'call',\n        'call_end',\n        'call_made',\n        'call_merge',\n        'call_missed',\n        'call_missed_outgoing',\n        'call_received',\n        'call_split',\n        'cancel_presentation',\n        'chat',\n        'chat_bubble',\n        'chat_bubble_outline',\n        'clear_all',\n        'comment',\n        'contact_mail',\n        'contact_phone',\n        'contacts',\n        'desktop_access_disabled',\n        'dialer_sip',\n        'dialpad',\n        'domain_disabled',\n        'domain_verification',\n        'duo',\n        'email',\n        'forum',\n        'forward_to_inbox',\n        'hourglass_bottom',\n        'hourglass_top',\n        'import_contacts',\n        'import_export',\n        'invert_colors_off',\n        'list_alt',\n        'live_help',\n        'location_off',\n        'location_on',\n        'mail_outline',\n        'mark_chat_read',\n        'mark_chat_unread',\n        'mark_email_read',\n        'mark_email_unread',\n        'message',\n        'mobile_screen_share',\n        'more_time',\n        'nat',\n        'no_sim',\n        'pause_presentation',\n        'person_add_disabled',\n        'person_search',\n        'phone',\n        'phone_disabled',\n        'phone_enabled',\n        'phonelink_erase',\n        'phonelink_lock',\n        'phonelink_ring',\n        'phonelink_setup',\n        'portable_wifi_off',\n        'present_to_all',\n        'print_disabled',\n        'qr_code',\n        'qr_code_scanner',\n        'read_more',\n        'ring_volume',\n        'rss_feed',\n        'screen_share',\n        'sentiment_satisfied_alt',\n        'speaker_phone',\n        'stay_current_landscape',\n        'stay_current_portrait',\n        'stay_primary_landscape',\n        'stay_primary_portrait',\n        'stop_screen_share',\n        'swap_calls',\n        'textsms',\n        'unsubscribe',\n        'voicemail',\n        'vpn_key',\n        'wifi_calling'\n    ],\n    'Content': [\n        'add',\n        'add_box',\n        'add_circle',\n        'add_circle_outline',\n        'amp_stories',\n        'archive',\n        'backspace',\n        'ballot',\n        'biotech',\n        'block',\n        'calculate',\n        'clear',\n        'contant_copy',\n        'content_cut',\n        'content_paste',\n        'create',\n        'delete_sweep',\n        'drafts',\n        'dynamic_feed',\n        'file_copy',\n        'filter_list',\n        'flag',\n        'font_download',\n        'foward',\n        'gesture',\n        'how_to_reg',\n        'how_to_vote',\n        'inbox',\n        'insights',\n        'link',\n        'link_off',\n        'low_priority',\n        'mail',\n        'markunread',\n        'move_to_inbox',\n        'next_week',\n        'outlined_flag',\n        'policy',\n        'push_pin',\n        'redo',\n        'remove',\n        'remove_circle',\n        'remove_circle_outline',\n        'reply',\n        'reply_all',\n        'report',\n        'report_off',\n        'save',\n        'save_alt',\n        'select_all',\n        'send',\n        'sort',\n        'square_foot',\n        'text_format',\n        'unarchive',\n        'undo',\n        'waves',\n        'weekend',\n        'where_to_vote'\n    ],\n    'Device': [\n        'access_alarm',\n        'access_time',\n        'ad_units',\n        'add_alarm',\n        'add_to_home_screen',\n        'airplanemode_active',\n        'airplanemode_inactive',\n        'battery_alert',\n        'battery_charging_full',\n        'battery_full',\n        'battery_std',\n        'battery_unknown',\n        'bluetooth',\n        'bluetooth_connected',\n        'bluetooth_disabled',\n        'bluetooth_searching',\n        'brightness_auto',\n        'brightness_high',\n        'brightness_low',\n        'brightness_medium',\n        'data_usage',\n        'developer_mode',\n        'devices',\n        'dvr',\n        'gps_fixed',\n        'gps_not_fixed',\n        'gps_off',\n        'graphic_eq',\n        'location_disabled',\n        'location_searching',\n        'mobile_friendly',\n        'mobile_off',\n        'nfc',\n        'screen_lock_landscape',\n        'screen_lock_portrait',\n        'screen_lock_rotation',\n        'screen_rotation',\n        'sd_storage',\n        'settings_system_daydream',\n        'signal_cellular_4_bar',\n        'signal_cellular_alt',\n        'signal_cellular_connected_no_internet_4_bar',\n        'signal_cellular_no_sim',\n        'signal_cellular_null',\n        'signal_cellular_off',\n        'signal_wifi_4_bar',\n        'signal_wifi_4_bar_lock',\n        'signal_wifi_off',\n        'storage',\n        'usb',\n        'wallpaper',\n        'widgets',\n        'wifi_lock',\n        'wifi_tethering',\n    ],\n    'Editor': [\n        'add_comment',\n        'attach_file',\n        'attach_money',\n        'bar_chart',\n        'border_all',\n        'border_bottom',\n        'border_clear',\n        'border_horizontal',\n        'border_inner',\n        'border_left',\n        'border_outer',\n        'border_right',\n        'border_style',\n        'border_top',\n        'border_vertical',\n        'bubble_chart',\n        'drag_handle',\n        'format_align_center',\n        'format_align_justify',\n        'format_align_left',\n        'format_align_right',\n        'format_bold',\n        'format_clear',\n        'format_color_reset',\n        'format_indent_decrease',\n        'format_indent_increase',\n        'format_italic',\n        'format_line_spacing',\n        'format_list_bulleted',\n        'format_list_numbered',\n        'format_list_numbered_rtl',\n        'format_paint',\n        'format_quote',\n        'format_shapes',\n        'format_size',\n        'format_strikethrough',\n        'format_textdirection_l_to_r',\n        'format_textdirection_r_to_l',\n        'format_underlined',\n        'functions',\n        'height',\n        'highlight',\n        'horizontal_rule',\n        'insert_chart',\n        'insert_chart_outlined',\n        'insert_comment',\n        'insert_drive_file',\n        'insert_emoticon',\n        'insert_invitation',\n        'insert_link',\n        'insert_photo',\n        'linear_scale',\n        'merge_type',\n        'mode_comment',\n        'monetization_on',\n        'money_off',\n        'multiline_chart',\n        'notes',\n        'pie_chart',\n        'post_add',\n        'publish',\n        'scatter_plot',\n        'score',\n        'short_text',\n        'show_chart',\n        'space_bar',\n        'strikethrough_s',\n        'subscript',\n        'superscript',\n        'table_chart',\n        'table_rows',\n        'text_fields',\n        'title',\n        'vertical_align_bottom',\n        'vertical_align_center',\n        'vertical_align_top',\n        'wrap_text'\n    ],\n    'File': [\n        'attach_email',\n        'attachment',\n        'cloud',\n        'cloud_circle',\n        'cloud_done',\n        'cloud_download',\n        'cloud_off',\n        'cloud_quere',\n        'cloud_upload',\n        'create_new_folder',\n        'folder',\n        'folder_open',\n        'folder_shared',\n        'request_quote',\n        'rule_folder',\n        'snippet_folder',\n        'text_snippet',\n        'topic'\n    ],\n    'Hardware': [\n        'browser_not_supported',\n        'cast',\n        'cast_connected',\n        'cast_for_education',\n        'computer',\n        'desktop_mac',\n        'desktop_windows',\n        'developer_board',\n        'device_hub',\n        'device_unknown',\n        'devices_other',\n        'dock',\n        'gamepad',\n        'headset',\n        'headset_mic',\n        'keyboard',\n        'keyboard_arrow_down',\n        'keyboard_arrow_left',\n        'keyboard_arrow_right',\n        'keyboard_arrow_up',\n        'keyboard_backspace',\n        'keyboard_capslock',\n        'keyboard_hide',\n        'keyboard_return',\n        'keyboard_tab',\n        'keyboard_voice',\n        'laptop',\n        'laptop_chromebook',\n        'laptop_mac',\n        'laptop_windows',\n        'memory',\n        'mouse',\n        'phone_android',\n        'phone_iphone',\n        'phonelink',\n        'phonelink_off',\n        'point_of_sale',\n        'power_input',\n        'router',\n        'scanner',\n        'security',\n        'sim_card',\n        'smartphone',\n        'speaker',\n        'speaker_group',\n        'tablet',\n        'tablet_android',\n        'tablet_mac',\n        'toys',\n        'tv',\n        'videogame_asset',\n        'watch'\n    ],\n    'Home': [\n        'sensor_door',\n        'sensor_window'\n    ],\n    'Image': [\n        'add_a_photo',\n        'add_photo_alternate',\n        'add_to_photos',\n        'adjust',\n        'assistant',\n        'assistant_photo',\n        'audiotrack',\n        'bedtime',\n        'blur_circular',\n        'blur_linear',\n        'blur_off',\n        'blur_on',\n        'brightness_1',\n        'brightness_2',\n        'brightness_3',\n        'brightness_4',\n        'brightness_5',\n        'brightness_6',\n        'brightness_7',\n        'broken_image',\n        'brush',\n        'burst_mode',\n        'camera',\n        'camera_alt',\n        'camera_front',\n        'camera_rear',\n        'camera_roll',\n        'center_focus_strong',\n        'center_focus_weak',\n        'collections',\n        'collections_bookmark',\n        'color_lens',\n        'colorize',\n        'compare',\n        'control_point',\n        'control_point_duplicate',\n        'crop',\n        'crop_16_9',\n        'crop_3_2',\n        'crop_5_4',\n        'crop_7_5',\n        'crop_din',\n        'crop_free',\n        'crop_landscape',\n        'crop_original',\n        'crop_portrait',\n        'crop_rotate',\n        'crop_square',\n        'dehaze',\n        'details',\n        'edit',\n        'euro',\n        'exposure',\n        'exposure_neg_1',\n        'exposure_neg_2',\n        'exposure_plus_1',\n        'exposure_plus_2',\n        'exposure_zero',\n        'filter',\n        'filter_1',\n        'filter_2',\n        'filter_3',\n        'filter_4',\n        'filter_5',\n        'filter_6',\n        'filter_7',\n        'filter_8',\n        'filter_9',\n        'filter_9_plus',\n        'filter_b_and_w',\n        'filter_center_focus',\n        'filter_drama',\n        'filter_frames',\n        'filter_hdr',\n        'filter_none',\n        'filter_tilt_shift',\n        'filter_vintage',\n        'flare',\n        'flash_auto',\n        'flash_off',\n        'flash_on',\n        'flip',\n        'flip_camera_android',\n        'flip_camera_ios',\n        'gradient',\n        'grain',\n        'grid_off',\n        'grid_on',\n        'hdr_off',\n        'hdr_on',\n        'hdr_strong',\n        'hdr_weak',\n        'healing',\n        'image',\n        'image_aspect_ratio',\n        'image_not_supported',\n        'image_search',\n        'iso',\n        'landscape',\n        'leak_add',\n        'leak_remove',\n        'lens',\n        'linked_camera',\n        'looks',\n        'looks_3',\n        'looks_4',\n        'looks_5',\n        'looks_6',\n        'looks_one',\n        'looks_two',\n        'loupe',\n        'monochrome_photos',\n        'motion_photos_on',\n        'motion_photos_paused',\n        'movie_creation',\n        'movie_filter',\n        'music_note',\n        'music_off',\n        'nature',\n        'nature_people',\n        'navigate_before',\n        'navigate_next',\n        'palette',\n        'panorama',\n        'panorama_fish_eye',\n        'panorama_horizontal',\n        'panorama_vertical',\n        'panorama_wide_angle',\n        'photo',\n        'photo_album',\n        'photo_camera',\n        'photo_filter',\n        'photo_library',\n        'photo_size_select_actual',\n        'photo_size_select_large',\n        'photo_size_select_small',\n        'picture_as_pdf',\n        'portrait',\n        'receipt_long',\n        'remove_red_eye',\n        'rotate_90_degrees_ccw',\n        'rotate_left',\n        'rotate_right',\n        'shutter_speed',\n        'slideshow',\n        'straighten',\n        'style',\n        'switch_camera',\n        'switch_video',\n        'tag_faces',\n        'texture',\n        'timelapse',\n        'timer',\n        'timer_10',\n        'timer_3',\n        'timer_off',\n        'tonality',\n        'transform',\n        'tune',\n        'view_comfy',\n        'view_compact',\n        'vignette',\n        'wb_auto',\n        'wb_cloudy',\n        'wb_incandescent',\n        'wb_iridescent',\n        'wb_sunny'\n    ],\n    'Maps': [\n        '360',\n        'add_business',\n        'add_location',\n        'add_location_alt',\n        'add_road',\n        'agriculture',\n        'alt_route',\n        'atm',\n        'beenhere',\n        'bike_scooter',\n        'category',\n        'cleaning_services',\n        'compass_calibration',\n        'departure_board',\n        'design_services',\n        'directions',\n        'directions_bike',\n        'directions_boat',\n        'directions_bus',\n        'directions_car',\n        'directions_railway',\n        'directions_run',\n        'directions_subway',\n        'directions_transit',\n        'directions_walk',\n        'edit_attributes',\n        'edit_location',\n        'edit_road',\n        'electric_bike',\n        'electric_car',\n        'electric_moped',\n        'electric_scooter',\n        'electrical_services',\n        'ev_station',\n        'fastfood',\n        'flight',\n        'handyman',\n        'home_repair_service',\n        'hotel',\n        'hvac',\n        'layers',\n        'layers_clear',\n        'local_activity',\n        'local_airport',\n        'local_atm',\n        'local_bar',\n        'local_cafe',\n        'local_car_wash',\n        'local_convenience_store',\n        'local_dining',\n        'local_drink',\n        'local_fire_department',\n        'local_florist',\n        'local_gas_station',\n        'local_grocery_store',\n        'local_hospital',\n        'local_hotel',\n        'local_laundry_service',\n        'local_library',\n        'local_mall',\n        'local_movies',\n        'local_offer',\n        'local_parking',\n        'local_pharmacy',\n        'local_phone',\n        'local_pizza',\n        'local_play',\n        'local_police',\n        'local_post_office',\n        'local_printshop',\n        'local_see',\n        'local_shipping',\n        'local_taxi',\n        'map',\n        'maps_ugc',\n        'medical_services',\n        'menu_book',\n        'miscellaneous_services',\n        'money',\n        'moped',\n        'multiple_stop',\n        'museum',\n        'my_location',\n        'navigation',\n        'near_me',\n        'near_me_disabled',\n        'no_meals',\n        'no_transfer',\n        'not_listed_location',\n        'pedal_bike',\n        'person_pin',\n        'person_pin_circle',\n        'pest_control',\n        'pest_control_rodent',\n        'pin_drop',\n        'place',\n        'plumbing',\n        'rate_review',\n        'restaurant',\n        'restaurant_menu',\n        'run_circle',\n        'satellite',\n        'set_meal',\n        'store_mall_directory',\n        'streetview',\n        'subway',\n        'terrain',\n        'traffic',\n        'train',\n        'tram',\n        'transfer_within_a_station',\n        'transit_enterexit',\n        'trip_origin',\n        'two_wheeler',\n        'wine_bar',\n        'wrong_location',\n        'zoom_out_map'\n    ],\n    'Navigation': [\n        'app_settings_alt',\n        'apps',\n        'arrow_back',\n        'arrow_back_ios',\n        'arrow_downward',\n        'arrow_drop_down',\n        'arrow_drop_down_circle',\n        'arrow_drop_up',\n        'arrow_forward',\n        'arrow_forward_ios',\n        'arrow_left',\n        'arrow_right',\n        'arrow_upward',\n        'campaign',\n        'cancel',\n        'check',\n        'chevron_left',\n        'chevron_right',\n        'close',\n        'double_arrow',\n        'east',\n        'expand_less',\n        'expand_more',\n        'first_page',\n        'fullscreen',\n        'fullscreen_exit',\n        'home_work',\n        'last_page',\n        'legend_toggle',\n        'menu',\n        'menu_open',\n        'more_horiz',\n        'more_vert',\n        'north',\n        'north_east',\n        'north_west',\n        'payments',\n        'refresh',\n        'south',\n        'south_east',\n        'south_west',\n        'subdirectory_arrow_left',\n        'subdirectory_arrow_right',\n        'switch_left',\n        'switch_right',\n        'unfold_less',\n        'unfold_more',\n        'west'\n    ],\n    'Notification': [\n        'account_tree',\n        'adb',\n        'airline_seat_flat',\n        'airline_seat_flat_angled',\n        'airline_seat_individual_suite',\n        'airline_seat_legroom_extra',\n        'airline_seat_legroom_normal',\n        'airline_seat_legroom_reduced',\n        'airline_seat_recline_extra',\n        'airline_seat_recline_normal',\n        'bluetooth_audio',\n        'confirmation_number',\n        'directions_off',\n        'disc_full',\n        'drive_eta',\n        'enhanced_encryption',\n        'event_available',\n        'event_busy',\n        'event_note',\n        'folder_special',\n        'live_tv',\n        'mms',\n        'more',\n        'network_check',\n        'network_locked',\n        'no_encryption',\n        'ondemand_video',\n        'personal_video',\n        'phone_bluetooth_speaker',\n        'phone_callback',\n        'phone_forwarded',\n        'phone_in_talk',\n        'phone_locked',\n        'phone_missed',\n        'phone_paused',\n        'power',\n        'power_off',\n        'priority_high',\n        'sd_card',\n        'sms',\n        'sms_failed',\n        'support_agent',\n        'sync',\n        'sync_disabled',\n        'sync_problem',\n        'system_update',\n        'tap_and_play',\n        'time_to_leave',\n        'tv_off',\n        'vibration',\n        'voice_chat',\n        'vpn_lock',\n        'wc',\n        'wifi',\n        'wifi_off',\n    ],\n    'Places': [\n        'ac_unit',\n        'airport_shuttle',\n        'all_inclusive',\n        'apartment',\n        'baby_changing_station',\n        'backpack',\n        'bathtub',\n        'beach_access',\n        'bento',\n        'business_center',\n        'carpenter',\n        'casino',\n        'charging_station',\n        'checkroom',\n        'child_care',\n        'child_friendly',\n        'corporate_fare',\n        'countertops',\n        'do_not_step',\n        'do_not_touch',\n        'dry',\n        'elevator',\n        'escalator',\n        'escalator_warning',\n        'family_restroom',\n        'fence',\n        'fire_extinguisher',\n        'fitness_center',\n        'food_bank',\n        'foundation',\n        'free_breakfast',\n        'golf_course',\n        'grass',\n        'hot_tub',\n        'house',\n        'house_siding',\n        'kitchen',\n        'meeting_room',\n        'microwave',\n        'night_shelter',\n        'no_cell',\n        'no_drinks',\n        'no_flash',\n        'no_food',\n        'no_meeting_room',\n        'no_photography',\n        'no_stroller',\n        'pool',\n        'rice_bowl',\n        'roofing',\n        'room_preferences',\n        'room_service',\n        'rv_hookup',\n        'smoke_free',\n        'smoking_rooms',\n        'soap',\n        'spa',\n        'sports_bar',\n        'stairs',\n        'storefront',\n        'stroller',\n        'tapas',\n        'tty',\n        'umbrella',\n        'wash',\n        'water_damage',\n        'wheelchair_pickup'\n    ],\n    'Social': [\n        '6_ft_apart',\n        'architecture',\n        'book_online',\n        'cake',\n        'clean_hands',\n        'connect_without_contact',\n        'construction',\n        'coronavirus',\n        'deck',\n        'domain',\n        'elderly',\n        'emoji_emotions',\n        'emoji_events',\n        'emoji_flags',\n        'emoji_food_beverage',\n        'emoji_nature',\n        'emoji_objects',\n        'emoji_people',\n        'emoji_symbols',\n        'emoji_transportation',\n        'engineering',\n        'fireplace',\n        'follow_the_signs',\n        'group',\n        'group_add',\n        'history_edu',\n        'king_bed',\n        'leave_bags_at_home',\n        'location_city',\n        'masks',\n        'military_tech',\n        'mood',\n        'mood_bad',\n        'nights_stay',\n        'notifications',\n        'notifications_active',\n        'notifications_none',\n        'notifications_off',\n        'notifications_paused',\n        'outdoor_grill',\n        'pages',\n        'party_mode',\n        'people',\n        'people_alt',\n        'people_outline',\n        'person',\n        'person_add',\n        'person_add_alt_1',\n        'person_outline',\n        'person_remove',\n        'plus_one',\n        'poll',\n        'psychology',\n        'public',\n        'public_off',\n        'reduce_capacity',\n        'sanitizer',\n        'school',\n        'science',\n        'self_improvement',\n        'sentiment_dissatisfied',\n        'sentiment_satisfied',\n        'sentiment_very_dissatisfied',\n        'sentiment_very_satisfied',\n        'share',\n        'sick',\n        'single_bed',\n        'sports',\n        'sports_baseball',\n        'sports_basketball',\n        'sports_cricket',\n        'sports_esports',\n        'sports_football',\n        'sports_golf',\n        'sports_handball',\n        'sports_hockey',\n        'sports_kabaddi',\n        'sports_mma',\n        'sports_motorsports',\n        'sports_rugby',\n        'sports_soccer',\n        'sports_tennis',\n        'sports_volleyball',\n        'thumb_down_alt',\n        'thumb_up_alt',\n        'whatshot'\n    ],\n    'Toggle': [\n        'check_box',\n        'check_box_outline_blank',\n        'indeterminate_check_box',\n        'radio_button_checked',\n        'radio_button_unchecked',\n        'star',\n        'star_border',\n        'star_half',\n        'star_outline',\n        'toggle_off',\n        'toggle_on'\n    ]\n}","import {\r\n    defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst buttonStyle = {\r\n    header: {\r\n        ...defaultFont,\r\n        display: 'flex',\r\n        width: '100%',\r\n        justifyContent: 'space-between'\r\n    },\r\n    content: {\r\n        position: 'relative',\r\n        width: '100%',\r\n        height: '100%',\r\n        display: 'flex',\r\n    },\r\n    info: {\r\n        display: 'flex',\r\n        width: '100%',\r\n        alignItems: 'center'\r\n    },\r\n    headerIcon: {\r\n        display: 'contents',\r\n        alignItems: 'center',\r\n    },\r\n    headerTitle: {\r\n        width: 'calc(100% - 33px)',\r\n        // marginLeft: '7px',\r\n        overflowX: 'hidden',\r\n        overflowY: 'hidden',\r\n        fontWeight: 'bold',\r\n        paddingTop: '3px',\r\n    },\r\n    actionButtons: {\r\n        // position: 'absolute',\r\n        // top: \"-9px\",\r\n        right: 0,\r\n        display: 'flex',\r\n    },\r\n    cancelButton: {\r\n        right: '4px',\r\n        position: 'absolute',\r\n        cursor: 'pointer',\r\n    },\r\n    saveButton: {\r\n        right: '33px',\r\n        position: 'absolute',\r\n        cursor: 'pointer',\r\n    },\r\n    button: {\r\n        padding: '3px auto',\r\n        cursor: 'pointer',\r\n        alignItems: 'center',\r\n        display: 'flex',\r\n        opacity: 1,\r\n        // backgroundColor: '#FFFFFF'\r\n        //transition: 'visibility 0.1s, opacity 0.5s linear'\r\n    },\r\n    parent: {\r\n        width: '100%',\r\n        padding: '0 5px',\r\n        '& .title': {\r\n            color: customApp('medium'),\r\n            fontSize: '10px',\r\n            textTransform: 'uppercase'\r\n        },\r\n        '& .info': {\r\n            marginTop: '-8px',\r\n            color: customApp('color'),\r\n            fontWeight: '500',\r\n            //display: 'flex',\r\n            alignItems: 'center',\r\n        }\r\n    },\r\n};\r\n\r\nexport default buttonStyle;\r\n","import React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport TextField from \"components/TextField\"\nimport SendingMessage from \"components/Timeline/sending.js\"\nimport PeriodFilter from \"components/Filter/period\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Icons from \"components/Icons\"\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\"\nimport Badge from \"components/Icon/Badge\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\n\nimport styles from \"assets/jss/material-dashboard-pro-react/components/headerWithIcon.js\"\n\n//FUNCTIONS\nimport { translate, customApp, Highlighted } from \"functions/\"\n\nconst useStyles = makeStyles(styles)\n\nfunction Component(props) {\n    const { session, functions } = reduxStore.getState()\n    const { socket } = functions\n    const classes = useStyles()\n    const [mounted, setMounted] = React.useState(false)\n    const [buttonsHover, setButtonsHover] = React.useState(false)\n    const [name, setName] = React.useState(props.title ? props.title.trim() : \"\")\n    const [icon, setIcon] = React.useState(props.icon || null)\n    const [prevIcon, setPrevIcon] = React.useState(props.icon || null)\n    const [editing, setEditing] = React.useState(false)\n    const [modMessageOpen, setModMessageOpen] = React.useState(false)\n\n    const customButtons = props.customButtons && props.customButtons.filter(bt => bt !== false)\n\n    React.useEffect(() => {\n        if (!mounted) {\n            if (!props.title && props.editable)\n                setEditing(true)\n            setMounted(true)\n        }\n    })\n\n    const stripHtml = (html) => {\n        let tmp = document.createElement(\"DIV\")\n        tmp.innerHTML = html\n        return tmp.textContent || tmp.innerText || \"\"\n    }\n\n    const saveName = async () => {\n        try {\n            if (props._id) {\n                socket.emit(\"data\", {\n                    module: \"node\",\n                    method: \"put\",\n                    action: \"update\",\n                    noLog: true\n                }, {\n                    _id: props._id,\n                    name,\n                })\n            }\n            if (props.onEdit)\n                props.onEdit({\n                    name,\n                    ...icon ? { icon: icon } : {}\n                }, props._id ? props._id : null)\n        } catch (e) {\n            console.log(e)\n        }\n        setEditing(false)\n    }\n\n\n    return (\n        <div\n            className={classes.header}\n            style={{\n                minHeight: '30px',\n                display: 'flex',\n                alignItems: 'center',\n                ...props.style,\n\n            }}\n            onMouseEnter={() => setButtonsHover(true)}\n            onMouseLeave={() => {\n                if (!modMessageOpen) {\n                    setButtonsHover(false)\n                }\n            }}\n        >\n            <div className={classes.content}>\n                <div className={classes.info}>\n                    {props.searchText ?\n                        <div style={{\n                            marginLeft: '7px',\n                        }}>\n                            {Highlighted(props.title ? props.title : '', props.searchText)}\n                        </div>\n                        :\n                        <div\n                            className={classes.headerTitle}\n                            style={{\n                                fontSize: props.fontSize ? props.fontSize : '16px',\n                                color: props.color ? props.color : customApp('colorText'),\n                                paddingRight: '7px',\n                                marginLeft: props.icon ? '7px' : 'none',\n                                width: \"100%\"\n                            }}\n                            onDoubleClick={() => {\n                                if (props.onEdit && props.editable) {\n                                    setName(props.title ? props.title.trim() : '')\n                                    setEditing(true)\n                                }\n                            }\n                            }\n                        >\n                            <div\n                                style={{\n                                    position: 'relative',\n                                    float: 'left',\n                                    width: '100%',\n                                    // paddingTop: '7px',\n                                    display: 'flex',\n                                    alignItems: \"center\"\n                                }}>\n                                {(props.icon || props.permitIcon || (props.iconOnEditable && editing)) ?\n                                    <Icons\n                                        icon={props.icon || 'perm_media'}\n                                        color={props.color ? props.color : customApp('colorText')}\n                                        onChange={(props.onChangeIcon || (props.editable && props.permitIcon)) ? (e) => {\n                                            if (props.onChangeIcon)\n                                                props.onChangeIcon(e)\n                                            if (props.onEdit) {\n                                                props.onEdit({\n                                                    name,\n                                                    ...e ? { icon: e } : {}\n                                                })\n                                            }\n                                            setIcon(e)\n                                        } : null}\n                                        size={`calc(${props.fontSize} + 4px)` || '25px'}\n                                        style={{ marginRight: 7 }}\n                                    />\n                                    : <React.Fragment></React.Fragment>\n                                }\n                                {(editing) ?\n                                    <React.Fragment>\n                                        <TextField\n                                            label={props.placeholder ? props.placeholder : translate('$__nameOfCard', 1)}\n                                            variant={customApp('fieldVariant')}\n                                            name={'name'}\n                                            InputLabelProps={{\n                                                shrink: true,\n                                            }}\n                                            InputProps={{\n                                                autoComplete: 'new-password',\n                                                onChange: (d) => {\n                                                    setName(d.target.value)\n                                                },\n                                                onKeyDown: (e) => {\n                                                    if (e.keyCode === 13 && name)\n                                                        saveName()\n                                                    if (e.keyCode === 27) {\n                                                        setEditing(false)\n                                                        setName(props.title ? props.title.trim() : '')\n                                                    }\n                                                }\n                                            }}\n                                            value={name}\n                                            placeholder={props.placeholder ? props.placeholder : translate('$__titleOfCard_placeholder', 1)}\n                                            autoFocus={props.noAutoFocus ? false : true}\n                                            multiline={props.multiline ? true : false}\n                                        />\n                                        {(editing || props.onSave) &&\n                                            <CustomButton\n                                                title={translate(`$__save`, 1)}\n                                                color='green'\n                                                icon={'save'}\n                                                onClick={() => {\n                                                    if (editing) {\n                                                        if (!props.noCancel) {\n                                                            saveName()\n                                                        } else {\n                                                            if (name)\n                                                                saveName()\n                                                        }\n                                                    } else {\n                                                        props.onSave()\n                                                    }\n                                                }}\n                                                size={props.actionsSize || '25px'}\n                                                transparent\n                                            />\n                                        }\n                                        {(editing || props.onCancel) &&\n                                            <CustomButton\n                                                title={translate(`$__close`, 1)}\n                                                color={customApp(\"colorText\")}\n                                                icon={'cancel'}\n                                                onClick={() => {\n                                                    if (editing) {\n                                                        if (!props.onCancel) {\n                                                            setEditing(false)\n                                                        } else {\n                                                            if (name)\n                                                                setEditing(false)\n                                                        }\n                                                    }\n                                                    if (props.onCancel)\n                                                        props.onCancel()\n                                                }\n                                                }\n                                                size={props.actionsSize || '25px'}\n                                                transparent\n                                            />\n                                        }\n                                    </React.Fragment>\n                                    :\n                                    <Tooltip\n                                        title={props.tooltipText ? props.tooltipText : props.title ? props.title : ''}\n                                    >\n                                        <div style={{\n                                            ...!props.expanded ? {\n                                                width: '100%',\n                                                textOverflow: 'ellipsis',\n                                                overflow: 'hidden',\n                                                whiteSpace: 'nowrap',\n                                            }\n                                                : {\n                                                    width: '100%',\n\n                                                }\n                                        }}>\n                                            {`${props.showOrder ? `${props.showOrder}. ` : ``}${props.title && props.title.indexOf('$__') > -1 ? translate(props.title, 1) : props.title ? stripHtml(props.title) : ''}`}\n                                        </div>\n                                    </Tooltip>\n                                }\n                            </div>\n                        </div>\n                    }\n                </div>\n                {props.periodFilter && session && session.period &&\n                    <div\n                        style={{\n                            display: \"flex\",\n                            whiteSpace: \"nowrap\",\n                            marginRight: 7\n                        }}>\n                        {translate(session.period)}\n                        <PeriodFilter\n                            style={{\n                                color: customApp('menu'),\n                                height: '20px',\n                                width: '20px'\n                            }}\n                        />\n                    </div>\n                }\n                <div\n                    className={classes.actionButtons}\n                    style={{ ...props.actionButtonsStyle ? props.actionButtonsStyle : {} }}\n                >\n                    {(props.actionsButtons && props.onSave) &&\n                        <CustomButton\n                            title={translate(`$__save`, 1)}\n                            color='green'\n                            icon={'save'}\n                            onClick={() => {\n                                if (editing) {\n                                    if (!props.noCancel) {\n                                        saveName()\n                                    } else {\n                                        if (name)\n                                            saveName()\n                                    }\n                                } else {\n                                    props.onSave()\n                                }\n                            }}\n                            size={props.actionsSize || '25px'}\n                            transparent\n                        />\n                    }\n                    {(props.actionsButtons && props.onCancel) &&\n                        <CustomButton\n                            title={translate(`$__close`, 1)}\n                            color='lightgrey'\n                            icon={'cancel'}\n                            onClick={() => {\n                                if (editing) {\n                                    if (!props.noCancel) {\n                                        setEditing(false)\n                                    } else {\n                                        if (name)\n                                            setEditing(false)\n                                    }\n                                } else {\n                                    props.onCancel()\n                                }\n                            }\n                            }\n                            size={props.actionsSize || '25px'}\n                            transparent\n                        />\n                    }\n                    {!editing && props.timelineMessage && buttonsHover &&\n                        <div className={classes.button}\n                            style={{\n                                opacity: buttonsHover ? '1' : '0'\n                            }}\n                        >\n                            <Badge\n                                overlap=\"rectangular\"\n                                onClick={() => setModMessageOpen(true)}\n                                icon={'add_comment'}\n                                size={'20px'}\n                                tooltipprops={modMessageOpen ? {\n                                    open: modMessageOpen,\n                                    disableFocusListener: true,\n                                    disableHoverListener: true,\n                                    disableTouchListener: true,\n                                    PopperProps: {\n                                        disablePortal: true,\n                                    },\n                                    interactive: true,\n                                } : {}}\n                                title={\n                                    modMessageOpen ?\n                                        <div style={{ position: 'relative', minWidth: '220px' }}>\n                                            <SendingMessage\n                                                nodeId={props._id}\n                                                onSending={() => {\n                                                    setButtonsHover(false)\n                                                    setModMessageOpen(false)\n                                                }}\n                                                onClose={() => {\n                                                    setModMessageOpen(false)\n                                                    setButtonsHover(false)\n                                                }}\n                                                relative\n                                                closeOption\n                                            />\n                                        </div>\n                                        : '$__addComment'\n                                }\n                            />\n                        </div>\n                    }\n\n                    {\n                        !editing && customButtons && customButtons.map((bt, i) => {\n                            if (bt && bt.component)\n                                return (\n                                    bt.component\n                                )\n                            return (\n                                bt && bt !== false && bt !== null && (buttonsHover || bt.show !== 'hover') &&\n                                <div key={i} className={classes.button}\n                                    {...bt.provided}\n                                >\n                                    <CustomButton\n                                        title={bt.title ? translate(bt.title, 1) : translate(bt.name, 1)}\n                                        color={customApp(bt.color || 'colorText')}\n                                        icon={bt.icon}\n                                        onClick={e => {\n                                            if (bt.onClick)\n                                                bt.onClick(e)\n                                        }\n                                        }\n                                        onMouseLeave={() => {\n                                            if (!modMessageOpen) {\n                                                setButtonsHover(false)\n                                            }\n                                        }}\n                                        onClose={bt.onClose ? () => {\n                                            if (bt.onClose) bt.onClose()\n                                            setButtonsHover(false)\n                                        } : null}\n                                        size={bt.actionsSize || '16px'}\n                                        transparent\n                                        badgeContent={bt.count ? bt.count : null}\n                                    />\n                                </div>\n                            )\n                        }\n                        )}\n                    {props.children}\n                </div>\n            </div >\n        </div>\n    )\n}\nconst mapStateToProps = (store) => ({\n    users: store.db.users,\n    groups: store.db.groups\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(Component)\n","//API\r\nimport apims from \"apims\"\r\n\r\nconst loadFiles = async (data) => {\r\n    const { ids, searchText, page = 0, limit = 20, asc = false, childrens = false } = data\r\n    let result = await new Promise(async (resolve, reject) => {\r\n        try {\r\n            let reqFiles = await apims.post(`/Files_List_V2/`,\r\n                {\r\n                    ids,\r\n                    type: data.type ? data.type : 'cards',\r\n                    limit,\r\n                    skip: page * limit\r\n                }\r\n            )\r\n            if (reqFiles && reqFiles.data) {\r\n                let data = reqFiles.data\r\n                resolve(data)\r\n            }\r\n        } catch (e) {\r\n            console.group('loadFiles::ERR::')\r\n            console.log(e)\r\n            console.groupEnd()\r\n            reject(true)\r\n        }\r\n\r\n    })\r\n    if (result)\r\n        return result\r\n}\r\n\r\nconst navFolders = async (data) => {\r\n    let result = await new Promise(async (resolve, reject) => {\r\n        try {\r\n            let reqFolders = await apims.post(`/Files_Folders/`,\r\n                {\r\n                    ids: data && data.ids ? data.ids : [],\r\n                    childrens: data && data.childrens ? data.childrens : false,\r\n                    types: data && data.types ? data.types : null\r\n                }\r\n            )\r\n            if (reqFolders && reqFolders.data) {\r\n                resolve(reqFolders.data)\r\n            }\r\n        } catch (e) {\r\n            console.group('loadFiles::ERR::')\r\n            console.log(e)\r\n            console.groupEnd()\r\n            reject(true)\r\n        }\r\n\r\n    })\r\n    if (result)\r\n        return result\r\n}\r\n\r\nconst navFiles = async (data) => {\r\n    const { ids, search, skip = null, limit = null, asc = false, childrens = false } = data\r\n    let result = await new Promise(async (resolve, reject) => {\r\n        try {\r\n            let reqFiles = await apims.post(`/Files_Nav/`,\r\n                {\r\n                    ids,\r\n                    skip,\r\n                    limit,\r\n                    search,\r\n                    asc,\r\n                    type: data.type ? data.type : 'cards',\r\n                    childrens\r\n                }\r\n            )\r\n            if (reqFiles && reqFiles.data) {\r\n                let data = reqFiles.data\r\n\r\n                resolve(data)\r\n            }\r\n        } catch (e) {\r\n            console.group('loadFiles::ERR::')\r\n            console.log(e)\r\n            console.groupEnd()\r\n            reject(true)\r\n        }\r\n\r\n    })\r\n    if (result)\r\n        return result\r\n}\r\n\r\nexport {\r\n    loadFiles,\r\n    navFiles,\r\n    navFolders\r\n}","import React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport Icon from \"components/Icon\"\nimport TextField from \"components/TextField/\"\n\n//@MATERIAL\nimport InputAdornment from '@material-ui/core/InputAdornment';\n\n//FUNCTIONS\nimport {\n    translate,\n} from \"functions/\"\n\nimport { customApp } from \"functions\"\n\nimport { navFolders } from \"functions/files\"\n\nfunction Navigation(props) {\n    const { db, session } = reduxStore.getState()\n    const [selectedParent, setSelectedParent] = React.useState(null)\n    const [cardType, setCardType] = React.useState(cardType)\n    const [files, setFiles] = React.useState([])\n    const [preloader, setPreloader] = React.useState(true)\n    const [folders, setFolders] = React.useState({})\n    const [searchFolder, setSearchFolder] = React.useState(\"\")\n\n    let idPlan = props.idPlan ? props.idPlan : null\n\n    React.useEffect(() => {\n        reqFolders({ id: idPlan })\n        navFolders()\n        return () => {\n            setFiles([])\n            setFolders({})\n            setPreloader(true)\n        }\n    }, [])\n\n    const reqFolders = async (data, fds) => {\n        let lf = await navFolders({\n            ids: data && data.id ? [data.id] : [],\n            childrens: false,\n            types: props && props.types ? props.types : null\n        })\n        if (lf) {\n            let ff = fds ? fds : folders\n            if (idPlan) {\n                ff = {\n                    ...ff,\n                    [idPlan]: {\n                        name: reduxStore.getState().db.cards[idPlan].name,\n                        parent: reduxStore.getState().db.cards[idPlan]._parent,\n                        private: null,\n                        type: \"plan\",\n                        _id: idPlan,\n                        open: true,\n                    }\n                }\n            }\n            lf.map(folder => {\n                ff = {\n                    ...ff,\n                    [folder._id]: {\n                        ...ff[folder._id] ? ff[folder._id] : {},\n                        ...folder,\n                    }\n                }\n            })\n            setFolders(ff)\n        }\n    }\n\n    const openFolder = async (data, option = false) => {\n        const { id = null, type = null } = data\n        let nFolders = folders\n\n        nFolders = {\n            ...nFolders,\n            [id]: {\n                ...nFolders[id],\n                open: option,\n                loading: true,\n            }\n        }\n        if (Object.keys(folders).filter(a => folders[a].parent === id).length === 0) {\n            reqFolders({ id, type }, nFolders)\n        } else {\n            setFolders(nFolders)\n        }\n    }\n\n    const RenderFolder = (folder, f) => (\n        <div\n            key={f}\n            style={{\n                position: \"relative\",\n                float: \"left\",\n                clear: \"both\",\n                cursor: \"pointer\",\n                borderLeft: \"solid 0.5px lightgray\",\n                paddingLeft: 7,\n                width: \"100%\",\n            }}\n            onClick={(e) => {\n                if (!folder.private ||\n                    (folder.private && reduxStore.getState().controls.lockPrivate)\n                ) {\n                    openFolder({\n                        id: f,\n                    }, folders[f] && folders[f].open ? false : true)\n                    setSelectedParent(f)\n                    if (props && props.onSelect)\n                        props.onSelect(folders[f])\n                } else {\n\n                }\n                e.preventDefault()\n                e.stopPropagation()\n            }}\n        >\n            <HeaderWithIcon\n                title={`${folder.private && !reduxStore.getState().controls.lockPrivate ? translate(\"$__private\") : folder.name}`}\n                tooltipText={`${folder.private && !reduxStore.getState().controls.lockPrivate ? translate(\"$__private\") : folder.name}`}\n                icon={(folder.private && !reduxStore.getState().controls.lockPrivate ? 'private_connectivity' : folder.type && db && db.dataType && db.dataType.filter(a => a.name === folder.type)[0].icon) || \"$__topic\"}\n                fontSize=\"12px\"\n                color={folder.private && !reduxStore.getState().controls.lockPrivate ? 'lightgray' : selectedParent && selectedParent === f ? customApp(\"color\") : customApp(\"gray\")}\n            />\n            {folders[f] && folders[f].open ? reqSubFolders(f) : <React.Fragment></React.Fragment>}\n        </div>\n    )\n\n    const reqSubFolders = (id = null) => {\n        return (\n            <div style={{\n                marginLeft: 7\n            }}>\n                {Object.keys(folders).filter(folder =>\n                (\n                    (\n                        !id\n                    )\n                    ||\n                    (\n                        id &&\n                        folders[folder].parent === id\n                    )\n                )\n                ).length > 0 ?\n                    Object.keys(folders).filter(folder =>\n                    (\n                        (\n                            !id\n                        )\n                        ||\n                        (\n                            id &&\n                            folders[folder].parent === id\n                        )\n                    )\n                    ).sort((a, b) => {\n                        console.log(folders[a])\n                        if (folders[a].step && folders[b].step && parseInt(folders[a].step) < parseInt(folders[b].step))\n                            return -1\n                        if (folders[a].step && folders[b].step && parseInt(folders[a].step) > parseInt(folders[b].step))\n                            return 1\n                        if (folders[a].name.toLowerCase().trim() < folders[b].name.toLowerCase().trim())\n                            return -1\n                        if (folders[a].name.toLowerCase().trim() > folders[b].name.toLowerCase().trim())\n                            return 1\n                        return 0\n                    }).map(f => {\n                        return RenderFolder(folders[f], f)\n                    }) : <React.Fragment></React.Fragment>\n                }\n            </div>\n        )\n    }\n\n    return (\n        <div >\n            <div style={{\n                position: \"relative\",\n                backgroundColor: \"#FFFFFF\",\n                clear: \"both\",\n                paddingTop: \"15px\"\n            }}>\n                <div>\n                    <div style={{ display: \"flex\", marginTop: -10 }}>\n                        {/* <HeaderWithIcon\n                            title={translate(\"$__selectLocation\", 1)}\n                            icon={\"touch_app\"}\n                            fontSize=\"20px\"\n                            color={customApp(\"menu\")}\n                        /> */}\n                        <TextField\n                            label={translate('$__search', '*')}\n                            variant={'standard'}\n                            autoFocus\n                            value={searchFolder}\n                            InputProps={{\n                                endAdornment: (\n                                    <InputAdornment position=\"start\">\n                                        <Icon color={customApp('lightgray')}>search</Icon>\n                                    </InputAdornment>\n                                ),\n                                onChange: e => {\n                                    setSearchFolder(e.target.value)\n                                },\n                                onKeyDown: e => {\n                                    // if (String(e.which) === '27')\n                                    //     setviewSearch(false)\n                                }\n                            }}\n                        />\n                    </div>\n                    <div style={{\n                        position: \"relative\",\n                        maxHeight: \"40vh\",\n                        overflowX: \"auto\",\n                        backgroundColor: \"rgba(250,250,250,0.9)\",\n                        borderRadius: \"solid 0.5px rgba(0,0,0,0.1)\",\n                        padding: 15\n                    }}>\n                        {/* {idPlan && Object.keys(navigation).map((nav, i) => {\n                            return (<div key={`${nav}-${i}`}\n                                style={{\n                                    cursor: \"pointer\"\n                                }}\n                                onClick={(e) => {\n                                    e.stopPropagation()\n                                    e.preventDefault()\n\n                                    setSelectedParent(nav)\n                                }}\n                            >\n                                <HeaderWithIcon\n                                    title={navigation[nav].name}\n                                    tooltipText={`${translate(`$__${navigation[nav].type}`, '*')} - ${navigation[nav].name}`}\n                                    icon={navigation[nav].icon ? navigation[nav].icon : (navigation[nav].type && db && db.dataType && db.dataType.filter(a => a.name === navigation[nav].type)[0].icon) || \"$__topic\"}\n                                    fontSize=\"12px\"\n                                    color={selectedParent === nav ? customApp(\"color\") : customApp(\"gray\")}\n                                />\n                            </div>)\n                        })} */}\n                        {Object.keys(folders).filter(folder =>\n                            folders[folder].type !== \"chatGroup\"\n                            && (\n                                (\n                                    (\n                                        !idPlan\n                                        ||\n                                        (\n                                            idPlan\n                                            && idPlan.length !== 36\n                                        )\n                                    )\n                                    &&\n                                    !folders[folder].parent\n                                )\n                                ||\n                                (\n                                    (\n                                        idPlan\n                                        && idPlan.length === 36\n                                    )\n                                    && (\n                                        (\n                                            folders[folder]._id === idPlan\n                                        )\n                                    )\n                                )\n                            )\n                            &&\n                            (\n                                searchFolder === \"\"\n                                ||\n                                (\n                                    searchFolder\n                                    && folders[folder].name.toLowerCase().indexOf(searchFolder.toLowerCase().trim()) > -1\n                                )\n                            )\n                        ).sort((a, b) => {\n                            if (folders[a].name.toLowerCase().trim() < folders[b].name.toLowerCase().trim())\n                                return -1\n                            if (folders[a].name.toLowerCase().trim() > folders[b].name.toLowerCase().trim())\n                                return 1\n                            return 0\n                        }).map(f => {\n                            return RenderFolder(folders[f], f)\n                        }\n                        )}\n                    </div>\n                </div>\n            </div>\n\n        </div >\n    )\n}\n\nconst mapStateToProps = (store) => ({\n    showPrivate: store.controls.lockPrivate\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(Navigation)","import React from 'react';\n\n//@MATERIAL\nimport LinearProgress from '@material-ui/core/LinearProgress';\nimport { makeStyles } from '@material-ui/core/styles';\n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\n\n\nfunction ProgressLinear(props) {\n    const styles = {\n        root: {\n            position: 'relative',\n            width: `100%`,\n            background: `transparent !important`,\n            '& .MuiLinearProgress-indeterminate': {\n                background: `transparent !important`\n            },\n            '& .MuiLinearProgress-bar': {\n                background: `${customApp('linearProgress')} !important`\n            },\n            '& .text': {\n                position: 'absolute',\n                width: '40px',\n                right: '-40px',\n                top: '-9px',\n                textAlign: 'right',\n                textSize: '11px',\n                fontWeight: 'bold',\n                color: customApp('color')\n            }\n        },\n        bar: {\n            borderRadius: 7,\n        },\n\n    }\n    const useStyles = makeStyles(styles);\n\n    const classes = useStyles();\n\n    let newProps = {\n        ...props\n    }\n    if (newProps.showText) delete newProps.showText\n    if (newProps.customColor) delete newProps.customColor\n\n    return (\n        <div className={classes.root} style={props.showText ? { width: `calc(100% - 40px)` } : {}}>\n            <LinearProgress {...newProps} />\n            {props.showText &&\n                <div className={'text'}>{Math.floor(props.value)}%</div>\n            }\n        </div>\n    )\n}\n\nexport default ProgressLinear","//@MATERIAL \nimport Checkbox from '@material-ui/core/Checkbox';\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\nconst Component = withStyles({\n    root: {\n        '&:hover': {\n            backgroundColor: 'transparent',\n        },\n        color: customApp('color'),\n    }\n})(Checkbox);\n\nexport default Component","import React from \"react\"\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//COMPONENTS\nimport Checkbox from \"components/Checkbox\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Icon from \"components/Icon\"\nimport TextField from \"components/TextField\";\n\n//DEPENDENCIES\nimport List from \"./avatarList\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\"\nimport ClickAwayListener from \"@material-ui/core/ClickAwayListener\"\nimport Grow from \"@material-ui/core/Grow\"\nimport Button from \"@material-ui/core/Button\"\nimport MenuItem from \"@material-ui/core/MenuItem\"\nimport MenuList from \"@material-ui/core/MenuList\"\nimport Paper from \"@material-ui/core/Paper\"\nimport Popper from \"@material-ui/core/Popper\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\nimport { makeStyles } from \"@material-ui/core/styles\"\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\n\n//FUNCTIONS\nimport {\n    getUserList,\n    getUserAccess\n} from \"functions/cards\"\n\nimport {\n    appAlert,\n    customApp,\n    getAppAccess,\n    translate,\n} from \"functions/\"\n\nimport {\n    cardsAccess,\n    isResponsible as setResponsible,\n    userParam as setUserParam,\n} from \"functions/users\"\n\nimport api from \"api/\"\nimport { setMyDay } from \"functions/cards\"\n\nconst useStyles = makeStyles((props) => ({\n    iconButtonStyleTransaparent: {\n        margin: 0,\n        \"&:hover\": {\n            backgroundColor: \"rgba(250,250,250,0.9)\"\n        },\n        \"& .MuiAvatarGroup-avatar\": {\n            border: 'none',\n            zIndex: 0\n        }\n    },\n    iconButtonStyleWhite: {\n        margin: 0,\n        backgroundColor: \"#FFFFFF\",\n        \"&:hover\": {\n            backgroundColor: \"rgba(250,250,250,0.9)\"\n        },\n        \"& .MuiAvatarGroup-avatar\": {\n            border: 'none',\n            zIndex: 0\n        }\n    },\n}))\n\nfunction Comp(props) {\n    const classes = useStyles()\n    const anchorRef = React.useRef(null)\n    const { db, session, functions } = reduxStore.getState()\n    const { data } = props\n    const [open, setOpen] = React.useState(!props.open ? false : true)\n    const [removeUsers, setRemoveUsers] = React.useState([])\n    const [myDayUsers, setMyDayUsers] = React.useState([])\n    const [searchValue, setSearchValue] = React.useState(\"\")\n    const [search, setSearch] = React.useState(false)\n    const [selectToMyDay, setSelectToMyDay] = React.useState(false)\n    const [userList, setUserList] = React.useState(getUserList(data._id))\n\n    React.useEffect(() => {\n        return () => { }\n    }, [])\n\n    let AppAccess = getAppAccess()\n    let CardAccess = getUserAccess(data._id)\n\n    let admin = false\n    if (CardAccess > 3)\n        admin = true\n\n    if (!admin && AppAccess.plan && AppAccess.planAdmin)\n        admin = true\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    const handleClose = (event) => {\n        setOpen(false)\n        setSelectToMyDay(false)\n        setMyDayUsers([])\n    }\n\n    function handleListKeyDown(event) {\n        if (event.key === \"Tab\") {\n            event.preventDefault()\n            setOpen(false)\n        }\n    }\n\n    const selectUser = async (id, acc) => {\n        let access = 1\n        if (data && data.type === 'plan')\n            access = 3\n\n        if (!acc) {\n            if (\n                data._planId\n                && db.cards[data._planId]\n                && db.cards[data._planId]._users\n                && db.cards[data._planId]._users[id]\n                && db.cards[data._planId]._users[id].access\n            ) {\n                if (data._parent\n                    && db.cards[data._parent]\n                    && db.cards[data._parent]._users\n                    && db.cards[data._parent]._users[id]\n                    && db.cards[data._parent]._users[id].access\n                    && parseInt(db.cards[data._parent]._users[id].access) > parseInt(db.cards[data._planId]._users[id].access)\n                ) {\n                    access = parseInt(db.cards[data._parent]._users[id].access)\n                } else {\n                    access = parseInt(db.cards[data._planId]._users[id].access)\n                }\n            }\n        } else {\n            access = acc\n        }\n        const noNotification = data && data._users && data._users[id] ? true : false\n        await cardsAccess(props, id, access, data._id, noNotification)\n    }\n\n    const deleteAccessUser = async (userId) => {\n        api.put(`cards/removeAccess/`, {\n            cardId: data._id,\n            userIds: removeUsers\n        })\n        setRemoveUsers([])\n    }\n\n    const sendToDay = async () => {\n        myDayUsers.map(s => {\n            setMyDay(props, {\n                _id: data._id,\n                userId: s,\n                option: true\n            })\n        })\n        setSelectToMyDay(false)\n    }\n\n\n    const validateUser = (pr) => {\n        let usersToRemove = Array.from(removeUsers)\n        if (data._users[pr] && usersToRemove.indexOf(pr) === -1) {\n            usersToRemove.push(pr)\n            setRemoveUsers(usersToRemove)\n            // setCountRemove(usersToRemove.length)\n        } else if (data._users[pr] && usersToRemove.indexOf(pr) > -1) {\n            usersToRemove.splice(usersToRemove.indexOf(pr), 1)\n            setRemoveUsers(usersToRemove)\n            // setCountRemove(usersToRemove.length)\n        } else if (!data._users[pr]) {\n\n            selectUser(pr)\n        }\n    }\n\n    // console.log(data)\n\n    const GroupMenuItem = (({ data }) => {\n        return (\n            <MenuItem\n            // onClick={userPermission ? () => {\n            // } : null}\n            // disabled={!userPermission}\n            >\n                {data.label}\n                <div style={{\n                    display: \"flex\",\n                    alignItems: \"center\",\n                    justifyContent: \"space-between\"\n                }}>\n                    {/* <CustomButton\n                        title={translate(!data._users[pr][props.customDefine.name] ? `$__defineAs${props.customDefine.name}` : `$__removeThe${props.customDefine.name}`, 1)}\n                        color={!data._users[pr][props.customDefine.name] ? \"green\" : \"red\"}\n                        icon={props.customDefine && props.customDefine.icon || \"check\"}\n                        onClick={() => {\n                            appAlert({\n                                message: translate(!data._users[pr][props.customDefine.name] ? `$__confirmSetAs${props.customDefine.name}` : `$__confirmUnSetAs${props.customDefine.name}`, 1),\n                                variant: 'warning',\n                                persist: false,\n                                horizontal: 'left',\n                                confirm: () => {\n                                    setUserParam(props, {\n                                        cardId: data._id,\n                                        userId: pr,\n                                        param: props.customDefine.name,\n                                        on: !data._users[pr][props.customDefine.name] ? true : false\n                                    })\n                                }\n                            })\n                        }}\n                        size={\"25px\"}\n                    /> */}\n                </div>\n\n            </MenuItem>\n        )\n    })\n\n    const UserMenuItem = ({ pr }) => {\n        let userPermission = false\n        if (props.permission)\n            userPermission = true\n        let myDay = false\n        if (data._users && data._users[pr] && data._users[pr].myDay\n            && data._users[pr].myDay\n            && moment(parseInt(data._users[pr].myDay) * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") === moment(new Date()).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\n        ) {\n            myDay = true\n        }\n        let isResponsible = Object.keys(userList).length > 1 && userList[pr] && userList[pr].isResponsible ? true : false\n        let customDefine = props.customDefine && props.customDefine.name && Object.keys(userList).length > 1 && userList[pr] && userList[pr][props.customDefine.name] ? true : false\n        let user = userList[pr] ? userList[pr] : data._users[pr]\n        return (\n            <MenuItem\n                onClick={userPermission ? () => {\n                } : null}\n                disabled={!userPermission}\n            >\n                <div style={{\n                    position: \"relative\",\n                    width: \"100%\",\n                    display: \"flex\",\n                    alignItems: \"center\",\n                    justifyContent: \"space-between\",\n                    ...!userPermission ? { cursor: \"pointer\" } : {}\n                }}>\n                    <div\n                        style={{\n                            width: \"33px\",\n                            height: \"33px\",\n                            borderRadius: \"50%\",\n                            ...!props.customDefine ? {\n                                border: isResponsible ? `3px deepskyblue solid` : myDay ? `2px #ff8800 solid` : `none`,\n                            } : {\n                                border: customDefine ? `3px green solid` : `none`,\n                            },\n                            backgroundImage: user.image ? `url(\"${user.image}\")` : `null`,\n                            backgroundSize: \"cover\",\n                            backgroundRepeat: \"no-repeat\",\n                            backgroundPosition: \"center center\",\n                            backgroundColor: \"lightgray\",\n                            textAlign: \"center\",\n                            marginRight: 7\n                        }}\n                        src={user.image || null} >\n                        {!user.image && user && user.name ? user.name.substr(0, 1) : \"\"}\n                    </div>\n                    {user.name || user.name}\n                    <div style={{\n                        display: \"flex\",\n                        alignItems: \"center\",\n                        justifyContent: \"space-between\"\n                    }}>\n                        {!props.customDefine && data._users[pr] && !data._users[pr].isResponsible && admin ?\n                            <CustomButton\n                                title={translate(`$__defineAsResponsible`, 1)}\n                                color={\"lightGray\"}\n                                icon={\"admin_panel_settings\"}\n                                onClick={() => {\n                                    appAlert({\n                                        message: translate('$__confirmSetAsResponsibleCard', 1),\n                                        variant: 'warning',\n                                        persist: false,\n                                        horizontal: 'left',\n                                        confirm: () => {\n                                            setResponsible(props, {\n                                                cardId: data._id,\n                                                userId: pr\n                                            })\n                                        }\n                                    })\n                                }}\n                                size={\"25px\"}\n                            />\n\n                            : <React.Fragment></React.Fragment>}\n\n                        {props.customDefine && data._users[pr] && admin ?\n                            <CustomButton\n                                title={translate(!data._users[pr][props.customDefine.name] ? `$__defineAs${props.customDefine.name}` : `$__removeThe${props.customDefine.name}`, 1)}\n                                color={!data._users[pr][props.customDefine.name] ? \"green\" : \"red\"}\n                                icon={props.customDefine && props.customDefine.icon || \"check\"}\n                                onClick={() => {\n                                    appAlert({\n                                        message: translate(!data._users[pr][props.customDefine.name] ? `$__confirmSetAs${props.customDefine.name}` : `$__confirmUnSetAs${props.customDefine.name}`, 1),\n                                        variant: 'warning',\n                                        persist: false,\n                                        horizontal: 'left',\n                                        confirm: () => {\n                                            setUserParam(props, {\n                                                cardId: data._id,\n                                                userId: pr,\n                                                param: props.customDefine.name,\n                                                on: !data._users[pr][props.customDefine.name] ? true : false\n                                            })\n                                        }\n                                    })\n                                }}\n                                size={\"25px\"}\n                            />\n\n                            : <React.Fragment></React.Fragment>}\n                        {!props.customDefine ?\n                            <Checkbox\n                                {...selectToMyDay ? {\n                                    checked: myDay || myDayUsers.indexOf(pr) > -1 ? true : false\n                                } : {\n                                    checked: data._users[pr] ? true : false\n                                }}\n                                disabled={selectToMyDay && myDay ? true : false}\n                                onClick={userPermission ? () => {\n                                    if (!selectToMyDay) {\n                                        validateUser(pr)\n                                    } else {\n                                        let mdu = Array.from(myDayUsers)\n                                        if (mdu.indexOf(pr) === -1) {\n                                            mdu.push(pr)\n                                        } else if (mdu.indexOf(pr) > -1) {\n                                            mdu.splice(mdu.indexOf(pr), 1)\n                                        }\n                                        setMyDayUsers(mdu)\n                                    }\n                                } : null}\n                                color=\"default\"\n                            />\n                            : <React.Fragment></React.Fragment>\n                        }\n                    </div>\n                    {removeUsers.indexOf(pr) > -1 &&\n                        <div style={{\n                            height: \"2px\",\n                            width: \"100%\",\n                            backgroundColor: \"red\",\n                            position: \"absolute\",\n                            top: \"50%\"\n                        }}>\n\n                        </div>\n                    }\n                </div>\n            </MenuItem>\n        )\n    }\n\n    return (\n        <div onClick={(e) => {\n            e.stopPropagation()\n        }}>\n            <Button\n                ref={anchorRef}\n                aria-controls={open ? \"menu-list-grow\" : undefined}\n                aria-haspopup=\"true\"\n                aria-label=\"menu\"\n                onClick={(e) => {\n                    if (\n                        (\n                            props.permission\n                        )\n                        ||\n                        (\n                            data && data._users && data._users[session._id] && data._users[session._id].access && parseInt(data._users[session._id].access) > 3\n                        )\n                    ) {\n                        setOpen((prevOpen) => !prevOpen)\n                        e.stopPropagation()\n                    }\n                }}\n                className={!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}\n            >\n                <List {...props} />\n            </Button>\n            <Popper\n                open={open}\n                anchorEl={anchorRef.current}\n                // role={undefined}\n                transition\n            >\n                {({ TransitionProps, placement }) => (\n                    <Grow\n                        {...TransitionProps}\n                        style={{ transformOrigin: placement === \"bottom\" ? \"center top\" : \"center bottom\", maxHeight: \"333px\", minHeight: \"50px\", overflowY: \"auto\" }}\n                    >\n                        <Paper>\n                            <div style={{\n                                position: \"relative\",\n                                width: \"100%\",\n                                paddingBottom: ((removeUsers && removeUsers.length > 0) || (myDayUsers && myDayUsers.length > 0)) ? \"50px\" : 0,\n                                width: \"100%\",\n                                display: \"flex\",\n                                justifyContent: \"space-between\"\n                            }}\n                            >\n                                <ClickAwayListener\n                                    onClickAway={() => {\n                                        handleClose()\n                                    }}>\n                                    <div>\n                                        {search &&\n                                            <div style={{\n                                                position: \"relative\",\n                                                marginTop: 15,\n                                                width: \"100%\",\n                                                padding: \"4px 15px\",\n                                                fontSize: \"16px\",\n                                                color: \"lightGray\"\n                                            }}>\n                                                <TextField\n                                                    id={`quickUser_Search`}\n                                                    label={translate('$__searchByName', 1)}\n                                                    variant={customApp('fieldVariant')}\n                                                    name={'fullName'}\n                                                    InputLabelProps={{\n                                                        shrink: true,\n                                                    }}\n                                                    InputProps={{\n                                                        autoComplete: 'new-password',\n                                                        endAdornment: (\n                                                            <InputAdornment position=\"end\"\n                                                                style={{ cursor: \"pointer\" }}\n                                                                onClick={() => {\n                                                                    setSearchValue(\"\")\n                                                                    setSearch(false)\n                                                                }}>\n                                                                <Icon icon='close' />\n                                                            </InputAdornment>\n                                                        ),\n                                                        onChange: (d) => {\n                                                            setSearchValue(d.target.value)\n                                                        },\n                                                        onBlur: (d) => {\n\n                                                        }\n                                                    }}\n                                                    value={searchValue}\n                                                    placeholder={translate('$__searchByName', 1)}\n                                                    autoFocus\n                                                />\n                                            </div>\n                                        }\n                                        <MenuList autoFocusItem={open} id=\"menu-list-grow\" onKeyDown={handleListKeyDown}>\n                                            {selectToMyDay ?\n                                                <div style={{ position: \"relative\", overflow: \"auto\" }}>\n                                                    <MenuItem\n                                                        disabled\n                                                    >{translate(\"$__selectUsersToMyDay\", \"*\")}</MenuItem>\n                                                    {Object.keys(data._users)\n                                                        .filter(a =>\n                                                            a !== session._id\n\n                                                        )\n                                                        .sort((a, b) => {\n                                                            if (data._users[a]?.name && data._users[b]?.name && data._users[a].name.toLowerCase() < data._users[b].name.toLowerCase())\n                                                                return -1\n                                                            else if (data._users[a]?.name && data._users[b]?.name && data._users[a].name.toLowerCase() > data._users[b].name.toLowerCase())\n                                                                return 1\n                                                            return 0\n                                                        }).map(pr => <UserMenuItem pr={pr} key={pr} />)}\n                                                </div>\n                                                :\n                                                <div>\n                                                    {props.types && props.types.indexOf(\"teams\") > -1 ?\n                                                        <React.Fragment>\n                                                            <MenuItem\n                                                                disabled\n                                                            >{translate(\"$__usersGroups\", \"*\")}</MenuItem>\n                                                            {console.log(reduxStore.getState().db.userGroup)}\n                                                            {reduxStore.getState().db.userGroup.map(group => {\n                                                                return (\n                                                                    <GroupMenuItem data={group} key={group.value} />\n                                                                )\n                                                            })}\n                                                        </React.Fragment>\n                                                        : <React.Fragment></React.Fragment>}\n                                                    <MenuItem\n                                                        disabled\n                                                    >{translate(\"$__users\", \"*\")}</MenuItem>\n                                                    {Object.keys(userList).filter(a => {\n                                                        if (\n                                                            (!searchValue ||\n                                                                (\n                                                                    searchValue &&\n                                                                    userList[a].name.toLowerCase().indexOf(searchValue.toLowerCase()) > -1\n                                                                ))\n                                                            && userList[a].type === \"user\"\n                                                            && !userList[a].deleted\n                                                            && !userList[a]._parent\n                                                            && (\n                                                                !props.customDefine\n                                                                ||\n                                                                (props.customDefine\n                                                                    && data._users[a]\n                                                                )\n                                                            )\n                                                        ) return true\n                                                    }).sort((a, b) => {\n                                                        if (userList[a].name < userList[b].name)\n                                                            return -1\n                                                        else if (userList[a].name > userList[b].name)\n                                                            return 1\n                                                        return 0\n                                                    }).map(pr =>\n                                                        userList && userList[pr] && userList[pr]._id &&\n                                                        <UserMenuItem pr={pr} key={pr} />\n                                                    )}\n                                                    {\n                                                        Object.keys(userList).filter(a => {\n                                                            if (\n                                                                (!searchValue ||\n                                                                    (\n                                                                        searchValue &&\n                                                                        userList[a].name.toLowerCase().indexOf(searchValue.toLowerCase()) > -1\n                                                                    ))\n                                                                && userList[a].type === \"external\"\n                                                                && !userList[a].deleted\n                                                                && (\n                                                                    !props.customDefine\n                                                                    ||\n                                                                    (props.customDefine\n                                                                        && data._users[a]\n                                                                    )\n                                                                )\n                                                            ) return true\n                                                        }).length > 0 &&\n                                                        <MenuItem\n                                                            disabled\n                                                        >{translate(\"$__UnityUsers\", \"*\")}</MenuItem>\n                                                    }\n                                                    {Object.keys(userList).filter(a => (\n                                                        (!searchValue ||\n                                                            (\n                                                                searchValue &&\n                                                                userList[a].name.toLowerCase().indexOf(searchValue.toLowerCase()) > -1\n                                                            ))\n                                                        && userList[a].type === \"external\"\n                                                        && !userList[a].deleted\n                                                        && (\n                                                            !props.customDefine\n                                                            ||\n                                                            (props.customDefine\n                                                                && data._users[a]\n                                                            )\n                                                        )\n                                                    )).sort((a, b) => {\n                                                        if (userList[a].name < userList[b].name)\n                                                            return -1\n                                                        else if (userList[a].name > userList[b].name)\n                                                            return 1\n                                                        return 0\n                                                    }).map(pr =>\n                                                        userList && userList[pr] && userList[pr]._id &&\n                                                        <UserMenuItem pr={pr} key={pr} />\n                                                    )}\n                                                    {\n                                                        Object.keys(userList).filter(a => {\n                                                            if (\n                                                                (!searchValue ||\n                                                                    (\n                                                                        searchValue &&\n                                                                        userList[a].name.toLowerCase().indexOf(searchValue.toLowerCase()) > -1\n                                                                    ))\n                                                                &&\n                                                                userList[a].type === \"consultant\"\n                                                                && !userList[a].deleted\n                                                                && (\n                                                                    !props.customDefine\n                                                                    ||\n                                                                    (props.customDefine\n                                                                        && data._users[a]\n                                                                    )\n                                                                )\n                                                            ) return true\n                                                        }).length > 0 &&\n                                                        <MenuItem\n                                                            disabled\n                                                        >{translate(\"$__planningUsers\", \"*\")}</MenuItem>\n                                                    }\n                                                    {Object.keys(userList).filter(a => {\n                                                        if (\n                                                            (!searchValue ||\n                                                                (\n                                                                    searchValue &&\n                                                                    userList[a].name.toLowerCase().indexOf(searchValue.toLowerCase()) > -1\n                                                                ))\n                                                            &&\n                                                            userList[a].type === \"consultant\"\n                                                            && !userList[a].deleted\n                                                            && (\n                                                                !props.customDefine\n                                                                ||\n                                                                (props.customDefine\n                                                                    && data._users[a]\n                                                                )\n                                                            )\n                                                        ) return true\n                                                    }).sort((a, b) => {\n                                                        if (userList[a].name < userList[b].name)\n                                                            return -1\n                                                        else if (userList[a].name > userList[b].name)\n                                                            return 1\n                                                        return 0\n                                                    }).map(pr =>\n                                                        userList && userList[pr] && userList[pr]._id &&\n                                                        <UserMenuItem pr={pr} key={pr} />\n                                                    )}\n                                                </div>\n                                            }\n                                        </MenuList>\n                                        {(!search && !selectToMyDay) ?\n                                            <div\n                                                style={{\n                                                    position: \"absolute\",\n                                                    right: 15,\n                                                    top: 10,\n                                                }}\n                                            >\n                                                <CustomButton\n                                                    title={translate(`$__searchUser`, 1)}\n                                                    color={customApp(\"menu\")}\n                                                    icon={\"search\"}\n                                                    onClick={() => { setSearch(true) }}\n                                                    size={\"25px\"}\n                                                />\n                                            </div>\n                                            :\n                                            <React.Fragment></React.Fragment>\n                                        }\n                                        {(!props.customDefine && !search && !selectToMyDay && admin) ?\n                                            <div\n                                                style={{\n                                                    position: \"absolute\",\n                                                    right: 45,\n                                                    top: 10,\n                                                }}\n                                            >\n                                                <CustomButton\n                                                    title={translate(`$__sendToMyDay`, 1)}\n                                                    color={'orange'}\n                                                    icon={\"schedule_send\"}\n                                                    onClick={() => { setSelectToMyDay(true) }}\n                                                    size={\"25px\"}\n                                                />\n                                            </div>\n                                            : selectToMyDay ?\n                                                <div\n                                                    style={{\n                                                        position: \"absolute\",\n                                                        right: 15,\n                                                        top: 10,\n                                                    }}\n                                                >\n                                                    <CustomButton\n                                                        title={translate(`$__back`, 1)}\n                                                        color={customApp(\"menu\")}\n                                                        icon={\"arrow_back\"}\n                                                        onClick={() => { setSelectToMyDay(false) }}\n                                                        size={\"25px\"}\n                                                    />\n                                                </div>\n                                                : <React.Fragment></React.Fragment>\n                                        }\n                                    </div>\n                                </ClickAwayListener>\n                            </div>\n                            {removeUsers && removeUsers.length > 0 &&\n                                <div style={{\n                                    position: \"absolute\",\n                                    bottom: \"0px\",\n                                    padding: \"7px\",\n                                    backgroundColor: \"red\",\n                                    width: \"100%\",\n                                    display: \"flex\",\n                                    justifyContent: \"space-between\",\n                                    color: \"#FFFFFF\",\n                                    alignItems: \"center\",\n                                    zIndex: 10\n                                }}\n                                    onClick={(e => {\n                                        e.preventDefault()\n                                        e.stopPropagation()\n                                    })}\n                                >\n                                    {translate(\"$__confirmSelectedUsersRemove\")}\n                                    <CustomButton\n                                        title={translate(`$__remove`, 1)}\n                                        color=\"#FFFFFF\"\n                                        icon={\"delete_forever\"}\n                                        onClick={() => {\n                                            deleteAccessUser()\n                                        }}\n                                        size={\"25px\"}\n                                        transparent\n                                    />\n                                </div>\n                            }\n                            {selectToMyDay && myDayUsers && myDayUsers.length > 0 &&\n                                <div style={{\n                                    position: \"absolute\",\n                                    bottom: \"0px\",\n                                    padding: \"7px\",\n                                    backgroundColor: \"orange\",\n                                    width: \"100%\",\n                                    display: \"flex\",\n                                    justifyContent: \"space-between\",\n                                    color: \"#FFFFFF\",\n                                    alignItems: \"center\",\n                                }}\n                                    onClick={(e => {\n                                        e.preventDefault()\n                                        e.stopPropagation()\n                                    })}\n                                >\n                                    <AvatarGroup\n                                        style={{\n                                            flexWrap: \"wrap\"\n                                        }}\n                                    >\n                                        {myDayUsers\n                                            .map((a, i) => {\n                                                if (a && reduxStore.getState().db.users[a]) {\n                                                    return (\n                                                        <Tooltip\n                                                            title={reduxStore.getState().db.users[a].name}\n                                                            key={a}\n                                                        >\n                                                            <Avatar\n                                                                alt={reduxStore.getState().db.users[a].name}\n                                                                src={reduxStore.getState().db.users[a].image || null}\n                                                                style={{\n                                                                    width: \"23px\",\n                                                                    height: \"23px\"\n                                                                }}>\n                                                                {reduxStore.getState().db.users[a].name.substr(0, 1)}\n                                                            </Avatar>\n                                                        </Tooltip>\n                                                    )\n                                                } else {\n                                                    return (<React.Fragment></React.Fragment>)\n                                                }\n                                            })}\n                                    </AvatarGroup>\n                                    <CustomButton\n                                        title={translate(`$__sendToMyDay`, 1)}\n                                        color=\"#FFFFFF\"\n                                        icon={\"schedule_send\"}\n                                        onClick={() => {\n                                            sendToDay()\n                                        }}\n                                        size={\"25px\"}\n                                        transparent\n                                    />\n                                </div>\n                            }\n                        </Paper>\n                    </Grow>\n                )}\n            </Popper>\n        </div>\n    )\n}\nconst mapStateToProps = (store, props) => {\n    return ({\n        data: store.db.cards[props._id] ? store.db.cards[props._id] : {},\n        store: {\n            users: store.db.users\n        }\n    })\n}\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Comp)","import React from \"react\"\nimport moment from \"moment-timezone\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\n\nimport QuickUsers from \"./quick\"\n\n\nimport {\n    translate,\n} from \"functions/\"\n\n\nfunction AvatarList(props) {\n    const { data } = props\n    // console.log(data)\n\n    return (\n        <div>\n            {Object.keys(data._users)\n                .filter(u =>\n                    String(u) !== \"null\"\n                    && (\n                        !props.customDefine\n                        ||\n                        (\n                            props.customDefine\n                            && data._users[u][props.customDefine.name]\n                        )\n                    )\n                ).length === 0 ?\n                translate(\"$__selectUsers\")\n                :\n                <div\n                    style={{\n                        display: \"flex\"\n                    }}\n                >\n                    {Object\n                        .keys(data._users)\n                        .filter(u =>\n                            String(u) !== \"null\"\n                            && (\n                                !props.customDefine\n                                ||\n                                (\n                                    props.customDefine\n                                    && data._users[u][props.customDefine.name]\n                                )\n                            )\n                        )\n                        .sort((a, b) => {\n                            if (data._users[a].isResponsible)\n                                return -1\n                            if (data._users[b].isResponsible)\n                                return 1\n                            if (data._users[a].name < data._users[b].name)\n                                return -1\n                            if (data._users[a].name > data._users[b].name)\n                                return 1\n                            return 0\n                        })\n                        .map((a, i) => {\n                            let myDay = false\n                            let isResponsible = Object.keys(data._users).length > 1 && data._users[a].isResponsible ? true : false\n                            let customDefine = props.customDefine && props.customDefine.name ? Object.keys(data._users).length > 1 && data._users[a][props.customDefine.name] ? true : false : false\n                            if (data._users[a].myDay\n                                && data._users[a].myDay\n                                && moment(parseInt(data._users[a].myDay) * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") === moment(new Date()).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\n                            ) {\n                                myDay = true\n                            }\n                            if (data._users[a] && data._users[a].name) {\n                                let limit = props.noLimit ? 7 : props.limit ? props.limit : 7\n                                if (i < limit) {\n                                    return (\n                                        <div key={a} style={{ marginLeft: -7, position: \"relative\" }}>\n                                            <Tooltip\n                                                title={`${data._users[a].name}${myDay ? ` (${translate(\"$__inMyDay\")})` : ``}`}\n                                                key={a}\n                                            >\n                                                <div\n                                                    overlap=\"circular\"\n                                                    alt={data._users[a].name}\n                                                    src={data._users[a].image || null}\n                                                    style={{\n                                                        width: myDay || isResponsible ? '30px' : props.avatarSize ? props.avatarSize : \"24px\",\n                                                        height: myDay || isResponsible ? '30px' : props.avatarSize ? props.avatarSize : \"24px\",\n                                                        borderRadius: \"50%\",\n                                                        ...!props.customDefine ? {\n                                                            border: isResponsible ? `3px deepskyblue solid` : myDay ? `2px #ff8800 solid` : `none`,\n                                                        } : {\n                                                            border: customDefine ? props.customDefine.avatarBorder || `3px green solid` : `none`,\n                                                        },\n                                                        backgroundImage: data._users[a].image ? `url(\"${data._users[a].image}\")` : `null`,\n                                                        backgroundSize: \"cover\",\n                                                        backgroundRepeat: \"no-repeat\",\n                                                        backgroundPosition: \"center center\",\n                                                        backgroundColor: \"lightgray\",\n                                                        textAlign: \"center\",\n                                                    }}>\n                                                    {!data._users[a].image ? data._users[a].name.substr(0, 1) : ``}\n                                                </div>\n                                            </Tooltip>\n                                            {myDay &&\n                                                <div style={{\n                                                    position: \"absolute\",\n                                                    backgroundColor: \"#ff8800\",\n                                                    width: \"14px\",\n                                                    height: \"14px\",\n                                                    borderRadius: \"14px\",\n                                                    display: \"flex\",\n                                                    alignItems: \"center\",\n                                                    justifyContent: \"center\",\n                                                    right: \"7px\",\n                                                    bottom: 0,\n                                                }}>\n                                                    <Icon icon={\"hourglass_top\"} size=\"10px\" color=\"#FFFFFF\" />\n                                                </div>\n                                            }\n                                        </div>\n                                    )\n                                } else if (i === limit) {\n                                    let count = Object.keys(data._users).length - limit\n                                    return (\n                                        <Tooltip\n                                            title={(\n                                                <ul style={{ listingStyle: \"none\", padding: 0 }}>\n                                                    {Object.keys(data._users)\n                                                        .sort((a, b) => {\n                                                            if (data._users[a].isResponsible)\n                                                                return -1\n                                                            if (data._users[b].isResponsible)\n                                                                return 1\n                                                            if (data._users[a].name < data._users[b].name)\n                                                                return -1\n                                                            if (data._users[a].name > data._users[b].name)\n                                                                return 1\n                                                            return 0\n                                                        })\n                                                        .map((aa, aai) => {\n                                                            let myDayS = false\n                                                            if (data._users[aa].myDay\n                                                                && data._users[aa].myDay\n                                                                && moment(parseInt(data._users[aa].myDay) * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") === moment(new Date()).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\n                                                            ) {\n                                                                myDayS = true\n                                                            }\n                                                            if (aai >= limit &&\n                                                                data._users[aa] &&\n                                                                data._users[aa].name\n                                                            )\n                                                                return (\n                                                                    <li key={aa} style={{ display: \"flex\", alignItems: \"center\" }}>\n                                                                        <Avatar\n                                                                            overlap=\"circular\"\n                                                                            alt={data._users[aa].name}\n                                                                            src={data._users[aa].image || null}\n                                                                            style={{\n                                                                                width: props.avatarSize ? props.avatarSize : \"22px\",\n                                                                                height: props.avatarSize ? props.avatarSize : \"22px\",\n                                                                                border: data._users[aa].isResponsible ? `3px deepskyblue solid` : data._users[aa].myDay ? `2px #ff8800 solid` : `none`,\n                                                                                ...!props.customDefine ? {\n                                                                                    border: data._users[aa].isResponsible ? `3px deepskyblue solid` : data._users[aa].myDay ? `2px #ff8800 solid` : `none`,\n                                                                                } : {\n                                                                                    border: data._users[aa][props.customDefine.name] ? `3px green solid` : `none`,\n                                                                                },\n                                                                                marginRight: 7\n                                                                            }}>\n                                                                            {data._users[aa].name.substr(0, 1)}\n                                                                        </Avatar>{data._users[aa].name}\n                                                                    </li>)\n                                                        })}\n                                                </ul>\n                                            )}\n                                            key={i}\n                                        >\n                                            <Avatar style={{\n                                                width: props.avatarSize ? props.avatarSize : 27,\n                                                height: props.avatarSize ? props.avatarSize : 27,\n                                                border: 'none'\n                                            }} alt={`+${count}`} >\n                                                <span style={{ fontSize: 10 }}>{`+${count}`}</span>\n                                            </Avatar>\n                                        </Tooltip>\n                                    )\n                                }\n                            }\n                        })}\n                </div>\n            }\n\n        </div>\n    )\n}\n\nexport default AvatarList","//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = theme => {\r\n    return ({\r\n        root: {\r\n            position: 'relative',\r\n            // display: 'flex',\r\n            // justifyContent: 'center',\r\n            // maxWidth: '100%'\r\n        },\r\n        timeInfo: {\r\n            display: 'flex',\r\n            alignItems: 'center',\r\n            color: 'grey',\r\n            width: 'calc(100% - 15px)',\r\n            position: 'relative',\r\n            float: 'left',\r\n            marginBottom: '7px',\r\n            '& .text': {\r\n                marginLeft: '7px',\r\n            }\r\n        },\r\n        dataSave: {\r\n            padding: '7px'\r\n        },\r\n        fieldSet: {\r\n            padding: '7px',\r\n            width: 'calc(100% - 50px)'\r\n        },\r\n        progress: {\r\n            //width: 'calc(100% - 50px)',\r\n        },\r\n        progressPercentage: {\r\n            //width: '45px',\r\n        }\r\n    })\r\n}\r\n\r\nexport default style;","import React from \"react\";\nimport { v4 as uuid } from \"uuid\";\n\n//COMPONENTS\nimport TextField from \"components/TextField\";\nimport CustomButton from \"components/Buttons/custom\";\n\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\"\n\n//FUNCTIONS\nimport { translate, customApp, appAlert, formatNumber } from \"functions/\";\nimport { kpiTimerDelete } from \"functions/cards\";\n\nimport api from \"api\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/KPI_change.js\";\n\nimport \"assets/css/components/chart.css\";\nrequire(\"chartist-plugin-tooltips\");\n\nconst Component = (props) => {\n    const { classes } = props\n    const { socket } = reduxStore.getState().functions\n    const [reqSave, setReqSave] = React.useState(false)\n    const [description, setDescription] = React.useState('')\n    const [value, setValue] = React.useState(0)\n\n    const timer = props.timer || {}\n    const data = props.data || {}\n\n    const changeKPI = async (d, b) => {\n        setReqSave(true)\n        let newValue = String(value)\n        if (d.key.toLowerCase() === 'backspace') {\n            newValue = newValue.substr(0, newValue.length - 1)\n        } else {\n            newValue = `${newValue ? newValue : ``}${!isNaN(d.key) || ((d.key === ',' || d.key === '.') && newValue.indexOf(',') === -1 && newValue.indexOf('.') === -1) ? d.key : ``}`\n        }\n        if (newValue && newValue.indexOf(',') > -1)\n            newValue = newValue.substr(0, newValue.indexOf(',') + 3)\n\n        setValue(newValue)\n    }\n\n    if (!data)\n        return (null)\n\n    const cancel = () => {\n        if (props.callBack)\n            props.callBack()\n    }\n    const save = async () => {\n        if (!props.timer && !description) {\n            appAlert({\n                message: translate('$__fillDescription', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'center',\n            })\n        } else {\n            let newValue = isNaN(value) ? value.replace(',', '.') : value\n            let dataSave = {\n                _id: uuid(),\n                cardId: data._id,\n                idRel: data._id,\n                value: !props.PositiveValue ? `-${newValue}` : newValue,\n                type: 'kpi',\n                ...props.manualEntry ? { manualEntry: true } : {},\n                kpi_type: data.kpi_type ? data.kpi_type : null,\n                message: description || ''\n            }\n            if (props.timer)\n                dataSave = {\n                    ...dataSave,\n                    value: timer.diff,\n                    ini: timer.created_at,\n                    fin: timer.updated_at,\n                    type: 'timer',\n                    kpi_type: 'timer',\n                    to: timer.to\n                }\n            // socket.emit(\"data\",\n            //     {\n            //         module: \"timeline\",\n            //         method: \"post\",\n            //         action: \"add\"\n            //     },\n            //     {\n            //         ...dataSave\n            //     })\n\n            api.post(\"timeline/add\", {\n                ...dataSave\n            })\n\n            if (props.callBack)\n                props.callBack()\n            if (props.timer && !props.manualAdd)\n                kpiTimerDelete(props, data._id, timer._id)\n\n            setValue(0)\n            setDescription('')\n        }\n    }\n\n    if (!props.data)\n        return (<div>NO DATA RECEIVED</div>)\n\n    return (\n        <div className={classes.dataSave}>\n            <fieldset>\n                <legend\n                    style={{ color: customApp('color') }}>\n                    {translate('$__new', 1)}\n                </legend>\n                {!props.timer &&\n                    <TextField\n                        placeholder={translate('$__value', 1)}\n                        value={formatNumber(value ? value : 0, data.kpi_type === 'time' ? 'number' : data.kpi_type, data.kpi_currency ? data.kpi_currency : null)}\n                        InputLabelProps={{\n                            shrink: true,\n                        }}\n                        InputProps={{\n                            onKeyDown: (d) => {\n                                changeKPI(d, 'ini')\n                            },\n                        }}\n                    />\n                }\n                <TextField\n                    multiline\n                    placeholder={translate('$__description', 1)}\n                    onChange={(e) => setDescription(e.target.value)}\n                    value={description}\n                    InputProps={{\n                        autoComplete: 'new-password',\n                    }}\n                />\n                <div style={{ display: 'flex', textAlign: 'right' }}>\n                    <CustomButton\n                        title={translate(`$__save`, 1)}\n                        color='green'\n                        icon={'save'}\n                        onClick={() => save()}\n                        size={'25px'}\n                        transparent\n                    />\n                    {(!props.timer || props.manualAdd) &&\n                        <CustomButton\n                            title={translate(`$__cancel`, 1)}\n                            color='lightgrey'\n                            icon={'cancel'}\n                            onClick={() => cancel()}\n                            size={'25px'}\n                            transparent\n                        />\n                    }\n                </div>\n            </fieldset>\n        </div>\n    );\n}\n//REACT\nconst mapStateToProps = (store) => ({});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","import React from \"react\"\n\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport TextField from \"components/TextField\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\"\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener'\nimport Grow from '@material-ui/core/Grow'\nimport Button from '@material-ui/core/Button'\nimport MenuItem from '@material-ui/core/MenuItem'\nimport MenuList from '@material-ui/core/MenuList'\nimport Paper from '@material-ui/core/Paper'\nimport Popper from '@material-ui/core/Popper'\nimport Dialog from '@material-ui/core/Dialog'\nimport Tooltip from \"@material-ui/core/Tooltip\"\nimport { makeStyles } from '@material-ui/core/styles'\nimport FormControlLabel from '@material-ui/core/FormControlLabel'\nimport RadioGroup from '@material-ui/core/RadioGroup'\nimport { withStyles } from \"@material-ui/core/styles\"\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\n\n//FUNCTIONS\nimport {\n    getUserList,\n    getUserAccess\n} from \"functions/cards\"\n\nimport {\n    translate,\n    customApp,\n} from \"functions/\"\n\nimport {\n    getAdminList\n} from \"functions/users\"\n\n\nconst useStyles = makeStyles((props) => ({\n    iconButtonStyleTransaparent: {\n        margin: 0,\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        }\n    },\n    iconButtonStyleWhite: {\n        margin: 0,\n        backgroundColor: '#FFFFFF',\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        }\n    },\n}))\n\nfunction Comp(props) {\n    const classes = useStyles()\n    const [open, setOpen] = React.useState(false)\n    const anchorRef = React.useRef(null)\n    const { data } = props\n    const { db, session, functions, sideModule } = reduxStore.getState()\n    const [removeUsers, setRemoveUsers] = React.useState([])\n    const [selectedUser, setSelectedUser] = React.useState(props.selected ? props.selected : [])\n    const [searchValue, setSearchValue] = React.useState(\"\")\n\n    const userList = props.admins\n        ? getAdminList(data\n            && data._id\n            ? data._id\n            : null,\n            null,\n            {\n                onlyCard: data\n                    && data._id\n                    ? true\n                    : false\n            })\n        : getUserList(data\n            && data._id\n            ? data._id\n            : null,\n            {\n                onlyCard:\n                    data\n                        && data._id\n                        ? true\n                        : false\n            })\n\n    let CardAccess = sideModule && sideModule.id ? getUserAccess(sideModule.id) : 0\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return\n        }\n\n        setOpen(false)\n    }\n\n    function handleListKeyDown(event) {\n        if (event.key === 'Tab') {\n            event.preventDefault()\n            setOpen(false)\n        }\n    }\n\n    const selectUser = async (id) => {\n        let selectedUsers = Array.from(selectedUser)\n        if (props.multiple) {\n            if (selectedUsers.filter(i => i === id).length === 0) {\n                selectedUsers.push(id)\n            } else {\n                selectedUsers.splice(selectedUsers.indexOf(id), 1)\n            }\n        } else {\n            selectedUsers = [id]\n        }\n        setSelectedUser(selectedUsers)\n        if (props.onSelect)\n            props.onSelect(selectedUsers)\n        if (!props.multiple)\n            setOpen(false)\n    }\n\n    const removeUser = async (id) => {\n        if (props.multiple) {\n            let selectedUsers = selectedUser\n            selectedUsers.splice(selectedUsers.indexOf(id), 1)\n            setSelectedUser(selectedUsers)\n        }\n    }\n\n    const UserMenuItem = ({ pr, selected }) => {\n        let userPermission = false\n        if (\n            !props.data\n            ||\n            (\n                userList[pr]\n                && userList[pr].access\n                && userList[session._id]\n                && userList[session._id].access\n                && parseInt(userList[session._id].access) >= parseInt(userList[pr].access)\n            )\n            ||\n            (\n                !userList[pr]\n                && (\n                    (userList[session._id]\n                        && userList[session._id].access\n                        && parseInt(userList[session._id].access) >= 3\n                    )\n                    ||\n                    (\n                        data._parent\n                        && db.cards[data._parent]._users[session._id]\n                        && db.cards[data._parent]._users[session._id].access\n                        && parseInt(db.cards[data._parent]._users[session._id].access) >= 3\n                    )\n                    ||\n                    (\n                        data._planId\n                        && db.cards[data._planId]._users[session._id]\n                        && db.cards[data._planId]._users[session._id].access\n                        && parseInt(db.cards[data._planId]._users[session._id].access) >= 3\n                    )\n                )\n            )\n            ||\n            (\n                CardAccess > 3\n            )\n        )\n            userPermission = true\n\n        let u = userList[pr]\n        if (u)\n            return (\n                <MenuItem\n                    autoFocus={false}\n                    onClick={userPermission ? () => {\n                        selectUser(pr)\n                    } : null}\n                // disabled={!userPermission}\n                >\n                    <div style={{\n                        position: 'relative',\n                        width: '100%',\n                        display: \"flex\",\n                        alignItems: \"center\",\n                        cursor: 'pointer',\n                        // backgroundColor: !selected ? `` : `rgba(0,0,0,0.1)`\n                    }}>\n                        <Avatar alt={u.name || null} src={u.image || null} style={{\n                            ...props.avatarSize ? { width: props.avatarSize, height: props.avatarSize } : {}\n                        }}>\n                            {u && u.name ? u.name.substr(0, 1) : ''}\n                        </Avatar>\n                        <div style={{ marginLeft: '15px', color: !userPermission ? \"lightgray\" : \"black\" }}>\n\n                            <div style={{ position: \"relative\", width: \"100%\", float: \"left\" }}>\n                                {u.name || u.name}\n\n                            </div>\n                            <div style={{ position: \"relative\", width: \"100%\", float: \"left\", display: \"flex\", alignItems: \"center\" }}>\n                                {u._parent &&\n                                    db.users[u._parent] &&\n                                    db.users[u._parent].image ?\n                                    <div\n                                        style={{\n                                            position: \"relative\",\n                                            bottom: -4,\n                                            right: -7,\n                                            width: 17,\n                                            height: 17,\n                                            borderRadius: \"50%\",\n                                            backgroundImage: `url(${db.users[u._parent].image})`,\n                                            backgroundSize: \"cover\",\n                                            backgroundRepeat: \"no-repeat\"\n                                        }}></div>\n                                    : <React.Fragment></React.Fragment>}\n                                {u._parent &&\n                                    db.users[u._parent] &&\n                                    db.users[u._parent].name ?\n                                    <div style={{ position: \"relative\", float: \"left\", fontSize: 11, color: \"lightgray\", marginLeft: 7 }}>\n                                        {db.users[u._parent].name}\n                                    </div>\n                                    : <React.Fragment></React.Fragment>}\n                            </div>\n                            {selected ?\n                                <div style={{\n                                    position: \"absolute\",\n                                    right: 0,\n                                    top: 0,\n                                    bottom: 0,\n                                    alignItems: \"center\",\n                                    justifyContent: \"center\",\n                                    display: \"flex\"\n                                }}>\n                                    {selectedUser.indexOf(u._id) === 0 ?\n                                        <div><Icon icon=\"admin_panel_settings\" color={\"lightgray\"} /></div>\n                                        : <React.Fragment></React.Fragment>}\n                                    <Icon icon=\"check\" color={\"green\"} />\n                                </div>\n                                : <React.Fragment></React.Fragment>\n                            }\n                        </div>\n                    </div>\n                </MenuItem>\n            )\n        return (<React.Fragment></React.Fragment>)\n    }\n\n\n    return (\n        <div onClick={(e) => {\n            e.stopPropagation()\n        }}\n        // onMouseOut={() => setOpen(false)}\n        >\n            <Button\n                ref={anchorRef}\n                aria-controls={open ? 'menu-list-grow' : undefined}\n                aria-haspopup=\"true\"\n                aria-label=\"menu\"\n                onClick={(e) => {\n                    if (\n                        !data\n                        ||\n                        (\n                            props.permission\n                        )\n                        ||\n                        (\n                            data && userList && userList[session._id] && userList[session._id].access && parseInt(userList[session._id].access) > 2\n                        )\n                        ||\n                        (\n                            CardAccess > 3\n                        )\n                    ) {\n                        setOpen((prevOpen) => !prevOpen)\n                    }\n                }}\n                className={!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}\n            >\n                {(selectedUser.length === 0) ?\n                    translate(\"$__selectUser\")\n                    :\n                    <div>\n                        <AvatarGroup\n                            max={!props.noLimit ? 4 : 300}\n                            style={{\n                                flexWrap: \"wrap\",\n                                display: \"inline-flex\"\n                            }}\n                        >\n                            {selectedUser.map(selectedUserId =>\n                                <Tooltip\n                                    key={selectedUserId}\n                                    title={userList[selectedUserId] && userList[selectedUserId].displayName ? userList[selectedUserId].displayName : userList[selectedUserId].name || \"\"}\n                                >\n                                    <div\n                                        style={{ display: \"flex\", alignItems: \"center\" }}\n                                    >\n                                        <Avatar\n                                            alt={userList[selectedUserId].name}\n                                            src={userList[selectedUserId].image || null}\n                                            style={{ width: props && props.avatarSize ? props && props.avatarSize : 'none', height: props && props.avatarSize ? props.avatarSize : 'none' }}>\n                                            {userList[selectedUserId].name.substr(0, 1)}\n                                        </Avatar>\n                                        {!props.multiple &&\n                                            <span style={{ marginLeft: 15 }}>\n                                                {userList[selectedUserId].displayName ? userList[selectedUserId].displayName : userList[selectedUserId].name}\n                                            </span>\n                                        }\n                                    </div>\n                                </Tooltip>\n                            )}\n                            {props.multiple &&\n                                <Tooltip\n                                    title={translate(\"$__selectUser\")}\n                                >\n                                    <Avatar\n                                        style={{ width: props && props.avatarSize ? props && props.avatarSize : 'none', height: props && props.avatarSize ? props.avatarSize : 'none' }}\n                                        alt={'ADD'}\n                                        src={null}>\n                                        +\n                                    </Avatar>\n                                </Tooltip>\n                            }\n                        </AvatarGroup>\n                    </div>\n                }\n            </Button>\n            <Dialog\n                open={open}\n            >\n                <div style={{\n                    position: 'relative',\n                    width: '100%',\n                    paddingBottom: removeUsers && removeUsers.length ? '66px' : 0,\n                    width: \"100%\",\n                    display: \"flex\",\n                    justifyContent: \"space-between\"\n                }}>\n                    <ClickAwayListener onClickAway={handleClose}>\n\n                        <div\n                            style={{\n                                position: \"relative\",\n                            }}\n                        >\n                            <div style={{\n                                width: \"100%\",\n                                padding: \"4px 15px\",\n                                fontSize: \"16px\",\n                                color: \"lightGray\",\n                                position: \"relative\",\n                            }}>\n                                <TextField\n                                    id={`quickUser_Search`}\n                                    label={translate('$__searchByName', 1)}\n                                    variant={customApp('fieldVariant')}\n                                    name={'searchValue'}\n                                    InputProps={{\n                                        autoComplete: 'new-password',\n                                        endAdornment: (\n                                            <InputAdornment position=\"end\"\n                                                style={{ cursor: \"pointer\" }}\n                                                onClick={() => {\n                                                    setSearchValue(\"\")\n                                                    setOpen(false)\n                                                }}>\n                                                <Icon icon='close' />\n                                            </InputAdornment>\n                                        ),\n                                        onChange: (d) => {\n                                            setSearchValue(d.target.value)\n                                        },\n                                    }}\n                                    value={searchValue}\n                                    placeholder={translate('$__searchByName', 1)}\n                                    autoFocus\n                                />\n                            </div>\n                            <div style={{\n                                width: \"100%\",\n                                padding: \"4px 15px\",\n                                fontSize: \"16px\",\n                                color: \"lightGray\",\n                                position: \"relative\",\n                                maxHeight: 250,\n                                overflowY: \"auto\"\n                            }}>\n                                <MenuList\n                                    id=\"menu-list-grow\"\n                                    autoFocusItem={false}\n                                    autoFocus={false}\n                                    onKeyDown={handleListKeyDown}\n                                >\n                                    {Object.keys(userList).filter(a =>\n                                        !userList[a].deleted\n                                        && (searchValue === \"\"\n                                            ||\n                                            (\n                                                searchValue\n                                                && userList[a].name\n                                                && userList[a].name.toLowerCase().indexOf(searchValue.toLowerCase()) > -1\n                                            )\n                                        )\n                                    ).sort((a, b) => {\n                                        if (userList[a].name < userList[b].name)\n                                            return -1\n                                        else if (userList[a].name > userList[b].name)\n                                            return 1\n                                        return 0\n                                    }).map(pr =>\n                                        userList && userList[pr] && userList[pr]._id &&\n                                        <UserMenuItem pr={pr} key={pr} selected={selectedUser.indexOf(userList[pr]._id) === -1 ? false : true} />\n                                    )}\n                                </MenuList>\n                            </div>\n                        </div>\n                    </ClickAwayListener>\n                </div>\n            </Dialog>\n        </div>\n    )\n}\nconst mapStateToProps = () => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Comp)","import React from \"react\"\nimport Chartist from \"chartist\"\nimport moment from \"moment-timezone\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport KpiDescription from \"components/KPI/dataSave\"\nimport SelectUsers from \"components/User/select\"\nimport TextField from \"components/TextField\"\nimport CustomButton from \"components/Buttons/custom\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\n\n\n//FUNCTIONS\nimport { translate, customApp, appAlert, formatNumber } from \"functions/\"\nimport { kpiTimerStart, kpiTimerStop } from \"functions/cards\"\n\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/KPI_change.js\"\n\nimport {\n    model\n} from \"variables/charts\"\nimport \"assets/css/components/chart.css\"\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\nrequire(\"chartist-plugin-tooltips\")\n\nconst TimerComponent = (props) => {\n    const { classes } = props\n    const { db, session } = reduxStore.getState()\n    const { cards } = db\n    const [reqSave, setReqSave] = React.useState(false)\n    const [started, setStart] = React.useState(false)\n    const [timer, setTimer] = React.useState({})\n    const { data } = props\n    const [cardsWithKpi, setCardsWithKpi] = React.useState([])\n    const [startDate, setStartDate] = React.useState(moment(new Date()).tz('America/Sao_Paulo').format('YYYY-MM-DDT06:00'))\n    const [endDate, setEndDate] = React.useState(moment(new Date()).tz('America/Sao_Paulo').format('YYYY-MM-DDT07:00'))\n    const [manualTime, setManualTime] = React.useState(false)\n    const [manualMinuteEntry, setManualMinuteEntry] = React.useState(0)\n    const [manualHourEntry, setManualHourEntry] = React.useState(1)\n    const [diffTime, setDiffTime] = React.useState(0)\n\n\n    let timerFunction\n    let kpi_ini = data.kpi_type === \"time\" && data.kpi_ini ? parseFloat(data.kpi_ini) : 0\n    let kpi_fin = data.kpi_type === \"time\" && data.kpi_fin ? parseFloat(data.kpi_fin) : 0\n\n\n    React.useEffect(() => {\n        if (timerFunction) clearTimeout(timerFunction)\n        verifyTimer()\n        childrenCards(props.data._id)\n    }, [started])\n\n\n\n    React.useEffect(() => {\n        if (timerFunction) clearTimeout(timerFunction)\n        verifyTimer()\n        childrenCards(props.data._id)\n    }, [JSON.stringify(props.card)])\n\n    //Filter all Children Cards with KPI = kpi_useParent\n    let kpiCards = [props.data._id]\n    const childrenCards = (cardId, children) => {\n        let chields = Object.keys(cards)\n            .filter(a => cards[a].kpi_useParent && cards[a]._parent === cardId)\n        if (chields.length > 0) {\n            chields.map(a => {\n                childrenCards(a, true)\n                kpiCards.push(a)\n                setCardsWithKpi(Array.from(new Set(kpiCards)))\n            })\n        } else if (!children) {\n            setCardsWithKpi(kpiCards)\n        }\n        return chields\n    }\n    const verifyTimer = () => {\n        // TIMER NÃO ESTÁ ATUALIZANDO QUANDO DA PLAY OU STOP DENTRO DO CARD\n        let newData = { ...reduxStore.getState().db.cards[props.data._id] }\n        if (newData && newData._kpiTimer && Object.keys(newData._kpiTimer).filter(a => newData._kpiTimer[a].userId === session._id).length > 0) {\n            let timer = newData._kpiTimer[Object.keys(newData._kpiTimer).filter(a => newData._kpiTimer[a].userId === session._id)[0]]\n            timer.diff = moment().tz('America/Sao_Paulo').unix('x') - timer.created_at\n            if (timer && timer.updated_at)\n                timer.diff = parseInt(timer.updated_at) - parseInt(timer.created_at)\n            calcTimer(timer, timer.updated_at ? true : false)\n        } else {\n            setReqSave(false)\n            setTimer({})\n            setStart(false)\n        }\n        if (Object.keys(timer).length === 0 && props.manualAdd) {\n            setTimer({\n                created_at: moment(startDate).tz('America/Sao_Paulo').unix('X'),\n                updated_at: moment(endDate).tz('America/Sao_Paulo').unix('X')\n            })\n            calcTimer({\n                created_at: moment(startDate).tz('America/Sao_Paulo').unix('X'),\n                updated_at: moment(endDate).tz('America/Sao_Paulo').unix('X')\n            }, timer.updated_at ? true : false)\n        }\n    }\n\n    const calcTimer = (d, kill, ignoreManual = false) => {\n\n        let newData = { ...d }\n        let iniTimer = false\n\n        let diff\n\n\n        if (newData.diff) {\n            diff = parseInt(newData.diff)\n        } else {\n            diff = parseInt(d.updated_at - d.created_at)\n            if (d.updated_at - d.created_at < 0)\n                diff = null\n        }\n        if (!diff && !manualTime) {\n            newData.diffText = translate(\"$__theEndMustBeGreaterThanTheBeginning\")\n        } else if (diff < 60) {\n            newData.diffText = `${newData.diff} ${translate('$__seconds', 1)}`\n            if (!ignoreManual)\n                setManualHourEntry(0)\n        } else if (diff >= 3600) {\n            let hours = Math.trunc(diff / 3600)\n            diff = diff - (hours * 3600)\n            let minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\n            diff = diff - (minutes * 60)\n            if (minutes < 60) {\n            } else {\n\n            }\n            let seconds = diff > 0 ? diff : 0\n            newData.diffText = `${hours} hora${hours > 1 ? 's' : ''} ${minutes} ${translate('$__minutes', 1)} ${seconds} ${translate('$__seconds', 1)}`\n            if (!ignoreManual) {\n                setManualHourEntry(hours)\n                setManualMinuteEntry(minutes)\n            }\n        } else {\n            let minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\n            diff = diff - (minutes * 60)\n            let seconds = diff > 0 ? diff : 0\n            newData.diffText = `${minutes} ${translate('$__minutes', 1)} ${seconds} ${translate('$__seconds', 1)}`\n            if (!ignoreManual) {\n                setManualHourEntry(0)\n                setManualMinuteEntry(minutes)\n            }\n        }\n        setTimer({ ...timer, ...newData })\n\n        if (d.updated_at) {\n            newData.diff = parseInt(d.updated_at) - parseInt(d.created_at)\n            if (!reqSave) setReqSave(true)\n        } else {\n            newData.diff = moment().tz('America/Sao_Paulo').unix('x') - parseInt(d.created_at)\n            if (!started) {\n                setStart(true)\n                iniTimer = true\n            }\n        }\n\n        if (!kill && !d.updated_at && iniTimer) {\n            timerFunction = setTimeout(() => { verifyTimer() }, 1000)\n        }\n    }\n\n    if (!data)\n        return (null)\n\n    const startTimer = async () => {\n        const response = await kpiTimerStart(props, data._id)\n        if (response) {\n            calcTimer(response)\n            setStart(true)\n        }\n    }\n    const stopTimer = async () => {\n        setStart(false)\n        const response = await kpiTimerStop(props, data._id)\n        if (response) {\n            setTimer({\n                ...timer,\n                ...response\n            })\n        }\n    }\n\n    let kpiChart = {\n        ...model\n    }\n\n    let series = []\n    let labels = []\n\n    let kpi_flow = {}\n    cardsWithKpi.map(a => {\n        kpi_flow = {\n            ...kpi_flow,\n            ...db.cards[a]._timeline || {}\n        }\n    })\n\n\n    kpi_flow = Object.keys(kpi_flow).filter(a => kpi_flow[a].type === 'kpi').map(a => kpi_flow[a])\n\n    let kpi_total = data.kpi_type !== 'time' ? parseFloat(kpi_ini) : 0\n    let percent100 = parseFloat(kpi_ini) - parseFloat(kpi_fin)\n    if (percent100 < 0) percent100 = percent100 * -1\n\n    if (kpi_flow && Object.keys(kpi_flow).length > 0) {\n        Object.keys(kpi_flow).sort((a, b) => {\n            if (kpi_flow[a].created_at < kpi_flow[b].created_at)\n                return -1\n            return 1\n        }).map((a, i) => {\n            kpi_total = parseFloat(kpi_total) + parseFloat(kpi_flow[a].value)\n            series.push({\n                meta: kpi_flow[a].value,\n                total: kpi_total,\n                value: parseFloat(kpi_ini) > parseFloat(kpi_fin) ? 100 - Math.floor((kpi_total * 100) / percent100) : Math.floor((kpi_total * 100) / percent100)\n            })\n            labels.push(i + 1)\n            if (i + 1 === Object.keys(kpi_flow).length)\n                kpiChart = {\n                    ...kpiChart,\n                    data: {\n                        labels: labels,\n                        series: [[...series]]\n                    },\n                    options: {\n                        //fullWidth: true,\n                        ...kpiChart.options,\n                        low: 0,\n                        high: 100,\n                        plugins: [Chartist.plugins.tooltip({\n                            tooltipFnc: function (meta, value) {\n                                return (\n                                    `${meta > 0 ? '+' : ''}` +\n                                    formatNumber(meta, data.kpi_type === 'time' ? 'number' : data.kpi_type) + '<br>' + formatNumber(value, 'percent')\n                                )\n                            }\n                        })],\n                        axisX: {\n                            showGrid: false,\n                        },\n                        axisY: {\n                            showGrid: false,\n                        },\n                        onlyInteger: true,\n                    },\n                }\n        })\n    }\n\n\n\n    let sumKpi = kpi_ini < kpi_fin ? kpi_fin - kpi_ini : kpi_ini - kpi_fin\n\n\n    if (kpi_flow && Object.keys(kpi_flow).length > 0) {\n        Object.keys(kpi_flow).map(a => {\n            sumKpi = parseFloat(sumKpi) + parseFloat(kpi_flow[a].value)\n        })\n    }\n\n\n    let percentKpi = Math.ceil(kpi_ini < kpi_fin ? kpi_fin - kpi_ini : kpi_ini - kpi_fin)\n    percentKpi = ((Math.ceil(sumKpi) * 100) / percentKpi) - 100\n    if (percentKpi < 0)\n        percentKpi = percentKpi * -1\n\n\n    if (!props.data)\n        return (<div>NO DATA RECEIVED</div>)\n\n    return (\n        <div className={classes.root}>\n            <fieldset>\n                <legend\n                    style={\n                        {\n                            color: customApp('color')\n                        }\n                    }>\n                    {!props.manualAdd ? translate('$__timer', 1) : translate('$__timerLog', 1)}\n                </legend>\n                {props.manualAdd &&\n                    <React.Fragment>\n                        {!manualTime ?\n                            <React.Fragment>\n                                <div className={classes.timeInfo}>\n                                    <Icon color='color' icon='schedule' />\n                                    <TextField\n                                        label={translate('$__initialDate', 1)}\n                                        variant={customApp('fieldVariant', 1)}\n                                        name=\"startDate\"\n                                        InputLabelProps={{\n                                            shrink: true,\n                                        }}\n                                        type='datetime-local'\n                                        inputProps={{\n                                            max: endDate,\n                                            autoComplete: 'start-date',\n                                            onChange: (d) => {\n                                                if (moment(d.target.value).isValid()) {\n                                                    setStartDate(d.target.value)\n                                                    calcTimer({\n                                                        ...timer,\n                                                        created_at: moment(d.target.value).tz('America/Sao_Paulo').unix('X')\n                                                    }, true)\n                                                }\n                                            },\n                                        }}\n                                        value={startDate}\n                                    />\n                                </div>\n                                <div className={classes.timeInfo}>\n                                    <Icon color='color' icon='watch_later' />\n                                    <TextField\n                                        label={translate('$__finalDate', 1)}\n                                        variant={customApp('fieldVariant', 1)}\n                                        name=\"endDate\"\n                                        InputLabelProps={{\n                                            shrink: true,\n                                        }}\n                                        type='datetime-local'\n                                        inputProps={{\n                                            min: startDate,\n                                            autoComplete: 'new-password',\n                                            onChange: (d) => {\n                                                if (moment(d.target.value).isValid()) {\n                                                    setEndDate(d.target.value)\n                                                    calcTimer({\n                                                        ...timer,\n                                                        updated_at: moment(d.target.value).tz('America/Sao_Paulo').unix('X')\n                                                    }, true)\n                                                }\n                                            },\n                                        }}\n                                        value={endDate}\n                                    />\n                                </div>\n\n                            </React.Fragment>\n                            :\n                            <React.Fragment>\n                                <div className={classes.timeInfo}>\n                                    <Icon color='color' icon='schedule' />\n                                    <TextField\n                                        label={translate('$__initialDate', 1)}\n                                        variant={customApp('fieldVariant', 1)}\n                                        name=\"startDate\"\n                                        InputLabelProps={{\n                                            shrink: true,\n                                        }}\n                                        type='date'\n                                        inputProps={{\n                                            max: moment().format(\"YYYY-MM-DD\"),\n                                            autoComplete: 'start-date',\n                                            onChange: (d) => {\n                                                if (moment(d.target.value).isValid()) {\n                                                    setStartDate(d.target.value)\n                                                }\n                                                let diffCalc = timer.updated_at - timer.created_at\n                                                calcTimer({\n                                                    ...timer,\n                                                    created_at: moment(`${d.target.value} 00:00:00`).unix('X'),\n                                                    updated_at: moment(`${d.target.value} 00:00:00`).unix('X') + diffCalc\n                                                }, true, true)\n                                            },\n                                        }}\n                                        value={startDate}\n                                    />\n                                </div>\n                            </React.Fragment>\n                        }\n                        <div className={classes.timeInfo}>\n                            <Icon color='color' icon='more_time' />\n                            <div style={{\n                                display: \"flex\",\n                                alignItems: \"center\"\n                            }}>\n                                <TextField\n                                    label={translate('$__hours', 1)}\n                                    variant={customApp('fieldVariant', 1)}\n                                    name=\"hours\"\n                                    InputLabelProps={{\n                                        shrink: true,\n                                    }}\n                                    type='number'\n                                    inputProps={{\n                                        min: 0,\n                                        autoComplete: 'hours',\n                                        onChange: (d) => {\n                                            setManualHourEntry(d.target.value)\n                                            setManualTime(true)\n                                            if (startDate.indexOf(\"T\") > -1)\n                                                setStartDate(startDate.substring(0, 10))\n\n                                            calcTimer({\n                                                ...timer,\n                                                created_at: moment(`${startDate.substring(0, 10)} 00:00:00`).unix('X'),\n                                                updated_at: moment(`${startDate.substring(0, 10)} 00:00:00`).unix('X') + (d.target.value * 60 * 60) + (manualMinuteEntry * 60)\n                                            }, true, true)\n                                        }\n                                    }\n                                    }\n                                    value={manualHourEntry}\n                                    style={{\n                                        paddingLeft: 7,\n                                        paddingRight: 7\n                                    }}\n                                />\n                                <TextField\n                                    label={translate('$__minutes', 1)}\n                                    variant={customApp('fieldVariant', 1)}\n                                    name=\"minutes\"\n                                    InputLabelProps={{\n                                        shrink: true,\n                                    }}\n                                    type='number'\n                                    inputProps={{\n                                        min: 0,\n                                        max: 59,\n                                        autoComplete: 'new-password',\n                                        onChange: (d) => {\n                                            setManualMinuteEntry(d.target.value)\n                                            setManualTime(true)\n                                            if (startDate.indexOf(\"T\") > -1)\n                                                setStartDate(startDate.substring(0, 10))\n                                            calcTimer({\n                                                ...timer,\n                                                created_at: moment(`${startDate.substring(0, 10)} 00:00:00`).unix('X'),\n                                                updated_at: moment(`${startDate.substring(0, 10)} 00:00:00`).unix('X') + (manualHourEntry * 60 * 60) + (d.target.value * 60)\n                                            }, true, true)\n                                        }\n                                    }\n                                    }\n                                    value={manualMinuteEntry}\n                                    style={{\n                                        paddingLeft: 7,\n                                        paddingRight: 7\n                                    }}\n                                />\n                                <CustomButton\n                                    title={translate(\"$__reset\", 1)}\n                                    icon={\"update_disabled\"}\n                                    color={customApp(\"menu\")}\n                                    onClick={() => {\n                                        setManualTime(false)\n                                        setStartDate(`${startDate} 00:00:00`)\n                                    }\n                                    }\n                                    size={\"17px\"}\n                                    style={{\n                                        marginLeft: 3,\n                                        marginRight: 3,\n                                        backgroundColor: \"rgba(0,0,0,0.05)\",\n                                        padding: 3\n                                    }}\n                                    transparent\n                                />\n                            </div>\n                        </div>\n                        <div\n                            style={{\n                                position: \"relative\",\n                                width: \"100%\",\n                                display: \"flex\",\n                                alignItems: \"center\"\n                            }}\n                        >\n\n\n                        </div>\n                        {timer && timer.diffText &&\n                            <div className={classes.timeInfo}>\n                                <Icon color='color' icon='hourglass_full' />\n                                <div className='text'>{timer.diffText}</div>\n                            </div>\n                        }\n                        {parseInt(db.cards[data._id]._users[session._id].access) >= 3 ?\n                            <ErrorBoundary>\n                                <SelectUsers\n                                    includeMe\n                                    data={db.cards[data._id]}\n                                    avatarSize=\"33px\"\n                                    permission={props.permission}\n                                    noLimit\n                                    multiple\n                                    onSelect={(e) => {\n                                        calcTimer({\n                                            ...timer,\n                                            to: e\n                                        }, true)\n                                    }}\n                                />\n                            </ErrorBoundary>\n                            : <React.Fragment></React.Fragment>\n                        }\n                    </React.Fragment>\n                }\n\n                {!reqSave && !props.manualAdd ?\n                    <div className={classes.time}>\n                        {!started ?\n                            <React.Fragment>\n                                {kpi_fin && kpi_total ?\n                                    <div className={classes.timeInfo}>\n                                        <Icon color={(kpi_fin * 60) < kpi_total ? 'red' : 'color'} icon='schedule' />\n                                        <div className='text'\n                                            style={{\n                                                color: (kpi_fin * 60) < kpi_total ? 'red' : 'grey'\n                                            }}\n                                        >{translate('$__timeLeft', 1)}\n                                            : {((kpi_fin * 60) - kpi_total) > -60 && ((kpi_fin * 60) - kpi_total) < 60 ? `${((kpi_fin * 60) - kpi_total)} ${translate('$__seconds', 1)} `\n                                                : `${Math.trunc(((kpi_fin * 60) - kpi_total) / 60)} ${translate('$__minutes', 1)} ${((kpi_fin * 60) - kpi_total) - (Math.trunc(((kpi_fin * 60) - kpi_total) / 60) * 60)} ${translate('$__seconds', 1)} `}\n                                        </div>\n                                    </div>\n                                    : <React.Fragment></React.Fragment>\n                                }\n                                <div className={classes.timeInfo}>\n                                    <Icon color='color'\n                                        onClick={() => {\n                                            startTimer()\n                                        }} title=\"playRegisterLogWork\">play_circle_outline</Icon>\n                                    <span style={{ marginLeft: 7, color: customApp(\"color\") }}>{translate(\"$__startStopWatch\")}</span>\n                                    {/* {kpi_fin && kpi_total ?\n                                        <div className='text'>\n                                            {kpi_total < 60 ? `${kpi_total} ${translate('$__seconds', 1)} `\n                                                : `${Math.trunc(kpi_total / 60)} ${translate('$__minutes', 1)} ${kpi_total - (Math.trunc(kpi_total / 60) * 60)} ${translate('$__seconds', 1)} `}\n                                        </div>\n                                        : <React.Fragment></React.Fragment>\n                                    } */}\n                                </div>\n                            </React.Fragment>\n                            :\n                            <div className={classes.timeInfo}>\n                                <Icon color='color'\n                                    onClick={() => {\n                                        appAlert({\n                                            message: translate('$__confirmStopTimer', 1),\n                                            variant: 'warning',\n                                            persist: false,\n                                            horizontal: 'right',\n                                            confirm: () => {\n                                                stopTimer()\n                                            }\n                                        })\n                                    }}>pause_circle_filled</Icon>\n                                <div className='text'>{timer.diffText}</div>\n                            </div>\n                        }\n                    </div>\n                    :\n                    <div>\n                        {!props.manualAdd\n                            && timer\n                            && timer.created_at\n                            && timer.updated_at\n                            && timer.diffText\n                            && moment(timer.created_at * 1000).isValid() &&\n                            <React.Fragment>\n                                <div className={classes.timeInfo}>\n                                    <Icon color='color' icon='schedule' />\n                                    <div className='text'>{moment(timer.created_at * 1000).tz('America/Sao_Paulo').format('DD/MM/YYYY HH:mm:ss')}</div>\n                                </div>\n                                <div className={classes.timeInfo}>\n                                    <Icon color='color' icon='watch_later' />\n                                    <div className='text'>{moment(timer.updated_at * 1000).tz('America/Sao_Paulo').format('DD/MM/YYYY HH:mm:ss')}</div>\n                                </div>\n                                <div className={classes.timeInfo}>\n                                    <Icon color='color' icon='hourglass_full' />\n                                    <div className='text'>{timer.diffText}</div>\n                                </div>\n                            </React.Fragment>\n                        }\n                        {timer.created_at < timer.updated_at ?\n                            <ErrorBoundary>\n                                <KpiDescription\n                                    manualAdd={props.manualAdd ? true : false}\n                                    data={data}\n                                    timer={timer}\n                                    manualEntry={manualTime}\n                                    callBack={() => {\n                                        setReqSave(false)\n                                        if (props.callBack)\n                                            props.callBack()\n                                    }}\n                                />\n                            </ErrorBoundary>\n                            : <React.Fragment></React.Fragment>\n                        }\n                    </div>\n                }\n            </fieldset>\n        </div >\n    )\n}\n//REACT\nconst mapStateToProps = (store, props) => ({\n    card: store.db.cards[props.data._id]\n    // card: store.db.cards[props.data._id]\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(TimerComponent))","import {\r\n  defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = {\r\n  containerNoShadow: {\r\n    ...defaultFont,\r\n    position: 'relative',\r\n    border: `0.5px solid ${customApp('light')}`,\r\n    borderRadius: '2px',\r\n    padding: '0px',\r\n    backgroundColor: '#FFFFFF',\r\n    padding: '3px',\r\n    // minWidth: '150px',\r\n    display: 'flow-root',\r\n  },\r\n  container: {\r\n    ...defaultFont,\r\n    position: 'relative',\r\n    border: `0.5px solid ${customApp('light')}`,\r\n    borderRadius: '2px',\r\n    padding: '0px',\r\n    backgroundColor: '#FFFFFF',\r\n    padding: '3px',\r\n    // minWidth: '150px',\r\n    display: 'flow-root',\r\n    boxShadow: '0px 0px 10px rgba(0,0,0,0.1)',\r\n  },\r\n  parent: {\r\n    width: '100%',\r\n    padding: '0 5px',\r\n    '& .title': {\r\n      color: customApp('medium'),\r\n      fontSize: '10px',\r\n      textTransform: 'uppercase'\r\n    },\r\n    '& .info': {\r\n      marginTop: '-8px',\r\n      color: customApp('color'),\r\n      fontWeight: '500',\r\n      //display: 'flex',\r\n      alignItems: 'center',\r\n    }\r\n  },\r\n  infos: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    height: 'auto',\r\n    display: 'block',\r\n  },\r\n  indicators: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    height: 'auto',\r\n    // display: 'flex',\r\n    zIndex: '0 !important'\r\n  },\r\n  indicatorsIcon: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    margin: '0px 0px',\r\n    '& MuiBadge-badge': {\r\n      position: 'relative',\r\n      float: 'left',\r\n      //zIndex: '30 !important'\r\n    }\r\n  },\r\n  image: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    marginTop: '7px',\r\n    maxWidth: '100%',\r\n    display: 'none',\r\n  },\r\n  imagePreview: {\r\n    backgroundRepeat: 'no-repeat',\r\n    backgroundSize: 'cover',\r\n    backgroundPosition: 'center',\r\n    paddingTop: '48%',\r\n    display: 'flex',\r\n    justifyContent: 'center',\r\n    alignItems: 'center',\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%'\r\n  },\r\n  imagePreviewList: {\r\n    backgroundRepeat: 'no-repeat',\r\n    backgroundSize: 'cover',\r\n    backgroundPosition: 'center',\r\n    display: 'flex',\r\n    justifyContent: 'center',\r\n    alignItems: 'center',\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: \"100%\",\r\n    paddingTop: \"48%\",\r\n    '@media screen and (max-width: 800px)': {\r\n      width: '100%'\r\n    }\r\n  },\r\n  PreLoader: {\r\n    top: 'calc(50% - 25px)',\r\n    left: 'calc(50% - 25px)',\r\n    position: 'absolute',\r\n  },\r\n  description: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    padding: '5px',\r\n    minHeight: '75px',\r\n    width: '100%',\r\n    overflow: 'hidden',\r\n    textOverflow: 'ellipses'\r\n  },\r\n  dates: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    marginTop: '7px',\r\n    padding: '0 5px',\r\n    marginRight: '15px',\r\n    color: customApp('medium'),\r\n    fontSize: '10px',\r\n    display: 'flex',\r\n  },\r\n  lateDates: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    marginTop: '7px',\r\n    padding: '0 5px',\r\n    marginRight: '15px',\r\n    color: 'red',\r\n    fontSize: '10px',\r\n    display: 'flex',\r\n  },\r\n  dateInfo: {\r\n    marginRight: '15px',\r\n    display: 'flex',\r\n    alignItems: 'center'\r\n  },\r\n  usersContent: {\r\n    minHeight: '20px',\r\n    minWidth: '40px',\r\n    zIndex: '0 !important'\r\n  },\r\n  users: {\r\n    position: 'absolute',\r\n    bottom: '0px',\r\n    right: '2px',\r\n    fontSize: '10px',\r\n    '& .MuiAvatarGroup-root': {\r\n      justifyContent: 'flex-end',\r\n    },\r\n    '& .MuiAvatar-root': {\r\n      width: '25px',\r\n      height: '25px',\r\n      fontSize: '10px',\r\n    }\r\n  }\r\n};\r\n\r\nexport default style;\r\n","import React from \"react\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\n\n\nimport {\n    customApp,\n} from \"functions/\"\n\n//STYLES\nimport styles from \"./Card.css.js\"\n\n\nfunction FakeExpanded(props) {\n    const { classes } = props\n    return (\n        <div>\n            <div\n                className={classes.infos}\n            >\n                <div\n                    className={classes.imagePreview}\n                    style={{\n                        background: props.backgroundColor ? props.backgroundColor : customApp('AvatarBackground'),\n                        display: 'flex',\n                        alignItems: 'center',\n                        justifyContent: 'center'\n                    }}>\n                    <div style={{ marginTop: `calc(-48% - 10px)`, display: 'flex', justifyContent: 'center', alignItems: 'center' }}>\n                        <Icon icon={\"lock\"} size=\"39px\" color={props.avatarIconColor ? props.avatarIconColor : customApp('AvatarIconColor')} />\n                    </div>\n                </div>\n            </div>\n        </div >\n    )\n}\n\n//REACT\nexport default withStyles(styles)(FakeExpanded)","import apims from \"apims\"\r\nimport api from \"api\"\r\nimport { v4 as uuid } from \"uuid\";\r\nimport moment from \"moment-timezone\"\r\n\r\n//REDUX\r\nimport reduxStore from \"store/\"\r\n\r\n\r\nimport {\r\n    cardsAccess,\r\n    isResponsible as setResponsible\r\n} from \"functions/users\"\r\n\r\nconst addColumn = async (newData) => {\r\n    let data = {\r\n        ...newData\r\n    }\r\n    Object.keys(data).map(x => {\r\n        if (!data[x])\r\n            delete (data[x])\r\n    })\r\n    let lines = data.name.trim().split(\"\\n\")\r\n\r\n    let newCards = {}\r\n    let users = {}\r\n    if (data.users && data.users.length > 0)\r\n        data.users.map((uid, i) => {\r\n            let u = reduxStore.getState().db.users[uid]\r\n            users = {\r\n                ...users,\r\n                [uid]: {\r\n                    _id: uid,\r\n                    name: u.name,\r\n                    image: u.image || null,\r\n                    ...i === 0 ? { isResponsible: true } : {},\r\n                }\r\n            }\r\n        })\r\n\r\n\r\n    let newId = uuid()\r\n\r\n    api.post('card/add', {\r\n        _id: newId,\r\n        ...data,\r\n    });\r\n\r\n    newCards = {\r\n        ...newCards,\r\n        [newId]: {\r\n            _id: newId,\r\n            ...data,\r\n            _users: users,\r\n        }\r\n    }\r\n\r\n    if (newCards[newId]?.users)\r\n        delete newCards[newId].users\r\n\r\n    return newCards\r\n}\r\n\r\nconst reorder = async (cards, orderBy = 'order', n = 0) => {\r\n    try {\r\n        await api.post('kanban/reorder', { cards, orderBy });\r\n        return true\r\n    } catch (e) {\r\n        if (n < 3)\r\n            setTimeout(() => {\r\n                reorder(cards, orderBy, n + 1)\r\n            }, 3000)\r\n    }\r\n}\r\n\r\nconst linkCard = async (data) => {\r\n    try {\r\n        await api.put('card/link', data);\r\n        return true\r\n    } catch (e) {\r\n        setTimeout(() => {\r\n            linkCard(data)\r\n        }, 3000)\r\n    }\r\n}\r\n\r\nexport const automation = (props, nodeId, to) => {\r\n\r\n    //LINK\r\n    let parentCard = reduxStore.getState().db.cards[to]\r\n    let card = reduxStore.getState().db.cards[nodeId]\r\n\r\n    // console.log(to, parentCard, card)\r\n\r\n    let dataUpdate = {}\r\n    if (\r\n        parentCard\r\n        && parentCard.automationDueDateType\r\n        && parentCard.automationDueDateType === \"add\"\r\n    )\r\n        dataUpdate = {\r\n            endDate: moment(`${moment().format(\"YYYY-MM-DD\")} 23:59:59`).add(parentCard?.automationDueDate || 1, \"days\").unix(\"X\"),\r\n            ...!card.startDate ? { startDate: moment().unix(\"X\") } : {}\r\n        }\r\n\r\n    if (parentCard\r\n        && parentCard.automationStatusType\r\n        && parentCard.automationStatusType === \"replace\"\r\n    )\r\n        dataUpdate = {\r\n            ...dataUpdate,\r\n            status: parentCard.automationStatus || 'notStarted',\r\n            ...parentCard.automationStatus && parentCard.automationStatus === 'completed' ? { completed_at: moment().unix('x') } : {}\r\n        }\r\n    let usersToRemove = []\r\n    let isResponsible\r\n    if (parentCard\r\n        && parentCard.automationUsers\r\n        && parentCard.automationUsers === 'add'\r\n        && parentCard._users\r\n        && Object.keys(parentCard._users).filter(a => a).length > 0\r\n    )\r\n        Object.keys(parentCard._users).filter(a => a).map(id => {\r\n            if (parentCard._users[id].isResponsible)\r\n                isResponsible = id\r\n            if (card && (!card._users || (card._users && !card._users[id]))) {\r\n                const noNotification = card._users && card._users[id] ? true : false\r\n                cardsAccess(props, id, parentCard._users[id].access, card._id, noNotification)\r\n            }\r\n        })\r\n\r\n\r\n    if (parentCard\r\n        && parentCard.automationTags\r\n        && parentCard.automationTags !== \"doNotChange\"\r\n        && parentCard._tags\r\n        && parentCard._tags.length > 0\r\n    ) {\r\n        let newTags = card._tags ? Array.from(card._tags) : []\r\n\r\n        if (parentCard.automationTags === \"replace\") {\r\n            let removeTags = []\r\n            let addTags = []\r\n            parentCard._tags.map(nt => {\r\n                if (newTags.findIndex(tag => tag.value === nt.value) > -1) {\r\n                    removeTags.push(nt.value)\r\n                    newTags.splice(newTags.findIndex(tag => tag.value === nt.value), 1)\r\n                }\r\n            })\r\n            parentCard._tags.map(nt => {\r\n                if (newTags.findIndex(tag => tag.value === nt.value) === -1) {\r\n                    newTags.push(nt)\r\n                    if (addTags.indexOf(nt.value) === -1)\r\n                        addTags.push(nt.value)\r\n                }\r\n            })\r\n            dataUpdate = {\r\n                ...dataUpdate,\r\n                ...removeTags.length > 0 ? { removeTags: removeTags } : {},\r\n                ...addTags.length > 0 ? { addTags: addTags } : {},\r\n            }\r\n\r\n            newTags = Array.from(parentCard._tags)\r\n        }\r\n\r\n        if (parentCard.automationTags === \"add\") {\r\n            let addTags = []\r\n            parentCard._tags.map(nt => {\r\n                if (newTags.filter(tag => tag.value === nt.value).length === 0) {\r\n                    addTags.push(nt.value)\r\n                    newTags.push(nt)\r\n                }\r\n            })\r\n            dataUpdate = {\r\n                ...dataUpdate,\r\n                addTags: addTags\r\n            }\r\n        }\r\n\r\n        if (parentCard.automationTags === \"remove\") {\r\n            let removeTags = []\r\n            parentCard._tags.map(nt => {\r\n                if (newTags.findIndex(tag => tag.value === nt.value) > -1) {\r\n                    removeTags.push(nt.value)\r\n                    newTags.splice(newTags.findIndex(tag => tag.value === nt.value), 1)\r\n                }\r\n            })\r\n            dataUpdate = {\r\n                ...dataUpdate,\r\n                removeTags: removeTags\r\n            }\r\n        }\r\n\r\n        dataUpdate = {\r\n            ...dataUpdate,\r\n            _tags: newTags\r\n        }\r\n    }\r\n\r\n    if (parentCard\r\n        && parentCard.automationUsers\r\n        && parentCard.automationUsers === 'remove'\r\n        && parentCard._users\r\n        && Object.keys(parentCard._users).filter(a => a).length > 0\r\n    )\r\n        Object.keys(parentCard._users).filter(a => a).map(id => {\r\n            if (card && card._users && card._users[id] && usersToRemove && usersToRemove.indexOf(id) === -1)\r\n                usersToRemove.push(id)\r\n        })\r\n    if (parentCard\r\n        && parentCard.automationUsers\r\n        && parentCard.automationUsers === 'replace'\r\n        && parentCard._users\r\n        && Object.keys(parentCard._users).filter(a => a).length > 0\r\n    ) {\r\n        Object.keys(parentCard._users).filter(a => a).map(id => {\r\n            if (parentCard._users[id].isResponsible)\r\n                isResponsible = id\r\n            if (card && (!card._users || (card._users && !card._users[id]))) {\r\n                const noNotification = card._users && card._users[id] ? true : false\r\n                cardsAccess(props, id, parentCard._users[id].access, card._id, noNotification)\r\n            }\r\n        })\r\n        if (card && card._users && Object.keys(card._users).filter(a => a).length > 0)\r\n            Object.keys(card._users).filter(a => a).map(id => {\r\n                if (!parentCard._users[id] && usersToRemove.indexOf(id) === -1)\r\n                    usersToRemove.push(id)\r\n            })\r\n    }\r\n\r\n    if (usersToRemove.length > 0)\r\n        api.put(`cards/removeAccess/`, {\r\n            cardId: card._id,\r\n            userIds: usersToRemove\r\n        })\r\n    if (isResponsible)\r\n        setResponsible(props, {\r\n            cardId: card._id,\r\n            userId: isResponsible\r\n        })\r\n    if (JSON.stringify(dataUpdate) !== \"{}\")\r\n        automationExec({\r\n            _id: nodeId,\r\n            ...dataUpdate\r\n        })\r\n    linkCard({\r\n        idRel: nodeId,\r\n        destination: to,\r\n    })\r\n\r\n    if (dataUpdate && dataUpdate.status && dataUpdate.status === 'completed' && !dataUpdate.completed_at)\r\n        dataUpdate = {\r\n            ...dataUpdate,\r\n            completed_at: moment().unix('x')\r\n        }\r\n    return dataUpdate\r\n}\r\n\r\nconst automationExec = async (data) => {\r\n    let newData = {\r\n        ...data,\r\n    }\r\n    let response = await api.post('kanban/automation', newData);\r\n    return response\r\n}\r\n\r\nconst getKanbanData = id => {\r\n    const cards = reduxStore.getState().db.cards\r\n    let columns = {}\r\n    let columnsOrder = []\r\n    if (\r\n        cards\r\n        && Object.keys(cards).length > 0\r\n        && Object.keys(cards)\r\n            .filter(card =>\r\n                cards[card]._parent === id\r\n                && cards[card].type === 'step'\r\n                && !cards[card].deleted\r\n            ).length > 0\r\n    )\r\n        Object.keys(cards)\r\n            .filter(card =>\r\n                cards[card]._parent === id\r\n                && cards[card].type === 'step'\r\n                && !cards[card].deleted\r\n            ).sort((c1, c2) => {\r\n                let step1 = cards[c1].step || 1\r\n                let step2 = cards[c2].step || 1\r\n                if (parseInt(step1) < parseInt(step2))\r\n                    return -1\r\n                if (parseInt(step1) > parseInt(step2))\r\n                    return 1\r\n                return 0\r\n            }).map((column, i) => {\r\n                let items = [] //Aqui colocar todos os cards da coluna\r\n                if (Object.keys(cards).length > 0)\r\n                    Object.keys(cards).filter(cid =>\r\n                        cards[cid]._parent === column\r\n                        ||\r\n                        (\r\n                            i === 0\r\n                            && cards[cid]._parent === id\r\n                            && !cards[cid].deleted\r\n                            && (\r\n                                cards[cid].type !== 'objective'\r\n                                && cards[cid].type !== 'goal'\r\n                                && cards[cid].type !== 'step'\r\n                                && cards[cid].type.indexOf('guideline') === -1\r\n                                && cards[cid].type !== 'link'\r\n                                && cards[cid].type !== 'insight'\r\n                                && cards[cid].type !== 'threat'\r\n                                && cards[cid].type !== 'strength'\r\n                                && cards[cid].type !== 'weakness'\r\n                                && cards[cid].type !== 'opportunity'\r\n                                && cards[cid].type !== 'chatGroup'\r\n                            )\r\n                        )\r\n                    )\r\n                        .sort((ca, cb) => {\r\n                            let orderA = 0\r\n                            let orderB = 0\r\n                            if (cards[ca]?.order)\r\n                                orderA = String(cards[ca]?.order?.low ? cards[ca]?.order?.low : cards[ca]?.order)\r\n\r\n                            if (cards[cb]?.order)\r\n                                orderB = String(cards[cb]?.order?.low ? cards[cb]?.order?.low : cards[cb]?.order)\r\n                            if (parseInt(orderA) < parseInt(orderB))\r\n                                return -1\r\n                            if (parseInt(orderA) > parseInt(orderB))\r\n                                return 1\r\n                            return 0\r\n\r\n                        })\r\n                        .map((cid, cIndex) => {\r\n                            items.push({\r\n                                ...cards[cid],\r\n                                order: String(cIndex)\r\n                            })\r\n                        })\r\n                columns = {\r\n                    ...columns,\r\n                    [column]: {\r\n                        id: column,\r\n                        name: cards[column].name,\r\n                        icon: cards[column].icon || null,\r\n                        items: items\r\n                    }\r\n\r\n                }\r\n                if (columnsOrder.indexOf(column) === -1)\r\n                    columnsOrder.push(column)\r\n            })\r\n    return {\r\n        columns: columns,\r\n        columnOrder: columnsOrder\r\n    }\r\n}\r\n\r\nexport const action = async (props) => {\r\n    const {\r\n        nodeId,\r\n        reason = null,\r\n        approval = false,\r\n        approved = false\r\n    } = props\r\n    const card = reduxStore.getState().db.cards[nodeId]\r\n    const flowCard = reduxStore.getState().db.cards[card._parent]\r\n    let moveTo\r\n    if (flowCard.onConcludedStepMoveTo) {\r\n        moveTo = flowCard.onConcludedStepMoveTo\r\n    } else {\r\n        moveTo = Object.keys(reduxStore.getState().db.cards).filter(c =>\r\n            reduxStore.getState().db.cards[c]._parent === flowCard._parent\r\n            && reduxStore.getState().db.cards[c].type === \"step\"\r\n            && parseInt(reduxStore.getState().db.cards[c].step) === parseInt(flowCard.step) + 1\r\n        )[0]\r\n    }\r\n\r\n    const nextStep = reduxStore.getState().db.cards[moveTo]\r\n\r\n    if (approval) {\r\n        let dataMessage = {\r\n            _id: uuid(),\r\n            idRel: nodeId,\r\n            cardId: flowCard._id,\r\n            message: `${approved ? `$__approved` : `$__rejected`} - ${reason ? `$__reason: ${reason}` : ``}`,\r\n            type: 'log',\r\n            filesCount: 0,\r\n            approval: true,\r\n            db: 'cards'\r\n        }\r\n\r\n        await api.post(\"timeline/add\", dataMessage)\r\n\r\n        if (!approved) {\r\n\r\n            linkCard({\r\n                idRel: nodeId,\r\n                destination: flowCard._parent,\r\n            })\r\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                ...reduxStore.getState().db,\r\n                cards: {\r\n                    ...reduxStore.getState().db.cards,\r\n                    [nodeId]: {\r\n                        ...reduxStore.getState().db.cards[nodeId],\r\n                        _parent: flowCard._parent,\r\n                        requireApproval: null\r\n                    }\r\n                }\r\n            })\r\n        }\r\n    }\r\n\r\n    if (!approval || (approval && approved)) {\r\n        let dataUpdate = automation(props, nodeId, moveTo)\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...reduxStore.getState().db,\r\n            cards: {\r\n                ...reduxStore.getState().db.cards,\r\n                [nodeId]: {\r\n                    ...reduxStore.getState().db.cards[nodeId],\r\n                    ...dataUpdate,\r\n                    _parent: flowCard.onConcludedStepMoveTo,\r\n                    ...nextStep?.requireApproval ? { requireApproval: true } : { requireApproval: null }\r\n                }\r\n            }\r\n        })\r\n    }\r\n}\r\n\r\nexport {\r\n    automationExec,\r\n    addColumn,\r\n    getKanbanData,\r\n    linkCard,\r\n    reorder,\r\n}\r\n","import React from \"react\"\nimport styled from \"styled-components\"\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//COMPONENTS\nimport Card from \"components/Card\"\nimport Icon from \"components/Icon\"\nimport TextField from \"components/TextField\"\nimport CustomButton from \"components/Buttons/custom\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/CardSimple.js\"\n\n//FUNCTIONS\nimport { translate, customApp, appAlert, getDate } from \"functions/\"\n\n//FUNCTIONS\nimport { updateCardData, setCompleted } from \"functions/cards\"\n\nimport { action } from \"functions/kanban\"\n\nimport apims from \"apims\"\n\n\n\n\nfunction Component(props) {\n    const { classes } = props\n    const { db } = reduxStore.getState()\n\n    let data = props.data && props.data._id ? reduxStore.getState().db.cards[props.data._id] : {}\n\n    const [name, setName] = React.useState(data.name ? data.name : \"\")\n    const [edit, setEdit] = React.useState(false)\n    const [over, setOver] = React.useState(false)\n\n    const update = async (d) => {\n        updateCardData(\n            {\n                ...props,\n                data: { _id: data._id }\n            }, d)\n        setEdit(false)\n    }\n\n    const deleteThis = async () => {\n        appAlert({\n            message: translate(\"$__confirmDeleteThisFullDescription\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                update({ deleted: true })\n            }\n        })\n    }\n\n    return (\n        <Container\n            {...props.provided && props.provided.draggableProps}\n            {...props.key ? { key: props.key } : {}}\n            ref={props.provided && props.provided.innerRef}\n            isDragging={props.snapshot && props.snapshot.isDragging}\n            isDragDisable={data.isDragDisable || props.isDragDisable || false}\n            inLine={props.inLine}\n            selectable={props.showSelected}\n            selected={data._selected}\n            priority={data.priority ? db.priority.filter(a => String(a.value) === String(data.priority))[0].color : null}\n            locked={props.locked || false}\n            className={!props.showCard ? classes.container : classes.cardContainer}\n        >\n            <div\n                {...props.provided && props.provided.dragHandleProps}\n            >\n                {edit ?\n                    <React.Fragment>\n                        <div\n                            style={{\n                                position: \"relative\",\n                                float: \"left\",\n                                width: \"100%\",\n                                padding: \"7px\",\n                                display: \"flex\",\n                                alignItems: \"center\"\n                            }}>\n                            <div style={{\n                                width: \"calc(100% - 50px)\",\n                                display: \"flex\"\n                            }}\n                            >\n                                <TextField\n                                    label={translate(\"$__taskTitle\")}\n                                    variant={customApp(\"fieldVariant\")}\n                                    name={\"name\"}\n                                    InputLabelProps={{\n                                        shrink: true,\n                                    }}\n                                    InputProps={{\n                                        autoComplete: \"new-password\",\n                                        onChange: (d) => {\n                                            setName(d.target.value)\n                                        },\n                                        onBlur: (d) => {\n                                            if (d.target.value === \"\")\n                                                setEdit(!edit)\n                                        },\n                                        onKeyDown: (e) => {\n                                            if (e.keyCode === 13 && name) {\n                                                update({\n                                                    name\n                                                })\n                                            }\n                                            if (e.keyCode === 27) {\n                                                setEdit(!edit)\n                                                setName()\n                                            }\n                                        }\n                                    }}\n                                    autoFocus\n                                    value={name}\n                                    placeholder={translate(\"$__taskTitlePlaceholder\")}\n                                />\n                            </div>\n                            <div style={{ display: \"flex\" }}>\n                                <div\n                                    onClick={() => update({\n                                        name\n                                    })}\n                                >\n                                    <Icon color=\"green\" icon={\"save\"} title={translate(\"$__save\", \"*\")} size={props.actionsSize || \"25px\"} />\n                                </div>\n                                <div\n                                    onClick={() => {\n                                        setEdit(!edit)\n                                        setName(\"\")\n                                    }}\n                                >\n                                    <Icon color={customApp(\"medium\")} icon={\"cancel\"} title={translate(\"$__cancel\", \"*\")} size={props.actionsSize || \"25px\"} />\n                                </div>\n                            </div>\n                        </div>\n                    </React.Fragment>\n                    :\n                    <div\n                        style={{\n                            position: \"relative\",\n                            display: \"flex\",\n                            alignItems: \"center\",\n                            justifyContent: \"center\"\n                        }}\n                        onMouseOver={() => {\n                            setOver(true)\n                        }}\n                        onMouseLeave={() => {\n                            setOver(false)\n                        }}\n                    >\n\n                        <div style={{ width: \"100%\", padding: \"0px 7px\", wordBreak: \"break-word\" }}\n                            onDoubleClick={() => { setEdit(!edit) }}\n                            {...props.provided ? { provided: props.provided } : {}}\n                            {...props.snapshot ? { snapshot: props.snapshot } : {}}\n                        >\n                            {props.showCard ?\n                                <Card db=\"cards\"\n                                    data={props.data}\n                                    viewTimer\n                                    viewAllName\n                                />\n                                :\n                                data.name ? data.name : translate(\"$__new\", 1)\n                            }\n                        </div >\n                        {data.status === \"completed\" && !props.showCard ?\n                            <div\n                                style={{ position: \"absolute\", top: 0, bottom: 0, left: 0, right: 0, backgroundColor: \"rgba(0,0,0,0.05)\", display: \"flex\", alignItems: \"center\" }}\n                            >\n                                <div style={{ position: \"absolute\", top: \"50%\", marginLeft: 15, height: 1, width: \"calc(100% - 50px)\", backgroundColor: \"rgba(0,0,0,0.1)\" }}>\n                                </div>\n                                {data.completed_at ?\n                                    <div\n                                        style={{\n                                            position: \"absolute\",\n                                            right: 33,\n                                            top: \"calc(50% - 15px)\",\n                                            fontSize: 10,\n                                            textAlign: \"right\",\n                                            backgroundColor: \"#f1f1f1\",\n                                            paddingLeft: 7\n                                        }}\n                                    >{getDate(data.completed_at)}</div>\n                                    : <React.Fragment></React.Fragment>}\n\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                        {(over && props.permission && !props.noDelete && (!props.showCard || (!props.dragStatus && props.showCard))) &&\n                            <div style={{ display: \"flex\", alignItems: \"center\" }}>\n                                <CustomButton\n                                    title={translate(\"$__undoConclude\", 1)}\n                                    color={\"lightgrey\"}\n                                    icon={\"delete_forever\"}\n                                    onClick={() => deleteThis()}\n                                    transparent\n                                />\n                                {data.checklist ?\n                                    <CustomButton\n                                        title={translate(\"$__turnIntoActivity\", 1)}\n                                        color={\"lightgrey\"}\n                                        icon={\"change_circle\"}\n                                        onClick={() => {\n                                            appAlert({\n                                                message: translate(\"$__confirmTurnIntoActivity\", 1),\n                                                variant: \"warning\",\n                                                persist: false,\n                                                horizontal: \"right\",\n                                                confirm: () => {\n                                                    update({\n                                                        checklist: null\n                                                    })\n                                                }\n                                            })\n\n                                        }\n\n                                        }\n                                        transparent\n                                    />\n                                    : <React.Fragment></React.Fragment>\n                                }\n                            </div>\n                        }\n                        {(!props.showCard || (!props.dragStatus && props.showCard)) &&\n                            <CustomButton\n                                title={data.status !== \"completed\" ? translate(\"$__conclude\", 1) : translate(\"$__undoConclude\", 1)}\n                                color={data.status !== \"completed\" ? \"lightgrey\" : \"grey\"}\n                                icon={data.status !== \"completed\" ? \"radio_button_unchecked\" : \"check_circle\"}\n                                onClick={() => {\n                                    if (data._hasStep) {\n                                        action({\n                                            ...props,\n                                            nodeId: data._id,\n                                        })\n                                    } else {\n                                        setCompleted(props, data)\n                                    }\n                                }}\n                                transparent\n                            />\n                        }\n                    </div>\n                }\n            </div>\n            {props.locked ?\n                <div style={{\n                    position: \"absolute\",\n                    backgroundColor: \"rgba(233,233,233,0.88)\",\n                    top: 0,\n                    left: 0,\n                    right: 0,\n                    bottom: 0,\n                    display: \"flex\",\n                    alignItems: \"center\",\n                    justifyContent: \"center\"\n                }}>\n                    <div style={{\n                        display: \"flex\"\n                    }}>\n                        <Icon color=\"lightgray\" icon=\"lock\" size={\"22px\"} />\n                    </div>\n\n                </div>\n                :\n                <React.Fragment></React.Fragment>\n            }\n        </Container >\n    )\n}\n\nconst Container = styled.div`\n${props =>\n        props.selectable && props.selected ? `\n    opacity:1`\n            : props.selectable ? `\n    opacity:0.5`\n                : ``\n    }\n${props =>\n        props.locked ?\n            `cursor:no-drop !important`\n            : `cursor:pointer`\n    }\n${props =>\n        props.priority && !props.showCard ? ``\n            // `border-left:5px solid ${props.priority}`\n            : ``\n    }\n${props =>\n        !props.selectable && props.selected ?\n            `border-bottom:solid 5px ${customApp(\"color\")}`\n            : ``\n    }\n${props =>\n        props.isDragDisable\n            ? \"\"\n            : props.isDragging\n                ? `\n                opacity:0.88\n                max-width:320px`\n                : ``\n    }\n${props =>\n        props.inLine ?\n            `position:relative\n            float:left\n            margin:1px\n            width:calc(20% - 7px)\n            // maxWidth:320px\n            `\n            : `\n            width:calc(100%) !important\n            margin:1px 0px 1px 0px\n            `\n    }\n    width:calc(100%) !important\n`\n\n//REACT\nconst mapStateToProps = () => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component))","import Switch from '@material-ui/core/Switch';\n\n//@MATERIAL \nimport { withStyles } from \"@material-ui/core/styles\";\n\n//Styles \n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\nconst Component = withStyles({\n    switchBase: {\n        color: customApp('medium'),\n        '&$checked': {\n            color: customApp('color'),\n        },\n        '&$checked + $track': {\n            backgroundColor: customApp('color'),\n        },\n    },\n    checked: {},\n    track: {},\n})(Switch);\n\nexport default Component","import apims from \"apims\"\r\nimport api from \"api\"\r\nimport { v4 as uuid } from \"uuid\";\r\n\r\n//REDUX\r\nimport reduxStore from \"store/\"\r\n\r\n//FUNCTIONS\r\nimport { setMyDay, localAddCard, updateCardData } from \"functions/cards\"\r\n\r\nconst addCard = (newData, rows = 0, props) => {\r\n    const { session, db } = reduxStore.getState()\r\n\r\n    let data = {\r\n        ...newData\r\n    }\r\n\r\n    let parentData = {\r\n        ...newData._parent && reduxStore.getState().db.cards[newData._parent] ? reduxStore.getState().db.cards[newData._parent] : {}\r\n    }\r\n    Object.keys(data).map(x => {\r\n        if (!data[x])\r\n            delete (data[x])\r\n    })\r\n    let lines = data.name.trim().split(\"\\n\")\r\n    let count = rows\r\n\r\n    let newCards = {}\r\n    let users = {}\r\n\r\n\r\n\r\n    data.users.map((uid, i) => {\r\n        let userData = {\r\n            ...i === 0 ? {\r\n                access: 5,\r\n                isResponsible: true,\r\n                ...data.channel ? { channel: true } : {}\r\n            } : {\r\n                access: 5,\r\n            }\r\n        }\r\n\r\n        if (parentData\r\n            && db.cards[parentData._id]\r\n            && db.cards[parentData._id]._users\r\n            && db.cards[parentData._id]._users[uid]\r\n        )\r\n            userData = db.cards[parentData._id]._users[uid]\r\n        let u = db.users[uid]\r\n        users = {\r\n            ...users,\r\n            [uid]: {\r\n                _id: uid,\r\n                name: u.name,\r\n                image: u.image || null,\r\n                ...userData,\r\n            }\r\n        }\r\n    })\r\n\r\n    lines.map(async (name, nameI) => {\r\n        if (name && name.trim()) {\r\n            let newId = uuid()\r\n            api.post('card/add', {\r\n                _id: newId,\r\n                ...data,\r\n                name,\r\n                ...data.type === \"step\" ? {\r\n                    step: `${count}`\r\n                } : {\r\n                    order: `${count}`\r\n                },\r\n            });\r\n\r\n            if (data.channel)\r\n                delete data.channel\r\n\r\n            newCards = {\r\n                ...newCards,\r\n                [newId]: {\r\n                    _id: newId,\r\n                    ...data,\r\n                    name,\r\n                    _users: users,\r\n                    ...data.type === \"step\" ? {\r\n                        step: `${count}`\r\n                    } : {\r\n                        order: `${count}`\r\n                    },\r\n                }\r\n            }\r\n            if (newCards[newId]?.users)\r\n                delete newCards[newId].users\r\n            count = count + 1\r\n        }\r\n    })\r\n    return newCards\r\n}\r\n\r\nexport {\r\n    addCard\r\n}\r\n","// \r\nimport React, { useState, useLayoutEffect, useRef, useEffect } from \"react\"\r\nimport moment from \"moment-timezone\"\r\n\r\n//COMPONENTS\r\n\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport TextareaAutosize from 'react-textarea-autosize';\r\nimport SelectUsers from \"components/User/select\"\r\n\r\n\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n\r\n//STYLE\r\nimport { addCard } from \"./functions\"\r\n\r\n\r\n\r\n//FUNCTIONS\r\nimport { customApp, translate } from \"functions\"\r\n\r\nconst QuickCardAdd = (props) => {\r\n    const { session } = reduxStore.getState()\r\n    let refUsers = []\r\n    const parentCard = reduxStore.getState().db.cards[props.nodeId] || {}\r\n    if (parentCard.automationUsers && parentCard.automationUsers !== \"doNotChange\" && parentCard.automationUsers !== \"remove\" && parentCard._users && Object.keys(parentCard._users).length > 0) {\r\n        let user = reduxStore.getState().db.users[reduxStore.getState().session._id] || {}\r\n        let users = {\r\n            ...parentCard.automationUsers === 'add' ? {\r\n                [user._id]: {\r\n                    _id: user._id,\r\n                    name: user.name,\r\n                    image: user.image || null\r\n                }\r\n            } : {},\r\n            ...parentCard._users,\r\n        }\r\n        Object.keys(users)\r\n            .sort((a, b) => {\r\n                // console.log(users[a].isResponsible, users[b].isResponsible)\r\n                if (users[a].isResponsible)\r\n                    return -1\r\n                return 1\r\n            })\r\n            .map((us, i) => {\r\n                if (refUsers.indexOf(us) === -1)\r\n                    refUsers.push(us)\r\n            })\r\n    }\r\n\r\n    const [selectedUsers, setSelectedUsers] = React.useState(refUsers.length > 0 ? refUsers : [reduxStore.getState().session._id])\r\n    const inputRef = React.createRef()\r\n    const saveRef = React.createRef({})\r\n\r\n    const createCards = async (list) => {\r\n        if (saveRef && (!saveRef.current || (saveRef.current && !saveRef.current.loading))) {\r\n            saveRef.current = ({\r\n                ...saveRef.current, loading: true\r\n            })\r\n\r\n            let newData = {\r\n                name: inputRef.current.value,\r\n                _parent: props.nodeId,\r\n                myDay: props.myDay ? true : false,\r\n                type: props.type ? props.type : \"task\",\r\n                status: props.status ? props.status : \"notStarted\",\r\n                users: selectedUsers,\r\n                ...props.checklist && list ? { checklist: true } : {},\r\n                ...props.initialData ? props.initialData : {}\r\n            }\r\n\r\n            if (\r\n                parentCard\r\n                && parentCard.automationDueDateType\r\n                && parentCard.automationDueDateType === \"add\"\r\n            )\r\n                newData = {\r\n                    ...newData,\r\n                    startDate: moment(`${moment().format(\"YYYY-MM-DD\")} 00:00:00`).unix(\"X\"),\r\n                    endDate: moment(`${moment().format(\"YYYY-MM-DD\")} 23:59:59`).add(parentCard?.automationDueDate || 1, \"days\").unix(\"X\")\r\n                }\r\n\r\n            if (parentCard\r\n                && parentCard.automationStatusType\r\n                && parentCard.automationStatusType === \"replace\"\r\n            )\r\n                newData = {\r\n                    ...newData,\r\n                    status: parentCard.automationStatus || 'notStarted',\r\n                    ...parentCard.automationStatus && parentCard.automationStatus === 'completed' ? { completed_at: moment().unix('x') } : {}\r\n                }\r\n\r\n            let result = addCard(newData, props.rows || 0, props)\r\n\r\n            if (result) {\r\n                props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                    ...reduxStore.getState().db,\r\n                    cards: {\r\n                        ...reduxStore.getState().db.cards,\r\n                        ...result\r\n                    }\r\n                })\r\n                if (props.onSave)\r\n                    props.onSave()\r\n            }\r\n        }\r\n\r\n\r\n        saveRef.current = ({\r\n            ...saveRef.current, loading: false\r\n        })\r\n        if (props.onCancel)\r\n            props.onCancel()\r\n    }\r\n\r\n    return (\r\n        <div\r\n            style={{\r\n                position: 'absolute',\r\n                top: 0,\r\n                left: 0,\r\n                bottom: 0,\r\n                right: 0,\r\n                backgroundColor: props.backgroundColor || \"rgba(250,250,250,0.77)\",\r\n                width: '100%',\r\n                padding: '7px',\r\n                display: 'flex',\r\n                alignItems: 'center',\r\n                ...props.styles ? props.styles : {}\r\n            }}>\r\n            <div style={{ width: 'calc(100% - 50px)' }}>\r\n                <div\r\n                    style={{\r\n                        position: \"relative\",\r\n                        width: \"100%\",\r\n                        padding: 3\r\n                    }}\r\n                >{props.placeHolder ? props.placeHolder : translate(props.checklist && !props.myDay ? \"$__newSimpleTask\" : \"$__newSubActivity\")}</div>\r\n                {props.explain ?\r\n                    <div\r\n                        style={{\r\n                            position: \"relative\",\r\n                            width: \"100%\",\r\n                            padding: 3,\r\n                            color: customApp(\"menu\")\r\n                        }}\r\n                    >{props.explain}</div>\r\n                    : <React.Fragment></React.Fragment>}\r\n                <TextareaAutosize\r\n                    ref={inputRef}\r\n                    style={{\r\n                        width: \"100%\",\r\n                        padding: 7,\r\n                        border: \"none\",\r\n                        borderBottom: `solid 1px ${customApp(\"color\")}`,\r\n                        background: \"none\",\r\n                        resize: \"none\",\r\n                        fontFamily: \"inherit\",\r\n                        fontSize: 14,\r\n                    }}\r\n                    onKeyDown={(e) => {\r\n                        const keyCode = e.which || e.keyCode;\r\n                        if (keyCode === 13 && !e.shiftKey) {\r\n                            e.preventDefault();\r\n                            if (\r\n                                inputRef.current\r\n                                && inputRef.current.value\r\n                                && inputRef.current.value.trim().length > 0\r\n                            )\r\n                                createCards(props.checklist && !props.myDay ? true : false)\r\n                            return\r\n                        }\r\n                        if (\r\n                            keyCode === 13\r\n                            && e.shiftKey\r\n                            && inputRef.current\r\n                            && inputRef.current.value\r\n                            && inputRef.current.value.trim().length === 0) {\r\n                            e.preventDefault();\r\n                            inputRef.current.value = \"\"\r\n                            return\r\n                        }\r\n\r\n                        if (keyCode === 27 && props.onCancel) {\r\n                            props.onCancel()\r\n                            return\r\n                        }\r\n                    }}\r\n                    autoFocus={true}\r\n                />\r\n                <SelectUsers\r\n                    includeMe\r\n                    defineResponsible\r\n                    avatarSize=\"23px\"\r\n                    permission={true}\r\n                    noLimit\r\n                    multiple\r\n                    onSelect={(e) => {\r\n                        setSelectedUsers(e)\r\n                    }}\r\n                    selected={selectedUsers}\r\n                    transparent\r\n                />\r\n            </div>\r\n            <div style={{ display: 'flex' }}>\r\n                <CustomButton\r\n                    id={`sideModule_saveButton`}\r\n                    title={props.placeHolder || translate(`$__save`, 1)}\r\n                    color={'green'}\r\n                    icon={\"save\"}\r\n                    onClick={() => {\r\n                        if (!inputRef.current.value || (\r\n                            inputRef.current.value\r\n                            && inputRef.current.value.trim() === \"\"\r\n                        )) {\r\n                            inputRef.current.focus()\r\n                        } else {\r\n                            createCards(props.checklist && !props.myDay ? true : false)\r\n                        }\r\n                    }\r\n                    }\r\n                    size={\"25px\"}\r\n                />\r\n                <CustomButton\r\n                    id={`sideModule_saveButton`}\r\n                    title={translate(`$__cancel`, 1)}\r\n                    color={customApp(\"medium\")}\r\n                    icon={\"cancel\"}\r\n                    onClick={() => {\r\n                        if (props.onCancel) {\r\n                            props.onCancel()\r\n                        }\r\n                    }}\r\n                    size={\"25px\"}\r\n                />\r\n            </div>\r\n        </div>\r\n    )\r\n}\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(null, mapDispatchToProps)(QuickCardAdd)","//CORE\r\nimport React from \"react\"\r\nimport styled from \"styled-components\"\r\nimport { DragDropContext, Droppable, Draggable } from \"react-beautiful-dnd\"\r\nimport moment from \"moment-timezone\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n//COMPONENTS\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport SimpleCard from \"./Card.js\"\r\nimport Switch from \"components/Switch\"\r\nimport TextareaAutosize from 'react-textarea-autosize'\r\nimport QuickCardAdd from \"components/Quick/card\"\r\n\r\n//@MATERIAL\r\nimport CustomIconButton from \"components/CustomButtons/IconButton\"\r\n\r\n//FUNCTIONS\r\nimport { translate, customApp } from \"functions/\"\r\nimport { setMyDay, localAddCard, updateCardData } from \"functions/cards\"\r\n\r\nfunction Component(props) {\r\n    const { db, session } = reduxStore.getState()\r\n    const { socket } = reduxStore.getState().functions\r\n    const [name, setName] = React.useState(props.name ? props.name : '')\r\n    const [add, setAdd] = React.useState(false)\r\n    const [addLoad, setAddLoad] = React.useState(false)\r\n    const [dragStatus, setDragStatus] = React.useState(false)\r\n    const [checklist, setChecklist] = React.useState(false)\r\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD')\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace('#', '')\r\n    if (hashs[0].length !== 36) {\r\n        hashs[0] = null\r\n    }\r\n\r\n    let parent = {}\r\n    if (reduxStore.getState().db[props.db] && reduxStore.getState().db[props.db][props.nodeId])\r\n        parent = reduxStore.getState().db[props.db][props.nodeId]\r\n\r\n\r\n    const tasksCards = Object.keys(reduxStore.getState().db.cards)\r\n        .filter(fil => {\r\n            if (\r\n                !props.myDay\r\n                && reduxStore.getState().db.cards[fil].type !== \"step\"\r\n                && (\r\n                    (\r\n                        !props.noChecklist\r\n                        && reduxStore.getState().db.cards[fil]\r\n                        && !reduxStore.getState().db.cards[fil].deleted\r\n                        // && reduxStore.getState().db.cards[fil].checklist\r\n                        && reduxStore.getState().db.cards[fil]._parent === props.nodeId\r\n                    )\r\n                    ||\r\n                    (\r\n                        props.noChecklist\r\n                        && !reduxStore.getState().db.cards[fil].deleted\r\n                        // && (\r\n                        //     !reduxStore.getState().db.cards[fil].checklist\r\n                        //     || reduxStore.getState().db.cards[fil].showCard\r\n                        // )\r\n                        && reduxStore.getState().db.cards[fil]._parent === props.nodeId\r\n                    )\r\n                )\r\n            )\r\n                return true\r\n            if (\r\n                props.myDay\r\n                &&\r\n                (\r\n                    db.cards[fil]._users\r\n                    && db.cards[fil]._users[session._id]\r\n                    && db.cards[fil]._users[session._id].myDay\r\n                    && (\r\n                        moment(new Date(db.cards[fil]._users[session._id].myDay * 1000)).tz('America/Sao_Paulo').format('YYYY/MM/DD') === today\r\n                    )\r\n                    && reduxStore.getState().db.cards[fil]\r\n                    && !reduxStore.getState().db.cards[fil].deleted\r\n                    // && (\r\n                    //     !reduxStore.getState().db.cards[fil].checklist\r\n                    //     || reduxStore.getState().db.cards[fil].showCard\r\n                    // )\r\n                )\r\n            ) {\r\n                return true\r\n            }\r\n        }\r\n        )\r\n        .sort((a, b) => {\r\n            let orderA = db.cards[a] && db.cards[a].order && !db.cards[a].order.low ? parseInt(db.cards[a].order) : db.cards[a].order && db.cards[a].order.low ? parseInt(db.cards[a].order.low) : 0\r\n            let orderB = db.cards[b] && db.cards[b].order && !db.cards[b].order.low ? parseInt(db.cards[b].order) : db.cards[b].order && db.cards[b].order.low ? parseInt(db.cards[b].order.low) : 0\r\n            if (orderA < orderB)\r\n                return -1\r\n            if (orderA > orderB)\r\n                return 1\r\n            return 0\r\n        })\r\n        .map(card => card)\r\n\r\n\r\n    const addCard = async (n = 0) => {\r\n        setAddLoad(true)\r\n        let lines = name.trim().split(\"\\n\")\r\n\r\n        const { socket } = reduxStore.getState().functions\r\n        let type = 'task'\r\n\r\n        let no = tasksCards.length + 1\r\n\r\n\r\n        // return\r\n\r\n        if (props.noChecklist && parent && parent.type) {\r\n            if (parent.type.indexOf('guideline') > -1)\r\n                type = 'objective'\r\n            if (parent.type === 'objective')\r\n                type = 'goal'\r\n            if (parent.type === 'goal')\r\n                type = 'task'\r\n        }\r\n\r\n        tasksCards.map(r => {\r\n            if (db.cards[r] && String(db.cards[r].order) && parseInt(db.cards[r].order) > parseInt(no))\r\n                no = parseInt(db.cards[r].order) + 1\r\n        })\r\n\r\n        let addText = lines[n]\r\n        let newOrder = no + n\r\n\r\n        socket.emit(\"data\", {\r\n            module: \"cards\",\r\n            method: \"post\",\r\n            action: \"add\"\r\n        }, {\r\n            _parent: parent && parent._id ? parent._id : null,\r\n            planId: parent._planId ? parent._planId : null,\r\n            name: addText,\r\n            type,\r\n            checklist: !props.noChecklist ? true : false,\r\n            order: String(newOrder),\r\n            status: 'notStarted'\r\n        }, async (response) => {\r\n            let cardData = {\r\n                ...response.data,\r\n                _parent: parent._id,\r\n                _planId: parent._planId ? parent._planId : null,\r\n                _timeline: {\r\n                    [response.log._id]: {\r\n                        ...response.log,\r\n                        _parent: [response.id],\r\n                    }\r\n                },\r\n                _users: {\r\n                    [session._id]: {\r\n                        name: reduxStore.getState().db.users[session._id].name ? reduxStore.getState().db.users[session._id].name : null,\r\n                        displayName: reduxStore.getState().db.users[session._id].displayName ? reduxStore.getState().db.users[session._id].displayName : null,\r\n                        image: reduxStore.getState().db.users[session._id].image ? reduxStore.getState().db.users[session._id].image : null,\r\n                        access: 5,\r\n                        _id: session._id\r\n                    }\r\n                }\r\n            }\r\n\r\n            if (props.myDay) {\r\n                setMyDay(props, { _id: response.id, userId: session._id, option: true }, {\r\n                    new: true,\r\n                    user: session._id,\r\n                    cardId: response.id,\r\n                    data: cardData,\r\n                })\r\n            } else {\r\n                localAddCard(props, { _id: response.id, userId: session._id, option: true }, {\r\n                    new: true,\r\n                    user: session._id,\r\n                    cardId: response.id,\r\n                    data: cardData,\r\n                })\r\n\r\n            }\r\n            if (lines.length > n + 1) {\r\n                setAdd(false)\r\n                addCard(n + 1)\r\n            } else {\r\n                setName(\"\")\r\n                setAddLoad(false)\r\n            }\r\n        })\r\n    }\r\n\r\n    const onDragEnd = async result => {\r\n        setDragStatus(false)\r\n        const { destination, source, draggableId } = result\r\n\r\n        if (!destination) return false\r\n\r\n        if (destination.droppableId === source.droppableId && destination.id === source.index) return false\r\n\r\n        let itemOrderIds = Array.from(\r\n            tasksCards\r\n                .filter(card => db.cards[card].status !== \"completed\")\r\n                .sort((a, b) => {\r\n                    let orderA = db.cards[a].order || 0\r\n                    if (String(orderA.low))\r\n                        orderA = parseInt(orderA.low)\r\n\r\n                    let orderB = db.cards[b].order || 0\r\n                    if (String(orderB.low))\r\n                        orderB = parseInt(orderB.low)\r\n\r\n                    if (orderA < orderB)\r\n                        return -1\r\n                    if (orderA > orderB)\r\n                        return 1\r\n                    return 0\r\n                })\r\n                .map(card => card)\r\n        )\r\n\r\n        itemOrderIds.splice(source.index, 1)\r\n        await setTimeout(500)\r\n\r\n        itemOrderIds.splice(destination.index, 0, draggableId)\r\n        await setTimeout(500)\r\n\r\n        socket.emit(\"data\", {\r\n            module: \"cards\",\r\n            method: \"put\",\r\n            action: \"reorder\"\r\n        }, {\r\n            cards: itemOrderIds\r\n        })\r\n\r\n        let newCards = {\r\n            ...reduxStore.getState().db.cards\r\n        }\r\n\r\n        let reorderAwait = await new Promise((resolve, reject) => {\r\n            itemOrderIds.map((a, i) => {\r\n                newCards = {\r\n                    ...newCards,\r\n                    [a]: {\r\n                        ...newCards[a],\r\n                        order: `${i + 1}`\r\n                    }\r\n                }\r\n                if (i + 1 === itemOrderIds.length)\r\n                    resolve(true)\r\n            })\r\n        })\r\n        if (reorderAwait)\r\n            props.reduxFunction(\"IMMEDIATE\", \"SET_DB\", {\r\n                ...db,\r\n                cards: {\r\n                    ...db.cards,\r\n                    ...newCards\r\n                }\r\n            })\r\n        return\r\n\r\n    }\r\n\r\n    const onDragStart = async result => {\r\n        setDragStatus(true)\r\n    }\r\n\r\n    const onDragUpdate = async result => {\r\n    }\r\n\r\n    let openCards = tasksCards\r\n        .filter(card => db.cards[card].status !== \"completed\")\r\n        .sort((a, b) => {\r\n            let orderA = db.cards[a] && db.cards[a].order && !db.cards[a].order.low ? parseInt(db.cards[a].order) : db.cards[a].order && db.cards[a].order.low ? parseInt(db.cards[a].order.low) : 0\r\n            let orderB = db.cards[b] && db.cards[b].order && !db.cards[b].order.low ? parseInt(db.cards[b].order) : db.cards[b].order && db.cards[b].order.low ? parseInt(db.cards[b].order.low) : 0\r\n            if (orderA < orderB)\r\n                return -1\r\n            if (orderA > orderB)\r\n                return 1\r\n            return 0\r\n        })\r\n\r\n    return (\r\n        <div style={{ width: '100%' }} onClick={(e) => e.stopPropagation()}>\r\n            {props.permission ?\r\n                <div style={{\r\n                    width: '100%',\r\n                    position: 'relative',\r\n                    display: 'flex',\r\n                    alignItems: \"center\",\r\n                    padding: \"3px 10px\",\r\n                    justifyContent: \"center\",\r\n                }}>\r\n                    <div style={{ marginRight: 15 }}>\r\n                        {translate(\"$__requireConcludedByStep\")}\r\n                    </div>\r\n                    <Switch\r\n                        checked={parent.listStepLock ? true : false}\r\n                        onChange={() => {\r\n                            updateCardData(\r\n                                {\r\n                                    ...props,\r\n                                    data: { _id: parent._id }\r\n                                }, {\r\n                                listStepLock: parent.listStepLock ? false : true\r\n                            })\r\n\r\n                        }}\r\n                        name=\"listStepLock\"\r\n                        inputProps={{ \"aria-label\": \"secondary checkbox\" }}\r\n                    />\r\n                    <CustomButton\r\n                        title={translate(\"$__openBoard\")}\r\n                        text={translate(\"$__openBoard\")}\r\n                        color={\"lightgrey\"}\r\n                        textColor={\"lightgrey\"}\r\n                        icon={\"open_in_new\"}\r\n                        onClick={() => {\r\n                            props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                ...reduxStore.getState().control,\r\n                                board: props.nodeId,\r\n                            })\r\n                            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\r\n                        }}\r\n                        size={\"25px\"}\r\n                    />\r\n                </div>\r\n                : <React.Fragment></React.Fragment>}\r\n\r\n            {props.showProgress && tasksCards.length > 0 ?\r\n                <div\r\n                    style={{\r\n                        position: \"relative\",\r\n                        width: \"100%\",\r\n                    }}\r\n                >\r\n                    <div style={{\r\n                        position: \"absolute\",\r\n                        right: 7,\r\n                        bottom: 0,\r\n                        fontSize: 9,\r\n                        color: customApp(\"menu\"),\r\n                        fontWeight: \"bold\"\r\n                    }}>\r\n                        {tasksCards.filter(card => db.cards[card].status === \"completed\").length}/<span style={{ fontWeight: \"normal\" }}>{tasksCards.length}</span>\r\n                    </div>\r\n                    <div\r\n                        style={{\r\n                            position: \"relative\",\r\n                            width: \"100%\",\r\n                            height: 5,\r\n                            backgroundColor: \"lightGray\"\r\n                        }}\r\n                    >\r\n                        <div\r\n                            style={{\r\n                                position: \"absolute\",\r\n                                top: 0,\r\n                                left: 0,\r\n                                bottom: 0,\r\n                                backgroundColor: customApp(\"menu\"),\r\n                                width: `${(100 / tasksCards.length) * tasksCards.filter(card => db.cards[card].status === \"completed\").length}%`\r\n                            }}\r\n                        >\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n            {\r\n                tasksCards.filter(card => db.cards[card].status !== \"completed\").length > 0 ?\r\n                    <DragDropContext\r\n                        onDragEnd={onDragEnd}\r\n                        onDragStart={onDragStart}\r\n                        onDragUpdate={onDragUpdate}\r\n                    >\r\n                        <Droppable\r\n                            droppableId={`Drop_tasks`} //ID OF BOARD\r\n                            type=\"column\"\r\n                            direction={\"vertical\"}\r\n                        >\r\n                            {(provided, snapshot) => (\r\n                                <Container\r\n                                    ref={provided.innerRef}\r\n                                    {...provided.droppableProps}\r\n                                    isDraggingOver={snapshot.isDraggingOver}\r\n                                >\r\n                                    {openCards\r\n                                        .map((card, index) => {\r\n                                            return (\r\n                                                <Draggable\r\n                                                    draggableId={card}\r\n                                                    index={index}\r\n                                                    key={`${card}${index}`}\r\n                                                >\r\n                                                    {(provided, snapshot) => (\r\n                                                        <SimpleCard\r\n                                                            dragStatus={dragStatus}\r\n                                                            provided={provided}\r\n                                                            snapshot={snapshot}\r\n                                                            data={db.cards[card]}\r\n                                                            db={'cards'}\r\n                                                            selectable\r\n                                                            noDelete={props.noDelete ? props.noDelete : false}\r\n                                                            showCard={(!db.cards[card].checklist || (db.cards[card].checklist && (props.showCard || db.cards[card].showCard))) ? true : false}\r\n                                                            permission={props.permission}\r\n                                                            locked={parent.listStepLock && index > 0 && db.cards[openCards[index - 1]].status !== \"completed\"}\r\n                                                        />\r\n                                                    )}\r\n                                                </Draggable>\r\n                                            )\r\n                                        }\r\n                                        )}\r\n                                    {provided.placeholder}\r\n                                </Container>\r\n                            )}\r\n                        </Droppable>\r\n                    </DragDropContext>\r\n                    : <React.Fragment></React.Fragment>\r\n            }\r\n            {\r\n                tasksCards.filter(card => db.cards[card].status === \"completed\").length > 0 ?\r\n                    <React.Fragment>\r\n                        {tasksCards\r\n                            .filter(card => db.cards[card].status === \"completed\")\r\n                            .sort((a, b) => {\r\n                                let dataA = 0\r\n                                let dataB = 0\r\n                                if (db.cards[a].completed_at && db.cards[a].completed_at.low)\r\n                                    dataA = parseInt(db.cards[a].completed_at.low)\r\n\r\n                                if (db.cards[b].completed_at && db.cards[b].completed_at.low)\r\n                                    dataB = parseInt(db.cards[b].completed_at.low)\r\n\r\n                                if (dataA > dataB)\r\n                                    return -1\r\n                                if (dataA < dataB)\r\n                                    return 1\r\n\r\n                                return 0\r\n                            })\r\n                            .map((card, index) =>\r\n                                <div key={`${card}${index}`}>\r\n                                    <SimpleCard\r\n                                        dragStatus={dragStatus}\r\n                                        data={db.cards[card]}\r\n                                        db={'cards'}\r\n                                        selectable\r\n                                        noDelete={props.noDelete ? props.noDelete : false}\r\n                                        showCard={(!db.cards[card].checklist || (db.cards[card].checklist && (props.showCard || db.cards[card].showCard))) ? true : false}\r\n                                        permission={props.permission}\r\n                                        locked={parent.listStepLock && index > 0 && db.cards[openCards[index - 1]].status !== \"completed\"}\r\n                                    />\r\n                                </div>\r\n                            )}\r\n                    </React.Fragment>\r\n                    : <React.Fragment></React.Fragment>\r\n            }\r\n            {\r\n                !add && !addLoad && (props.permission || props.myDay) &&\r\n                <div style={{ position: 'relative', float: 'right', width: '100%', padding: '7px', display: 'flex', alignContent: 'flex-end', justifyContent: 'center' }}>\r\n                    {/* <div> */}\r\n                    <CustomIconButton\r\n                        // reverse\r\n                        text={translate(\"$__new\", '*')}\r\n                        icon=\"add_box\"\r\n                        iconColor={customApp('color')}\r\n                        onClick={() => {\r\n                            setAdd(!add)\r\n                            setChecklist(false)\r\n                        }}\r\n                        style={{ padding: 7 }}\r\n                    />\r\n                    {!props.myDay ?\r\n                        <CustomIconButton\r\n                            // reverse\r\n                            text={translate(\"$__newSimpleTask\", '*')}\r\n                            icon=\"playlist_add\"\r\n                            iconColor={customApp('medium')}\r\n                            onClick={() => {\r\n                                setAdd(!add)\r\n                                setChecklist(true)\r\n                            }}\r\n                            style={{ padding: 7 }}\r\n                        />\r\n                        : <React.Fragment></React.Fragment>\r\n                    }\r\n                </div>\r\n            }\r\n            {\r\n                add && !addLoad ?\r\n                    <QuickCardAdd\r\n                        nodeId={parent._id}\r\n                        checklist={checklist}\r\n                        onCancel={() => setAdd(false)}\r\n                        rows={tasksCards.length}\r\n                        myDay={props.myDay || false}\r\n                    />\r\n                    :\r\n                    addLoad ?\r\n                        <div style={{\r\n                            position: 'relative',\r\n                            float: 'right',\r\n                            width: '100%',\r\n                            padding: '7px',\r\n                            display: 'flex',\r\n                            alignContent: 'flex-end',\r\n                            justifyContent: 'center',\r\n                            color: customApp(\"menu\")\r\n                        }}>\r\n                            {translate(\"$__saving\")}\r\n                        </div>\r\n                        : <React.Fragment></React.Fragment>\r\n            }\r\n        </div >\r\n    )\r\n}\r\n\r\nconst Container = styled.div`\r\n            background-color:none\r\n            ${props =>\r\n        props.isDragDisable\r\n            ? \"\"\r\n            : props.isDragging\r\n                ? `opacity:0.88`\r\n                : ``\r\n    }\r\n            `\r\n\r\nconst mapStateToProps = (store) => ({\r\n    cards: store.db.cards,\r\n}\r\n)\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","import React from \"react\"\n\n//REDUX\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport Badge from \"components/Icon/Badge\"\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\"\n\n//FUNCTIONS\nimport {\n    customApp,\n    getAppAccess,\n    translate,\n} from \"functions/\"\nimport {\n    connectInMount,\n    getUserAccess,\n    planAccountVerify,\n} from \"functions/cards\"\n\nfunction ConnectedIn(props) {\n    const { db, session } = reduxStore.getState()\n    const connectedIn = connectInMount(props.id)\n\n    let AppAccess = getAppAccess()\n\n    if (Object.keys(connectedIn).length === 0)\n        return null\n\n    const returnConnections = Object.keys(connectedIn).map((a, i) => {\n        let connectedCardAccess = getUserAccess(a)\n        if (connectedIn[a].icon && connectedIn[a].type && connectedIn[a].name)\n            return (\n                <div style={{ marginRight: '10px', width: '100%' }} key={i}>\n                    <div style={{ display: 'flex', cursor: 'pointer' }}\n                        onClick={\n                            (props.open\n                                && (\n                                    (\n                                        (\n                                            (AppAccess.planAdmin\n                                                || AppAccess.planModerate\n                                            )\n                                            &&\n                                            (\n                                                db.cards[connectedIn[a]._id].type !== 'plan'\n                                                || (\n                                                    db.cards[connectedIn[a]._id].type === 'plan'\n                                                    && planAccountVerify(connectedIn[a]._id)\n                                                )\n                                            )\n                                        )\n                                        || connectedCardAccess >= 1\n                                    ) &&\n                                    (\n                                        !db.cards[connectedIn[a]._id].private ||\n                                        (\n                                            db.cards[connectedIn[a]._id].private &&\n                                            db.cards[connectedIn[a]._id]._users &&\n                                            db.cards[connectedIn[a]._id]._users[session._id]\n                                        )\n                                    )\n                                )\n                            )\n                                ? (e) => {\n                                    props.open(connectedIn[a]._id)\n                                    e.stopPropagation()\n                                } : null}\n                    >\n                        <Badge\n                            overlap=\"rectangular\"\n                            icon={connectedIn[a].icon}\n                            title={`${translate(`$__${connectedIn[a].type}`, '*')}: ${connectedIn[a].name}`}\n                            size=\"16px\"\n                            color={customApp(\"color\")}\n                        />\n                        <span style={{ marginLeft: '5px' }}>\n                            {connectedIn[a].name}\n                        </span>\n                    </div>\n                    <div style={{ clear: \"both\" }}></div>\n                </div>\n            )\n    }\n    )\n    return (\n        <div style={{ width: 'calc(100% - 5px)' }} onClick={(e) => { e.stopPropagation() }}>\n            {props.showLegend ?\n                <fieldset style={{ marginBottom: '14px', width: '100%' }}>\n                    <legend>{translate(props.legend || '$__connectedIn', 1)}</legend>\n                    {returnConnections}\n                </fieldset>\n                : returnConnections\n            }\n            <div style={{ clear: \"both\" }}></div>\n        </div>\n    )\n}\n\nexport default ConnectedIn","import React from \"react\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\n\n//@MATERIAL\nimport Tooltip from \"@material-ui/core/Tooltip\";\nimport IconButton from '@material-ui/core/IconButton';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport Grow from '@material-ui/core/Grow';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport MenuList from '@material-ui/core/MenuList';\nimport { makeStyles } from '@material-ui/core/styles';\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\";\n\n\nconst useStyles = makeStyles((props) => ({\n    iconButtonStyleTransaparent: {\n        margin: 0,\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        }\n    },\n    iconButtonStyleWhite: {\n        margin: 0,\n        backgroundColor: '#FFFFFF',\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        }\n    },\n}));\n\nfunction Comp(props) {\n    const classes = useStyles();\n    const [open, setOpen] = React.useState(false);\n    const anchorRef = React.useRef(null)\n\n    const handleToggle = (e) => {\n        setOpen((prevOpen) => !prevOpen);\n        e.stopPropagation()\n    };\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n        setOpen(false);\n    };\n\n    return (\n        <div\n            onClick={(e) => {\n                e.stopPropagation()\n            }}\n            style={{ zIndex: 100 }}\n        >\n            <Tooltip\n                title={translate(`$__options`, 1)}\n            >\n                <IconButton\n                    ref={anchorRef}\n                    aria-controls={open ? 'menu-list-grow' : undefined}\n                    aria-haspopup=\"true\"\n                    aria-label=\"menu\"\n                    onClick={(e) => {\n                        setOpen((prevOpen) => !prevOpen);\n                        if (props.onClick)\n                            props.onClick()\n                        e.stopPropagation()\n                    }}\n                    className={!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}\n                >\n                    <Icon\n                        usePropagation\n                        size={!props.size ? \"20px\" : props.size}\n                        color={props.iconColor ? props.iconColor : customApp('menu')}\n                        icon={props.icon ? props.icon : 'design_services'}\n                        title={props.title ? props.title : \"NO_ALIAS\"}\n                    />\n                </IconButton>\n            </Tooltip>\n            <Popper open={open} anchorEl={anchorRef.current} role={undefined} transition>\n                {({ TransitionProps, placement }) => (\n                    <Grow\n                        {...TransitionProps}\n                        style={{\n                            transformOrigin: placement === 'bottom' ? 'center top' : 'center bottom',\n                        }}\n                    >\n                        <Paper>\n                            <ClickAwayListener onClickAway={handleClose}>\n                                <div\n                                    onClick={(e) => {\n                                        e.stopPropagation()\n                                        e.preventDefault()\n                                    }}\n                                >\n                                    {React.cloneElement(props.children, {\n                                        callBack: (e) => {\n                                            setOpen(false);\n                                        }\n                                    })}\n                                </div>\n                            </ClickAwayListener>\n                        </Paper>\n                    </Grow>\n                )}\n            </Popper>\n        </div >\n    )\n}\nexport default Comp;\n","import React from \"react\";\nimport Chartist from \"chartist\";\nimport ChartistGraph from \"react-chartist\";\n\n//COMPONENTS\nimport LinearProgress from \"components/Progress/linear\";\nimport KpiDescription from \"components/KPI/dataSave\";\nimport PopperMenu from \"components/PopperMenu\";\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//FUNCTIONS\nimport { translate, customApp, formatNumber } from \"functions/\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/KPI_change.js\";\n\nimport {\n    model\n} from \"variables/charts\";\nimport {\n    loadTimeline,\n} from \"functions/chat\";\n\nimport \"assets/css/components/chart.css\";\nrequire(\"chartist-plugin-tooltips\");\n\nconst Component = (props) => {\n    const { classes, data } = props\n    const { db, timeline } = reduxStore.getState()\n    const { cards } = db\n    const [mounted, setMounted] = React.useState(false)\n    const [PositiveValue, setPositiveValue] = React.useState(true)\n    // const [data, setData] = React.useState({ ...reduxStore.getState().db.cards[props.data._id] })\n    const [loading, setLoading] = React.useState(true)\n    const [cardsWithKpi, setCardsWithKpi] = React.useState([])\n\n    let kpi_ini = parseFloat(data.kpi_ini)\n    let kpi_fin = parseFloat(data.kpi_fin)\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true)\n            childrenCards(props.data._id)\n            iniKpi()\n        }\n    }, [])\n\n    React.useEffect(() => {\n        childrenCards(props.data._id)\n    }, [cards])\n\n    const iniKpi = async () => {\n        if (\n            timeline\n            && (\n                !timeline[data._id]\n                ||\n                (\n                    timeline[data._id]\n                    && Object.keys(timeline[data._id]).filter(l => timeline[data._id][l].type === 'kpi').length === 0\n                )\n            )\n        ) {\n            const result = await loadTimeline(\n                {\n                    ...props,\n                    fnIdentification: \"Timeline/Index/init()\"\n                },\n                {\n                    ids: [data._id],\n                    db: 'cards',\n                    reqChildrens: true,\n                    type: 'kpi',\n                    limit: true\n                }\n            )\n            if (result)\n                setLoading(false)\n        } else {\n            setLoading(false)\n        }\n    }\n\n    //Filter all Children Cards with KPI = kpi_useParent\n    let kpiCards = [props.data._id]\n    const childrenCards = async (cardId, children) => {\n        let chields = Object.keys(cards)\n            .filter(a => cards[a].kpi_useParent && cards[a]._parent === cardId)\n        if (chields.length > 0) {\n            chields.map(async a => {\n                childrenCards(a, true)\n                kpiCards.push(a)\n                setCardsWithKpi(Array.from(new Set(kpiCards)))\n            })\n        } else if (!children) {\n            setCardsWithKpi(kpiCards)\n        }\n        return chields\n    }\n\n    if (!data)\n        return (null)\n\n    let kpiChart = {\n        ...model\n    }\n\n    let series = []\n    let labels = []\n\n    let kpi_flow = {}\n    cardsWithKpi.map(a => {\n        kpi_flow = {\n            ...kpi_flow,\n            ...timeline[a] || {}\n        }\n    })\n\n\n    kpi_flow = Object.keys(kpi_flow).filter(a => kpi_flow[a].type === 'kpi' && kpi_flow[a].kpi_type === data.kpi_type).map(a => kpi_flow[a])\n\n    let kpi_total = data.kpi_type !== 'time' ? parseFloat(kpi_ini) : 0\n    let percent100 = parseFloat(kpi_ini) - parseFloat(kpi_fin)\n    let accomplished = 0\n    if (percent100 < 0) percent100 = percent100 * -1\n\n    if (kpi_flow && Object.keys(kpi_flow).length > 0) {\n        Object.keys(kpi_flow).sort((a, b) => {\n            if (kpi_flow[a].created_at < kpi_flow[b].created_at)\n                return -1\n            return 1\n        }).map((a, i) => {\n            kpi_total = parseFloat(kpi_total) + parseFloat(kpi_flow[a].value)\n            accomplished = accomplished + parseFloat(kpi_flow[a].value)\n            series.push({\n                meta: kpi_flow[a].value,\n                total: kpi_total,\n                value: parseFloat(kpi_ini) > parseFloat(kpi_fin) ? 100 - Math.floor((kpi_total * 100) / percent100) : Math.floor((kpi_total * 100) / percent100),\n            })\n            labels.push(i + 1)\n            if (i + 1 === Object.keys(kpi_flow).length)\n                kpiChart = {\n                    ...kpiChart,\n                    data: {\n                        labels: labels,\n                        series: [[...series]]\n                    },\n                    options: {\n                        //fullWidth: true,\n                        ...kpiChart.options,\n                        low: 0,\n                        high: 100,\n                        plugins: [Chartist.plugins.tooltip({\n                            tooltipFnc: function (meta, value, name) {\n                                return (\n                                    `${meta > 0 ? '+' : ''}` +\n                                    formatNumber(meta, data.kpi_type === 'time' ? 'number' : data.kpi_type, data.kpi_currency ? data.kpi_currency : null) + '<br>' + formatNumber(value, 'percent')\n                                );\n                            }\n                        })],\n                        axisX: {\n                            showGrid: false,\n                        },\n                        axisY: {\n                            showGrid: false,\n                        },\n                        onlyInteger: true,\n                    },\n                }\n        })\n    }\n\n\n\n    let sumKpi = kpi_ini < kpi_fin ? kpi_fin - kpi_ini : kpi_ini - kpi_fin\n    let goalKpi = sumKpi\n\n\n    if (kpi_flow && Object.keys(kpi_flow).length > 0) {\n        Object.keys(kpi_flow).map(a => {\n            sumKpi = parseFloat(sumKpi) + parseFloat(kpi_flow[a].value)\n        })\n    }\n    let goalValue = goalKpi - (sumKpi - goalKpi)\n    let balanceValue = goalKpi - (goalKpi - sumKpi)\n\n    let percentKpi = Math.ceil(kpi_ini < kpi_fin ? kpi_fin - kpi_ini : kpi_ini - kpi_fin)\n    percentKpi = ((Math.ceil(sumKpi) * 100) / percentKpi) - 100\n    if (percentKpi < 0)\n        percentKpi = percentKpi * -1\n\n\n    if (!props.data)\n        return (<div>NO DATA RECEIVED</div>)\n\n    if (loading)\n        return (<div style={{ position: \"absolute\", bottom: 0, left: \"7px\", right: \"7px\" }}>\n            <LinearProgress />\n        </div>\n        )\n\n    const kpiInfo = () => {\n        let kpiTitle = ``\n        let kpiIniTitle = ``\n\n        let kpii = kpi_ini && parseInt(kpi_ini) ? parseInt(kpi_ini) : 0\n        let kpif = kpi_fin && parseInt(kpi_fin) ? parseInt(kpi_fin) : 0\n        if (data && data.kpi_type === 'time') {\n            kpiIniTitle = {}\n            if (parseInt(kpii) < parseInt(kpif)) {\n                kpiTitle = translate('$__maxTime', 1)\n            }\n            if (parseInt(kpii) > parseInt(kpif)) {\n                kpiTitle = translate('$__minTime', 1)\n            }\n        }\n        if (kpii > 0) {\n            kpiIniTitle = `${translate('$__initial', 1)}: ${formatNumber(kpii, data.kpi_type === 'time' ? 'number' : data.kpi_type, data.kpi_currency ? data.kpi_currency : null)} / `\n        }\n\n        let numberAr = [\"decimal\", \"currency\", \"percentage\"]\n        if (numberAr.indexOf(data.kpi_type) > -1)\n            kpiTitle = translate('$__targetValue', 1)\n\n        return (\n            <React.Fragment>\n                {translate(`${kpii > kpif ? '$__balance' : '$__targetValue'}`, 1)}: {formatNumber(kpii < kpif ? goalValue : balanceValue || 0, data.kpi_type === 'time' ? 'number' : data.kpi_type, data.kpi_currency ? data.kpi_currency : null)}{data.kpi_type === 'time' ? <span style={{ marginLeft: 5, fontSize: 10, textTransform: \"lowercase\" }}>{translate(\"$__minutes\")}</span> : ``}\n            </React.Fragment>\n        )\n    }\n\n    return (\n        <div className={classes.root}>\n            <React.Fragment>\n                {props.chartShow && data.kpi_type !== 'time' && data.kpi_type !== 'task' && kpi_flow.length > 0 &&\n                    <div style={{\n                        backgroundColor: customApp('color')\n                    }}>\n                        <ChartistGraph\n                            className=\"ct-chart-white-colors\"\n                            data={kpiChart.data}\n                            type=\"Line\"\n                            options={kpiChart.options}\n                            listener={kpiChart.animation}\n                        />\n                    </div>\n                }\n                {data.kpi_type !== 'task' &&\n                    <fieldset style={{ position: 'relative' }}>\n                        <legend\n                            style={\n                                {\n                                    color: customApp('color')\n                                }\n                            }>\n                            {translate('$__progress', 1)}\n                        </legend>\n                        {/* <div style={{\n                            position: 'relative',\n                            textSize: '11px',\n                            color: customApp('color'),\n                        }}>\n                            {kpiInfo()}\n                        </div> */}\n                        <div className={classes.progress}>\n                            <LinearProgress\n                                variant=\"determinate\"\n                                size={100}\n                                value={percentKpi}\n                                showText\n                                onClick={() => {\n                                    // setReqSave(true)\n                                }} />\n                        </div>\n                        <div style={{\n                            position: 'relative',\n                            textSize: '11px',\n                            fontWeight: 'bold',\n                            color: customApp('color')\n                        }}>\n                            {kpiInfo()}\n\n                        </div>\n                        <div style={{\n                            position: 'relative',\n                            textSize: '11px',\n                            fontWeight: 'bold',\n                            color: accomplished > 0 ? customApp('green') : 'red'\n                        }}>\n                            {translate(`$__accomplished`, 1)}: {accomplished && parseInt(accomplished) > 0 ? formatNumber(accomplished, data.kpi_type === 'time' ? 'number' : data.kpi_type, data.kpi_currency ? data.kpi_currency : null) : 0}\n                        </div>\n                        <div style={{\n                            position: 'absolute',\n                            right: '0px',\n                            top: '-33px',\n                            display: 'flex'\n                        }}>\n                            {(\n                                (percentKpi >= 0 && percentKpi < 100 && kpi_fin > kpi_ini)\n                                ||\n                                (percentKpi > 0 && percentKpi <= 100 && kpi_fin < kpi_ini)\n                            ) &&\n                                <PopperMenu\n                                    icon=\"add_circle\"\n                                    title={translate(\"$__increase\")}\n                                    iconColor={customApp('blue')}\n                                    onClick={() => {\n                                        setPositiveValue(true)\n                                        // setReqSave(true)\n                                    }}\n                                    transparent\n                                >\n                                    <KpiDescription\n                                        data={data}\n                                        PositiveValue={true}\n                                        callBack={() => {\n                                            // setReqSave(false)\n                                        }}\n                                    />\n                                </PopperMenu>\n                            }\n                            {(\n                                (percentKpi >= 0 && percentKpi < 100 && kpi_fin < kpi_ini)\n                                ||\n                                (percentKpi > 0 && percentKpi <= 100 && kpi_fin > kpi_ini)\n                            ) &&\n\n                                <PopperMenu\n                                    icon=\"remove_circle\"\n                                    iconColor={'orange'}\n                                    title={translate(\"$__decrease\")}\n                                    onClick={() => {\n                                        setPositiveValue(false)\n                                    }}\n                                    transparent\n                                >\n                                    <KpiDescription\n                                        data={data}\n                                        PositiveValue={false}\n                                        callBack={() => {\n                                            // setReqSave(false)\n                                        }}\n                                    />\n                                </PopperMenu>\n                            }\n                        </div>\n                    </fieldset>\n                }\n                {data.kpi_type === 'task' &&\n                    <div className={classes.time}>TASK</div>\n                }\n            </React.Fragment>\n        </div >\n    );\n}\n//REACT\nconst mapStateToProps = (store) => ({\n    store: {\n        timeline: store.timeline,\n        cards: store.db.cards\n    }\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","import {\r\n  defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = {\r\n  root: {\r\n    ...defaultFont,\r\n  },\r\n  aspectsTitle: {\r\n    width: '100%',\r\n    fontWeight: 'bold',\r\n    padding: '3px',\r\n    color: customApp('color'),\r\n    display: 'flex',\r\n    alignItems: 'center'\r\n  }\r\n};\r\n\r\nexport default style;\r\n","import React from \"react\";\n\n\n//REDUX\nimport * as reduxActions from \"store/actions\";\nimport history from \"store/history\";\nimport reduxStore from \"store\";\nimport { bindActionCreators } from \"redux\";\nimport { connect } from \"react-redux\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport Chip from '@material-ui/core/Chip';\n\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Card-SWOT.js\";\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\";\n\n\nconst useStyles = makeStyles(styles);\n\nfunction Component(props) {\n    console.log(props.data)\n    const { db } = reduxStore.getState()\n    const classes = useStyles();\n    const [mounted, setMounted] = React.useState(false)\n    const [aspects, setAspects] = React.useState([])\n\n    React.useEffect(() => {\n\n        let newAspects = []\n        if (props.data && props.data.length > 0)\n            props.data.map(a => {\n                newAspects.push(db.cards[a])\n            })\n        setAspects(newAspects)\n        return () => {\n            // return false\n        }\n    }, [props.data])\n\n    let internal = props.type === 'guidelineD' || props.type === 'guidelineR' ? aspects.filter(a => a && a.type === 'strength') : aspects.filter(a => a && a.type === 'weakness')\n    let external = props.type === 'guidelineD' || props.type === 'guidelineE' ? aspects.filter(a => a && a.type === 'threat') : aspects.filter(a => a && a.type === 'opportunity')\n    let internalType = props.type === 'guidelineD' || props.type === 'guidelineR' ? 'strength' : 'weakness'\n    let externalType = props.type === 'guidelineD' || props.type === 'guidelineE' ? 'threat' : 'opportunity'\n    let internalTypeMult = props.type === 'guidelineD' || props.type === 'guidelineR' ? 'forces' : 'weaknesses'\n    let externalTypeMult = props.type === 'guidelineD' || props.type === 'guidelineE' ? 'threats' : 'opportunities'\n\n    return (\n        <div className={classes.root} >\n            <div className={classes.aspectsTitle}>\n                <Icon\n                    icon={props.type === 'guidelineD' || props.type === 'guidelineR' ?\n                        db.dataType.filter(a => a.name === 'strength')[0].icon\n                        : db.dataType.filter(a => a.name === 'weakness')[0].icon\n                    }\n                    color={customApp('color')}\n                    title={translate(internalType, 1)}\n                />\n                <span style={{ marginLeft: '5px' }}>{translate('$__internalAspects', 1)} - {translate(`$__${internalTypeMult}`, 1)}</span>\n            </div>\n            {internal && internal.length > 0 && internal.sort((a, b) => a.name - b.name).map((a, i) => (\n                <Chip\n                    size=\"small\"\n                    label={a.name}\n                    title={a.name}\n                    style={{ margin: '3px', maxWidth: '100%', overflow: 'hidden' }}\n                    key={a._id} />\n            )\n            )\n            }\n\n\n            <div className={classes.aspectsTitle}>\n                <Icon\n                    icon={props.type === 'guidelineD' || props.type === 'guidelineE' ?\n                        db.dataType.filter(a => a.name === 'threat')[0].icon\n                        : db.dataType.filter(a => a.name === 'opportunity')[0].icon\n                    }\n                    color={customApp('color')}\n                    title={translate(externalType, 1)}\n                />\n                <span style={{ marginLeft: '5px' }}>{translate('$__externalAspects', 1)} - {translate(`$__${externalTypeMult}`, 1)}</span>\n            </div>\n            {external && external.length > 0 && external.sort((a, b) => a.name - b.name).map((a, i) => (\n                <Chip size=\"small\"\n                    label={a.name}\n                    title={a.name}\n                    style={{ margin: '3px', maxWidth: '100%', overflow: 'hidden' }}\n                    key={a._id} />\n            ))\n            }\n        </div >\n    );\n}\nconst mapStateToProps = (store) => ({})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(Component);\n","import {\r\n  defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = {\r\n  containerNoShadow: {\r\n    ...defaultFont,\r\n    position: 'relative',\r\n    border: `0.5px solid ${customApp('light')}`,\r\n    borderRadius: '2px',\r\n    padding: '0px',\r\n    backgroundColor: '#FFFFFF',\r\n    padding: '3px',\r\n    minWidth: '150px',\r\n    display: 'flow-root',\r\n  },\r\n  container: {\r\n    ...defaultFont,\r\n    position: 'relative',\r\n    border: `0.5px solid ${customApp('light')}`,\r\n    borderRadius: '2px',\r\n    padding: '0px',\r\n    backgroundColor: '#FFFFFF',\r\n    padding: '3px',\r\n    minWidth: '150px',\r\n    display: 'flow-root',\r\n    boxShadow: '0px 0px 10px rgba(0,0,0,0.1)',\r\n  },\r\n  parent: {\r\n    width: '100%',\r\n    padding: '0 5px',\r\n    '& .title': {\r\n      color: customApp('medium'),\r\n      fontSize: '10px',\r\n      textTransform: 'uppercase'\r\n    },\r\n    '& .info': {\r\n      marginTop: '-8px',\r\n      color: customApp('color'),\r\n      fontWeight: '500',\r\n      //display: 'flex',\r\n      alignItems: 'center',\r\n    }\r\n  },\r\n  infos: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    height: 'auto',\r\n    display: 'block',\r\n  },\r\n  indicators: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    height: 'auto',\r\n    // display: 'flex',\r\n    zIndex: '0 !important'\r\n  },\r\n  indicatorsIcon: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    margin: '0px 0px',\r\n    '& MuiBadge-badge': {\r\n      position: 'relative',\r\n      float: 'left',\r\n      //zIndex: '30 !important'\r\n    }\r\n  },\r\n  image: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    marginTop: '7px',\r\n    maxWidth: '100%',\r\n    display: 'none',\r\n  },\r\n  imagePreview: {\r\n    backgroundRepeat: 'no-repeat',\r\n    backgroundSize: 'cover',\r\n    backgroundPosition: 'center',\r\n    paddingTop: '48%',\r\n    display: 'flex',\r\n    justifyContent: 'center',\r\n    alignItems: 'center',\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%'\r\n  },\r\n  imagePreviewList: {\r\n    backgroundRepeat: 'no-repeat',\r\n    backgroundSize: 'cover',\r\n    backgroundPosition: 'center',\r\n    display: 'flex',\r\n    justifyContent: 'center',\r\n    alignItems: 'center',\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: \"100%\",\r\n    paddingTop: \"48%\",\r\n    '@media screen and (max-width: 800px)': {\r\n      width: '100%'\r\n    }\r\n  },\r\n  PreLoader: {\r\n    top: 'calc(50% - 25px)',\r\n    left: 'calc(50% - 25px)',\r\n    position: 'absolute',\r\n  },\r\n  description: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    padding: '5px',\r\n    minHeight: '75px',\r\n    width: '100%',\r\n    overflow: 'hidden',\r\n    textOverflow: 'ellipses'\r\n  },\r\n  dates: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    marginTop: '7px',\r\n    padding: '0 5px',\r\n    marginRight: '15px',\r\n    color: customApp('medium'),\r\n    fontSize: '10px',\r\n    display: 'flex',\r\n  },\r\n  lateDates: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    marginTop: '7px',\r\n    padding: '0 5px',\r\n    marginRight: '15px',\r\n    color: 'red',\r\n    fontSize: '10px',\r\n    display: 'flex',\r\n  },\r\n  dateInfo: {\r\n    marginRight: '15px',\r\n    display: 'flex',\r\n    alignItems: 'center'\r\n  },\r\n  usersContent: {\r\n    minHeight: '20px',\r\n    minWidth: '40px',\r\n    zIndex: '0 !important'\r\n  },\r\n  users: {\r\n    position: 'absolute',\r\n    bottom: '0px',\r\n    right: '2px',\r\n    fontSize: '10px',\r\n    '& .MuiAvatarGroup-root': {\r\n      justifyContent: 'flex-end',\r\n    },\r\n    '& .MuiAvatar-root': {\r\n      width: '25px',\r\n      height: '25px',\r\n      fontSize: '10px',\r\n    }\r\n  }\r\n};\r\n\r\nexport default style;\r\n","import React, { memo } from \"react\"\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport history from \"store/history\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//COMPONENTS\nimport Badge from \"components/Icon/Badge\"\nimport Checklist from \"components/Checklist\"\nimport ConnectedIn from \"components/ConnectedIn\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Icon from \"components/Icon\"\nimport KPIChange from \"components/KPI/change\"\nimport LinearProgress from \"components/Progress/linear\"\n\n//DEPENDENCIES\nimport SWOT from \"./SWOT\"\n\n//@MATERIAL\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Card.js\"\n\n//IMAGES\nimport defaultAvatar from \"assets/img/fundo-sonne.png\"\nimport MachenIco from \"assets/icons/machen.svg\"\nimport BrightAndConnectedIco from \"assets/icons/BrigthAndConnected\"\n\n//FUNCTIONS\nimport PreLoader from \"components/PreLoader\"\nimport {\n    getUserAccess\n} from \"functions/cards\"\n\nimport {\n    translate,\n    customApp,\n    getAppAccess,\n    nl2br\n} from \"functions/\"\nimport {\n    loadCardsV2\n} from \"functions/loadData.js\"\nimport {\n    loadTimeline\n} from \"functions/chat\"\n\n\nfunction ExpandedCard(props) {\n    const { classes } = props\n    const { db, session, timeline } = reduxStore.getState()\n    const [ImagePreview, setImagePreview] = React.useState(null)\n    const [stopLoading, setStopLoading] = React.useState(true)\n    const [mounted, setMounted] = React.useState(false)\n    const [showChecklist, setShowChecklist] = React.useState(false)\n    const [loadingData, setLoadingData] = React.useState(false)\n\n    let data = props.data && props.data._id ? reduxStore.getState().db.cards[props.data._id] : {}\n\n    let AppAccess = getAppAccess()\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    React.useEffect(() => {\n        let isSubscribed = true\n        if (isSubscribed) {\n            if (data._parent && (!hashs[0] || (hashs[0] && hashs[0].length !== 36))) {\n                init()\n            } else {\n                setLoadingData(false)\n            }\n        }\n        return () => {\n            isSubscribed = false\n        }\n    }, [])\n\n    const init = async () => {\n        if (\n            (\n                !data._loadTimeline\n                ||\n                (\n                    data._loadTimeline\n                    && !data._loadTimeline['kpi']\n                )\n            )\n            && data.kpi_type && data.kpiType !== 'task' && data.kpiType !== 'timer' && data.kpiType !== 'time')\n            loadTimeline(\n                {\n                    ...props,\n                    fnIdentification: \"Card/index/init()\"\n                },\n                {\n                    ids: [data._id],\n                    db: 'cards',\n                    type: 'kpi'\n                }\n            )\n\n        const reqParents = async (parent) => {\n            if (!db.cards[parent]) {\n                setLoadingData(true)\n                let response = await loadCardsV2({ ...props, ignoreLoader: true }, {\n                    idRel: [parent],\n                    cardLoad: \"parents\"\n                })\n                if (response)\n                    setLoadingData(false)\n            } else if (db.cards[parent] && db.cards[parent]._parent) {\n                let response = reqParents(db.cards[parent]._parent)\n                if (response)\n                    setLoadingData(false)\n            } else {\n                setLoadingData(false)\n            }\n        }\n\n        const reqFullData = async () => {\n            reqParents(data._parent)\n        }\n        reqFullData()\n        if (props.onExpand)\n            props.onExpand()\n    }\n\n    if (loadingData)\n        return <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"center\", width: \"100%\" }}>\n            <span style={{ color: customApp('menu'), fontSize: \"12px\", paddingRight: \"15px\", whiteSpace: \"nowrap\" }}>{translate('$__loadingData')}</span>\n            <LinearProgress />\n        </div>\n\n    if (!data || !props.data || !props.data._id)\n        return null\n\n    const openSideModule = async (module = \"cardEdit\") => {\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...props.store.sideModule,\n            db: props.db,\n            id: data._id,\n            module: \"cardEdit\",\n            activeModule: module,\n            data: data,\n        })\n    }\n    let hasYoutube = false\n    let youtube = (<React.Fragment></React.Fragment>)\n    if (data && data.url && data.url.indexOf(\".youtube.com/watch?\") > -1) {\n        let ybQuery = data.url.split(\"?\")[1].split(\"v=\")[1].split(\"&\")[0]\n        if (ybQuery) {\n            youtube = (\n                <iframe\n                    width=\"560\"\n                    height=\"315\"\n                    style={{\n                        top: 0,\n                        width: \"100%\",\n                        maxWidth: \"500px\",\n                        height: \"100%\",\n                        alignSelf: \"center\",\n                        position: \"absolute\",\n                        overflow: \"hidden\"\n                    }}\n                    src={`https://www.youtube.com/embed/${ybQuery}`}\n                    title=\"YouTube video player\"\n                    frameBorder=\"0\"\n                    allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                    allowFullScreen >\n\n                </iframe >\n            )\n            hasYoutube = true\n        }\n    }\n\n    if (data && data.url && data.url.indexOf(\"youtu.be/\") > -1) {\n        let ybQuery = data.url.split(\"youtu.be/\")[1]\n        if (ybQuery) {\n            youtube = (\n                <iframe\n                    width=\"560\"\n                    height=\"315\"\n                    style={{\n                        top: 0,\n                        width: \"100%\",\n                        maxWidth: \"500px\",\n                        height: \"100%\",\n                        alignSelf: \"center\",\n                        position: \"absolute\",\n                        overflow: \"hidden\"\n                    }}\n                    src={`https://www.youtube.com/embed/${ybQuery}`}\n                    title={data.name}\n                    frameBorder=\"0\"\n                    allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                    allowFullScreen >\n\n                </iframe >\n            )\n            hasYoutube = true\n        }\n    }\n\n    return (\n        <div>\n            <div            >\n                <div {...props.provided && props.provided.dragHandleProps} style={{ display: \"none\" }}></div>\n                <React.Fragment>\n                    <div className={classes.infos}\n                        onClick={(e) => {\n                            if (props.onClick) {\n                                props.onClick()\n                            }\n                        }\n                        }\n                    >\n                        {\n                            (data.image && (((data.image || props.Avatar)) || ((data.image || props.Avatar))) && !session.cards.hide.image) ?\n                                <div\n                                    className={classes.imagePreview}\n                                    style={ImagePreview ? {\n                                        backgroundImage: `url(\"${!ImagePreview ? defaultAvatar : ImagePreview}\")`,\n                                    } : {\n                                        background: customApp('AvatarBackground'),\n                                        display: 'flex',\n                                        alignItems: 'center',\n                                        justifyContent: 'center'\n                                    }}>\n                                    {hasYoutube ?\n                                        youtube\n                                        :\n                                        data.image && !ImagePreview ?\n                                            <React.Fragment>\n                                                <div style={{ marginTop: `calc(-48% - ${(data.type === 'insight' || data.type === 'link') ? `10px` : `0px`})`, display: 'flex', justifyContent: 'center', alignItems: 'center' }}>\n                                                    {(data.type === 'insight' || data.type === 'link') ?\n                                                        <Icon icon={BrightAndConnectedIco} size=\"39px\" color=\"rgba(250,250,250,0.77)\" />\n                                                        :\n                                                        <img src={MachenIco} style={{ width: '25%' }} />\n                                                    }\n                                                    <div style={{ clear: \"both\" }}></div>\n                                                </div>\n                                                {!stopLoading &&\n                                                    <div\n                                                        style={{ position: 'absolute', marginTop: \"calc(-48% + 0px)\", zIndex: 1 }}>\n                                                        <PreLoader />\n                                                        <div style={{ clear: \"both\" }}></div>\n                                                    </div>\n                                                }\n                                            </React.Fragment>\n                                            :\n                                            <React.Fragment></React.Fragment>\n                                    }\n                                    {!hasYoutube && (!ImagePreview || props.Avatar || data.image !== ImagePreview) &&\n                                        <React.Fragment>\n                                            <img\n                                                className={classes.image}\n                                                src={`${data.image ? data.image : defaultAvatar}`}\n                                                onError={(e) => {\n                                                    if (data.image) {\n                                                        setImagePreview(null)\n                                                        // e.target.src = data.image\n                                                    } else {\n                                                        setStopLoading(true)\n                                                    }\n                                                }}\n                                                onLoad={(e) => {\n                                                    setImagePreview(`${(props.Avatar && !data.image) ? defaultAvatar : data.image}`)\n                                                }}\n                                                width=\"100%\" />\n                                        </React.Fragment>\n                                    }\n                                    <div style={{ clear: \"both\" }}></div>\n                                </div>\n                                : props.Avatar && !session.cards.hide.image &&\n                                <div\n                                    className={db.viewList ? classes.imagePreviewList : classes.imagePreview}\n                                    style={{\n                                        background: customApp('AvatarBackground'),\n                                        display: 'flex',\n                                        alignItems: 'center',\n                                        justifyContent: 'center'\n                                    }}>\n                                    <div style={{\n                                        position: \"absolute\",\n                                        top: 0,\n                                        left: 0,\n                                        right: 0,\n                                        bottom: 0,\n                                        display: \"flex\",\n                                        alignItems: \"center\",\n                                        justifyContent: \"center\"\n                                    }}>\n                                        {(data.type === 'insight' || data.type === 'link') ?\n                                            <Icon icon={BrightAndConnectedIco} size=\"39px\" color=\"rgba(250,250,250,0.77)\" />\n                                            :\n                                            <img src={MachenIco} style={{ width: '25%' }} />\n                                        }\n                                        <div style={{ clear: \"both\" }}></div>\n                                    </div>\n                                    <div style={{ clear: \"both\" }}></div>\n                                </div>\n                        }\n                        {(\n                            db.dataType.filter(c => c.name === data.type)[0].module !== 'swot'\n                            &&\n                            (\n                                (\n                                    data._parent\n                                    && data._parent !== data._id\n                                )\n                                ||\n                                (\n                                    data._planId\n                                    && data._planId !== data._id\n                                )\n                            )\n                        ) &&\n                            <div\n                                style={{\n                                    position: 'relative',\n                                    width: '100%',\n                                    display: 'flex',\n                                    paddingTop: '7px'\n                                }}>\n                                {data.name === \"SQUASH\" && console.log(data)}\n                                {db.cards[data._parent] ?\n                                    <ConnectedIn\n                                        id={data._parent && reduxStore.getState().db.cards[data._parent] ? data._parent : data._planId && reduxStore.getState().db.cards[data._planId] ? data._planId : null}\n                                        loading={loadingData}\n                                        showLegend={props.Resume ? false : true}\n                                    />\n                                    : <React.Fragment></React.Fragment>\n                                }\n                                <div style={{ clear: \"both\" }}></div>\n                            </div>\n                        }\n                        <div style={!db.viewList || props.ignoreList ? {} : {\n                            position: 'relative',\n                            float: 'left',\n                            width: '100%'\n                        }}>\n                            {\n                                (data.type.indexOf(\"guideline\") > -1 && ((data._aspects && data._aspects.length > 0) || (data._aspects && data._aspects.length > 0))) ?\n                                    <SWOT data={data._aspects} type={data.type} />\n                                    : <React.Fragment></React.Fragment>\n                            }\n                            {!props.searchText && data.description &&\n                                <Tooltip\n                                    title={data.description || \"\"}\n                                >\n                                    {props.Resume ?\n                                        <div className={classes.description}\n                                            style={{\n                                                height: 90\n                                            }}\n                                        >{data.description ? `${data.description.substr(0, 150)}...` : ``}</div>\n                                        :\n                                        <div className={classes.description} style={{ wordBreak: 'break-word', height: 90 }} dangerouslySetInnerHTML={{\n                                            __html: data.description ? nl2br(data.description) : ``\n                                        }} />\n                                    }\n                                </Tooltip>\n                            }\n\n                            {(data.kpi_type && !session.cards.hide.kpi) &&\n                                <KPIChange data={data} chartShow={!session.cards.hide.kpiChart ? true : false} />\n                            }\n\n                            <AvatarGroup max={100} className={classes.indicators}>\n                                {(\n                                    (\n                                        data._timelineCount\n                                        && data._timelineCount > 0\n                                    )\n                                    ||\n                                    (\n                                        timeline[data._id]\n                                        && Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'comment').length > 0\n                                    )\n                                ) &&\n                                    <Badge\n                                        overlap=\"rectangular\"\n                                        className={classes.indicatorsIcon}\n                                        icon=\"timeline\"\n                                        title={\"$__timeline\"}\n                                        size=\"16px\"\n                                        onClick={() => !props.onlyOption && openSideModule(\"timeline\")}\n                                        disabled\n                                        count={timeline[data._id] && Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'comment').length > 0 ? Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'comment').length : data._timelineCount}\n                                    />\n                                }\n                                {\n                                    (\n                                        (\n                                            data._logCount\n                                            && data._logCount > 0\n                                        )\n                                        ||\n                                        (\n                                            timeline[data._id]\n                                            && Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'log').length > 0\n                                        )\n                                    ) &&\n                                    <Badge\n                                        overlap=\"rectangular\"\n                                        className={classes.indicatorsIcon}\n                                        icon=\"history\"\n                                        title={\"$__log\"}\n                                        size=\"16px\"\n                                        onClick={() => !props.onlyOption && openSideModule(\"log\")}\n                                        disabled\n                                    />\n                                }\n                                {\n                                    (\n                                        (\n                                            data._kpiCount\n                                            && data._kpiCount > 0\n                                        )\n                                        ||\n                                        (\n                                            timeline[data._id]\n                                            && Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'kpi').length > 0\n                                        )\n                                    ) &&\n                                    <Badge\n                                        overlap=\"rectangular\"\n                                        className={classes.indicatorsIcon}\n                                        icon=\"analytics\"\n                                        title={\"$__kpi\"}\n                                        size=\"16px\"\n                                        onClick={() => !props.onlyOption && openSideModule(\"kpi\")}\n                                        disabled\n                                        count={timeline[data._id] && Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'kpi').length > 0 ? Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'kpi').length : data._kpiCount}\n                                    />\n                                }\n                                {\n                                    (\n                                        (\n                                            data._timerCount\n                                            && data._timerCount > 0\n                                        )\n                                        ||\n                                        (\n                                            timeline[data._id]\n                                            && Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'timer').length > 0\n                                        )\n                                    ) &&\n                                    <Badge\n                                        overlap=\"rectangular\"\n                                        className={classes.indicatorsIcon}\n                                        icon=\"timer\"\n                                        title={\"$__timeSheet\"}\n                                        size=\"16px\"\n                                        onClick={() => !props.onlyOption && openSideModule(\"timeLog\")}\n                                        disabled\n                                        count={timeline[data._id] && Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'timer').length > 0 ? Object.keys(timeline[data._id]).filter(a => timeline[data._id][a].type === 'timer').length : data._timerCount}\n                                    />\n                                }\n                                {data && data._id && reduxStore.getState().db.cards && Object.keys(reduxStore.getState().db.cards).length > 0 && Object.keys(reduxStore.getState().db.cards)\n                                    .filter(fil =>\n                                        data\n                                        && data._id\n                                        && reduxStore.getState().db.cards[fil]\n                                        && reduxStore.getState().db.cards[fil].checklist\n                                        && reduxStore.getState().db.cards[fil]._parent === data._id\n                                    ).length > 0 &&\n                                    <Badge\n                                        overlap=\"rectangular\"\n                                        className={classes.indicatorsIcon}\n                                        icon=\"checklist\"\n                                        title={\"$__list\"}\n                                        size=\"16px\"\n                                        onClick={() => !props.onlyOption && setShowChecklist(!showChecklist)}\n                                        disabled\n                                        count={reduxStore.getState().db.cards && Object.keys(reduxStore.getState().db.cards).length > 0 && Object.keys(reduxStore.getState().db.cards)\n                                            .filter(fil =>\n                                                data\n                                                && data._id\n                                                && reduxStore.getState().db.cards[fil]\n                                                && reduxStore.getState().db.cards[fil].checklist\n                                                && reduxStore.getState().db.cards[fil]._parent === data._id\n                                            ).length\n                                        }\n                                    />\n                                }\n                                {/* {!props.showChildrens && Object.keys(indicators).length > 0 && Object.keys(indicators).map((a, i) => (\n                                    String(a) !== \"null\" && String(a) !== \"undefined\" ?\n                                        <Badge\n                                        overlap=\"rectangular\"\n                                            key={i}\n                                            className={classes.indicatorsIcon}\n                                            icon={db.dataType.filter(c => c.name === a)[0].icon}\n                                            title={translate(`$__${a}`, 1)}\n                                            size=\"16px\"\n                                            count={indicators[a]}\n                                            disabled\n                                        />\n                                        : null\n                                ))} */}\n\n                            </AvatarGroup>\n                            {(data.type === \"link\" || data.type === \"insight\") &&\n                                <div className={classes.dates}>\n                                    <div className={classes.dateInfo}>\n                                        <Badge\n                                            overlap=\"rectangular\"\n                                            className={classes.dateIco} icon=\"event_available\" title={\"$__pubDate\"} size=\"14px\" disabled />\n                                        {moment(data.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY HH:mm\")}\n                                    </div>\n                                </div>\n                            }\n                            <div style={{ clear: \"both\" }}></div>\n                        </div>\n                        <div style={{ clear: \"both\" }}></div>\n                    </div>\n                </React.Fragment>\n                {\n                    (\n                        showChecklist\n                        ||\n                        (data.type !== 'plan'\n                            &&\n                            (\n\n                                Object.keys(reduxStore.getState().db.cards).filter(fil => reduxStore.getState().db.cards[fil]\n                                    && reduxStore.getState().db.cards[fil].checklist\n                                    && reduxStore.getState().db.cards[fil]._parent === data._id\n                                ).length > 0\n                                && Object.keys(reduxStore.getState().db.cards).filter(fil => reduxStore.getState().db.cards[fil]\n                                    && reduxStore.getState().db.cards[fil].type === \"step\"\n                                    && reduxStore.getState().db.cards[fil]._parent === data._id\n                                ).length === 0\n\n                            )\n                        )\n                    )\n                    &&\n                    <div style={{\n                        position: 'relative',\n                        width: 'calc(100%)',\n                        top: '16px',\n                        clear: 'both',\n                        marginBottom: '16px'\n                    }}>\n                        <div style={{\n                            padding: '7px',\n                            backgroundColor: 'rgba(0,0,0,0.05)',\n                            fontSize: '16px',\n                            borderTopLeftRadius: 7,\n                            borderTopRightRadius: 7,\n                        }}>{translate('$__list', 1)}</div>\n                        <Checklist nodeId={data._id} db={\"cards\"} noDelete showProgress />\n                        <div style={{ clear: 'both' }}></div>\n                    </div>\n                }\n                {\n                    (\n                        showChecklist\n                        ||\n                        (\n                            Object.keys(reduxStore.getState().db.cards).filter(fil => reduxStore.getState().db.cards[fil]\n                                && reduxStore.getState().db.cards[fil].type === \"step\"\n                                && reduxStore.getState().db.cards[fil]._parent === data._id\n                            ).length > 0\n\n                        )\n                    )\n                    &&\n                    <div style={{\n                        position: 'relative',\n                        width: 'calc(100%)',\n                        top: '16px',\n                        clear: 'both',\n                        marginBottom: '16px'\n                    }}>\n                        <CustomButton\n                            title={translate(\"$__openTaskList\")}\n                            text={translate(\"$__openTaskList\")}\n                            color={\"lightgrey\"}\n                            textColor={\"lightgrey\"}\n                            icon={\"open_in_new\"}\n                            onClick={() => {\n                                // setAddColumn(true)\n                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\n                                    ...reduxStore.getState().control,\n                                    board: data._id,\n                                })\n                            }}\n                            size={\"25px\"}\n                        />\n                        <div style={{ clear: 'both' }}></div>\n                    </div>\n                }\n                <div style={{ clear: \"both\" }}></div>\n            </div >\n            <div style={{ clear: \"both\" }}></div>\n        </div >\n    )\n}\n\n//REACT\nconst mapStateToProps = (store, props) => ({\n    card: store.db.cards[props.data._id],\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(ExpandedCard))","const cropperStyle = () => ({\r\n  root: {\r\n\r\n  },\r\n  viewer: {\r\n    alignItems: 'center',\r\n    justifyContent: 'center',\r\n    display: 'flex'\r\n  },\r\n  image: {\r\n    width: '100%',\r\n    // backgroundColor: 'rgba(60,60,60)',\r\n    backgroundRepeat: 'no-repeat',\r\n    backgroundSize: 'cover'\r\n  },\r\n  avatarImage: {\r\n    marginTop: '7px',\r\n    width: '170px',\r\n    height: '170px',\r\n    borderRadius: '50%',\r\n    boxShadow: '0px 0px 7px 7px rgba(0,0,0,0.2)'\r\n  },\r\n  addImage: {\r\n    width: '100%',\r\n    // backgroundColor: 'rgba(60,60,60,0.1)',\r\n    padding: '15px',\r\n    '&:hover': {\r\n      // backgroundColor: 'rgba(60,60,60,0.3)',\r\n    }\r\n  },\r\n  cropper: {\r\n    overflow: 'hidden',\r\n    '& .cropper-container': {\r\n      width: '100% !important',\r\n      overflow: 'hidden !important'\r\n    }\r\n  },\r\n  circleCropper: {\r\n    overflow: 'hidden',\r\n    '& .cropper-container': {\r\n      width: '100% !important',\r\n      overflow: 'hidden !important'\r\n    },\r\n    '& .cropper-view-box': {\r\n      borderRadius: '50%'\r\n    }\r\n  },\r\n});\r\n\r\nexport default cropperStyle;\r\n","//CORE\nimport React from \"react\";\nimport Cropper from \"react-cropper\";\nimport Resizer from \"react-image-file-resizer\";\n\n//REDUX\nimport * as reduxActions from \"store/actions\";\nimport { bindActionCreators } from \"redux\";\nimport { connect } from \"react-redux\";\n\n//COMPONENTS\nimport HeaderWithIcon from \"components/Header/withIcon\";\nimport Icon from \"components/Icon\";\nimport IconButton from \"components/CustomButtons/IconButton\";\n\n//@MATERIAL\nimport Dialog from \"@material-ui/core/Dialog\";\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport \"cropperjs/dist/cropper.css\";\nimport styles from \"./Cropper.css.js\";\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\";\n\nconst cropper = React.createRef(null);\n\nfunction Component(props) {\n    const [CroppedImage, SetCroppedImage] = React.useState(null)\n    const [ImageCropDialog, SetImageCropDialog] = React.useState(false)\n    const [ImagetoCrop, SetImagetoCrop] = React.useState(null)\n    const [files, setFiles] = React.useState([])\n    const fileInput = React.useRef(null)\n    const { classes } = props\n\n    React.useEffect(() => {\n        ini()\n    }, [])\n    React.useEffect(() => {\n        ini()\n    }, [props.files, props.img])\n\n    const ini = () => {\n        let ff = files\n        if (props.files) {\n            Object.keys(props.files).map(f => {\n                if (ff.filter(fil => fil._id === f).length === 0)\n                    ff.push(props.files[f])\n            })\n            setFiles(ff)\n        }\n    }\n\n    const handleImageChange = (e) => {\n        SetImageCropDialog(true)\n        let reader = new FileReader();\n        if (e.files[0] != null) {\n            let file = e.files[0];\n            reader.onloadend = () => {\n                SetImagetoCrop(reader.result)\n                SetImageCropDialog(true)\n            };\n            reader.readAsDataURL(file);\n        } else {\n            SetImageCropDialog(false)\n        }\n    }\n\n    const _crop = async (e) => {\n        var img = cropper.current.getCroppedCanvas().toDataURL()\n        SetCroppedImage(img)\n        SetImagetoCrop(null)\n        SetImageCropDialog(false)\n        var nameImg = fileInput.current.files[0].name;\n        var typeImg = fileInput.current.files[0].type;\n        var imgResult = await urltoFile(img, nameImg, typeImg);\n\n        const options = {\n            maxSizeMB: 0.5,\n            maxWidthOrHeight: props.maxWidthOrHeight ? props.maxWidthOrHeight : 600,\n            useWebWorker: true,\n            // initialQuality: 1\n        }\n        try {\n            const imgResizer = new Promise(resolve => Resizer.imageFileResizer(\n                imgResult, // Is the file of the image which will resized.\n                props.maxWidthOrHeight ? props.maxWidthOrHeight : 600, //maxWidth, // Is the maxWidth of the resized new image.\n                props.maxWidthOrHeight ? props.maxWidthOrHeight : 600, //maxHeight, // Is the maxHeight of the resized new image.\n                imgResult.type.replace('image/', ''), // compressFormat, // Is the compressFormat of the resized new image.\n                50,//quality, // Is the quality of the resized new image.\n                0,\n                (e) => {\n                    resolve(urltoFile(e, nameImg, typeImg))\n                },//rotation, // Is the degree of clockwise rotation to apply to uploaded image.\n                //responseUriFunc, // Is the callBack function of the resized new image URI.\n                //outputType, // Is the output type of the resized new image.\n                // minWidth, // Is the minWidth of the resized new image.\n                //minHeight // Is the minHeight of the resized new image.\n            )\n            )\n            let response = await imgResizer.then(a => {\n                return a\n            })\n            if (response)\n                if (props.onChange)\n                    props.onChange(img, response)\n        } catch (e) {\n            console.log(e)\n        }\n    }\n\n    const urltoFile = (url, filename, mimeType) => {\n        return fetch(url)\n            .then(function (res) {\n                return res.arrayBuffer();\n            })\n            .then(function (buf) {\n                return new File([buf], filename, { type: mimeType });\n            });\n    }\n\n    const openLightBox = () => {\n        if (files && files.length > 0) {\n            let openFile = files.filter(f => props.img && props.img.indexOf(f.file) > -1)\n\n            if (openFile.length > 0)\n                props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n                    open: true,\n                    files: openFile,\n                    file: openFile[0]._id\n                })\n        }\n    }\n\n    return (\n        <div className={classes.root}>\n            <div\n                className={classes.viewer}\n                style={{}}\n            >\n                {!CroppedImage && !props.img && props.avatar && props.avatarIcon &&\n                    <div style={{ width: \"100%\", display: \"flex\", alignItems: \"center\", justifyContent: \"center\", marginTop: '15px' }}>\n                        <div\n                            style={{\n                                width: \"133px\",\n                                height: \"133px\",\n                                top: \"-4px\",\n                                left: \"-13px\",\n                                borderRadius: '50%',\n                                border: `solid 2px ${customApp('color')}`,\n                                zIndex: '5 !important',\n                                background: props.transparent ? \"none\" : customApp('AvatarBackground'),\n                                display: 'flex',\n                                alignItems: 'center',\n                                justifyContent: 'center'\n                            }}\n                        >\n                            <Icon size=\"40px\" color=\"rgba(250,250,250,0.77)\">{props.avatarIcon}</Icon>\n                        </div>\n                    </div>\n                }\n                {!props.avatar && (CroppedImage || props.img) ?\n                    <img className={props.avatar ? classes.avatarImage : classes.image} src={`${CroppedImage || props.img}`}\n                        style={{ cursor: \"pointer\" }}\n                        onError={(e) => e.target.src = CroppedImage || props.img} width=\"100%\" alt=\"\"\n                        onClick={() => {\n                            openLightBox()\n                        }}\n                    />\n                    : props.avatar && (CroppedImage || props.img) ?\n                        <div\n                            style={{\n                                width: \"133px\",\n                                height: \"133px\",\n                                top: \"-4px\",\n                                left: \"-13px\",\n                                borderRadius: '50%',\n                                border: `solid 2px ${customApp('color')}`,\n                                zIndex: '5 !important',\n                                background: props.transparent ? \"none\" : customApp('AvatarBackground'),\n                                backgroundImage: `url(\"${CroppedImage || props.img}\")`,\n                                backgroundRepeat: \"no-repeat\",\n                                backgroundPosition: \"center center\",\n                                backgroundSize: \"cover\",\n                                display: 'flex',\n                                alignItems: 'center',\n                                justifyContent: 'center'\n                            }}\n                        >\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                }\n            </div>\n            <div style={{\n                display: \"flex\",\n                justifyContent: \"space-between\"\n            }}>\n                {props.onChange ?\n                    <React.Fragment>\n                        <div style={{ padding: \"7px\" }} onClick={() => { fileInput.current.click(); }}>\n                            <IconButton text={translate(CroppedImage || props.img ? \"$__changeImage\" : \"$__addImage\", 1)} icon={CroppedImage || props.img ? \"image\" : \"add_a_photo\"} textColor=\"color\" iconColor=\"color\" />\n                        </div>\n\n                        <input\n                            type=\"file\"\n                            onChange={(e) => { handleImageChange(e.target) }}\n                            ref={fileInput}\n                            id=\"file-picker\"\n                            name=\"image\"\n                            accept={props.accept || \".jpg,.jpeg,.png,.gif\"}\n                            style={{ display: \"none\" }}\n                        />\n                    </React.Fragment>\n                    : <React.Fragment></React.Fragment>\n                }\n                {\n                    props.onDelete && (CroppedImage || props.img) ?\n                        <div style={{ padding: \"7px\" }} onClick={() => { props.onDelete() }}>\n                            <IconButton text={translate(\"$__removeImage\", 1)} icon={\"hide_image\"} textColor=\"color\" iconColor=\"color\" />\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                }\n            </div>\n            <Dialog fullWidth={true} onClose={() => SetImageCropDialog(false)} aria-labelledby=\"simple-dialog-title\" open={ImageCropDialog}>\n                <div style={{\n                    position: 'relative',\n                    marginLeft: '10px',\n                    width: 'calc(100% - 10px)',\n                    height: '45px',\n                    display: \"flex\"\n                }}>\n                    <HeaderWithIcon\n                        title={translate(\"$__cropImage\", 1)}\n                        icon=\"crop\"\n                        onSave={() => { _crop() }}\n                        onCancel={() => { SetImageCropDialog(false) }}\n                        actionsButtons={true}\n                        actionButtonsStyle={{ top: 0, height: 45, display: \"flex\", alignItems: \"center\" }}\n                    />\n                </div>\n                <Cropper\n                    className={props.avatar ? classes.circleCropper : classes.cropper}\n                    ref={cropper}\n                    src={ImagetoCrop || null}\n                    style={{ height: '50vh', width: '100%', margin: 'auto', padding: '0px' }}\n                    aspectRatio={props.ignoreAspect ? null : props.aspectRatio ? props.aspectRatio : props.avatar ? 1 : 16 / 9}\n                    guides={!props.noGuides ? true : false}\n                    viewMode={String(props.viewMode) ? props.viewMode : 2}\n                    checkOrientation={props.checkOrientation || false}\n                />\n            </Dialog>\n        </div>\n    )\n}\nconst mapStateToProps = store => ({\n    store\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","import React from \"react\";\n\n//REDUX\nimport * as reduxActions from \"store/actions\";\nimport history from \"store/history\";\nimport reduxStore from \"store\";\nimport { bindActionCreators } from \"redux\";\nimport { connect } from \"react-redux\";\n\n//COMPONENTS\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport TextField from \"components/TextField\";\nimport ImgCropper from \"components/Cropper\";\nimport Icon from \"components/Icon\";\nimport HeaderWithIcon from \"components/Header/card\";\nimport LinearProgress from \"components/Progress/linear\";\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\nimport Paper from \"@material-ui/core/Paper\";\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Card.js\";\n\nimport {\n    translate,\n    customApp,\n} from \"functions/\";\n\nimport {\n    saveCard,\n    copyCards,\n} from \"functions/cards\";\n\nimport {\n    loadCardsV2\n} from \"functions/loadData\";\n\nfunction Card(props) {\n    const { classes } = props;\n    const { db, session, timeline, functions } = reduxStore.getState();\n    const [data, setData] = React.useState({})\n\n    React.useEffect(() => {\n        setData({\n            ...props.toTemplate && db.cards[props.cardId].name ? { name: `${translate('$__template')} - ${db.cards[props.cardId].name}` } : {},\n            ...props.toTemplate && db.cards[props.cardId].description ? { description: db.cards[props.cardId].description } : {},\n            ...props.toTemplate && db.cards[props.cardId].image ? { image: db.cards[props.cardId].image } : {},\n        })\n    }, [])\n    const [errorData, setErrorData] = React.useState({})\n    const [installProgress, setInstallProgress] = React.useState(0)\n\n    const dataType = reduxStore.getState().db.cards[props.cardId] && reduxStore.getState().db.cards[props.cardId].type ? db.dataType.filter(a => a.name === reduxStore.getState().db.cards[props.cardId].type)[0] : {}\n\n    // console.log(data)\n    const installTemplate = async () => {\n        if (data && !data.name) {\n            setErrorData({\n                ...errorData,\n                name: true\n            })\n        } else {\n            setInstallProgress(1)\n            try {\n                let dataSend = {\n                    ...db.cards[props.cardId],\n                    ...data,\n                    templateId: db.cards[props.cardId]._id,\n                    created_at: null,\n                    isTemplate: props.toTemplate ? true : null,\n                    order: null,\n                    updated_at: null,\n                    _id: null,\n                    _planId: null,\n                }\n                const request = await saveCard(props, true, dataSend);\n                if (request && request._id) {\n                    setInstallProgress(2)\n                    setTimeout(() => {\n                        installStep2(request._id)\n                    }, 1500)\n                }\n            } catch (e) {\n\n            }\n        }\n    }\n\n    const installStep2 = async (id) => {\n        try {\n            const request2 = await copyCards(props, props.cardId, id);\n            if (request2) {\n                setInstallProgress(3)\n                setTimeout(() => {\n                    installStep3(id)\n                }, 1500)\n            }\n        } catch (err) {\n            console.log(err)\n        }\n    }\n\n    const installStep3 = async (id) => {\n        const loadPlan = await loadCardsV2(props, { idRel: [id], cardLoad: 'plans' })\n        const loadPlanCompleted = await loadCardsV2(props, { idRel: [id], cardLoad: 'plans', completed: true })\n        if (loadPlan && loadPlanCompleted) {\n            setInstallProgress(4)\n            setTimeout(() => {\n                if (props.onComplete)\n                    props.onComplete()\n\n                if (props.toTemplate) {\n                    history.push(`sp#tab/templates`)\n                } else {\n                    history.push(`sp#${id}/dashboard`)\n                }\n            }, 500)\n\n        }\n    }\n\n    if (installProgress > 0)\n        return (\n            <Paper style={{ padding: '7px', }}>\n                <HeaderWithIcon\n                    title={`${data.name ? data.name : db.cards[props.cardId].name} `}\n                    icon={dataType && dataType.icon ? dataType.icon : 'help'}\n                    iconTitle={`$__${db.cards[props.cardId].type}`}\n                    color={customApp('medium')}\n                    fontSize={\"16px\"}\n                />\n                {installProgress === 1 &&\n                    <div style={{ position: 'relative', float: 'left', width: '100%', clear: \"both\" }}>\n                        <div style={{ position: 'relative', float: 'left', width: '100%' }}>{translate('$__installingTemplate')}</div>\n                        <LinearProgress />\n                    </div>\n                }\n\n                {installProgress === 2 &&\n                    <React.Fragment>\n                        <div style={{ position: 'relative', float: 'left', width: '100%', display: \"flex\" }}>\n                            <div style={{ position: 'relative', float: 'left', width: '100%' }}>{translate('$__templateInstalled')}</div>\n                            <Icon icon='done_all' color={'green'} />\n                        </div>\n                        <div style={{ position: 'relative', float: 'left', width: '100%', marginTop: '15px' }}>\n                            <div style={{ position: 'relative', float: 'left', width: '100%' }}>{translate('$__copyingData')}</div>\n                            <LinearProgress />\n                        </div>\n                    </React.Fragment>\n                }\n                {installProgress === 3 &&\n                    <React.Fragment>\n                        <div style={{ position: 'relative', float: 'left', width: '100%', display: \"flex\" }}>\n                            <div style={{ position: 'relative', float: 'left', width: '100%' }}>{translate('$__templateInstalled')}</div>\n                            <Icon icon='done_all' color={'green'} />\n                        </div>\n                        <div style={{ position: 'relative', float: 'left', width: '100%', display: \"flex\", marginTop: '15px' }}>\n                            <div style={{ position: 'relative', float: 'left', width: '100%' }}>{translate('$__copiedData')}</div>\n                            <Icon icon='done_all' color={'green'} />\n                        </div>\n                        <div style={{ position: 'relative', float: 'left', width: '100%', marginTop: '15px' }}>\n                            <div style={{ position: 'relative', float: 'left', width: '100%' }}>{translate('$__preparingToRedirect')}</div>\n                            <LinearProgress />\n                        </div>\n                    </React.Fragment>\n                }\n                {installProgress === 4 &&\n                    <div style={{\n                        position: 'relative',\n                        width: '100%',\n                        display: \"flex\",\n                        justifyContent: \"center\",\n                    }}>\n                        <div style={{\n                            position: 'relative',\n                            float: 'left',\n                            padding: '15px',\n                            display: \"flex\",\n                            justifyContent: \"center\",\n                            borderRadius: '50%',\n                            border: 'solid 1px green'\n                        }}>\n                            <Icon icon='done_all' color={'green'} size={'50px'} />\n                        </div>\n                    </div>\n                }\n                <div style={{ clear: \"both\" }}></div>\n            </Paper>\n        )\n\n    return (\n        <Paper style={{ padding: '7px' }}>\n            <HeaderWithIcon\n                title={`${translate('$__template', 1)}: ${db.cards[props.cardId].name}`}\n                icon={dataType && dataType.icon ? dataType.icon : 'help'}\n                iconTitle={`$__${db.cards[props.cardId].type}`}\n                color={customApp('medium')}\n                fontSize={\"16px\"}\n            />\n            <div>\n                <ImgCropper\n                    img={props.toTemplate && db.cards[props.cardId].image ? db.cards[props.cardId].image : null}\n                    onChange={(a, file) => {\n                        setData({\n                            ...data,\n                            image: a,\n                            file: file\n                        })\n                    }}\n                    placeholder={''}\n                />\n                <TextField\n                    error={errorData && errorData.name}\n                    helperText={translate(\"$__youMustDefineAName\")}\n                    label={`${translate('$__customName', 1)}`}\n                    variant={customApp('fieldVariant')}\n                    name={'name'}\n                    defaultValue={props.toTemplate && db.cards[props.cardId].name ? `${translate('$__template')} - ${db.cards[props.cardId].name}` : null}\n                    InputLabelProps={{\n                        shrink: true,\n                    }}\n                    InputProps={{\n                        autoComplete: 'new-password',\n                        endAdornment: (\n                            <InputAdornment position=\"start\">\n                                <Icon icon='view_headline' />\n                            </InputAdornment>\n                        ),\n                        onChange: (d) => {\n                            setData({\n                                ...data,\n                                name: d.target.value\n                            })\n                            if (errorData && errorData.name)\n                                setErrorData({\n                                    ...errorData,\n                                    name: false\n                                })\n                        },\n                    }}\n                    // value={data && data.name ? data.name : ''}\n                    placeholder={translate(props.toTemplate ? '$__templateName_placeholder' : '$__planName_placeholder', 1)}\n                // disabled={!props.permission || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf('name') > -1) ? true : false}\n                />\n                <TextField\n                    label={`${translate('$__customDescription', 1)}`}\n                    variant={customApp('fieldVariant')}\n                    name={'description'}\n                    defaultValue={props.toTemplate && db.cards[props.cardId].description ? db.cards[props.cardId].description : null}\n                    InputLabelProps={{\n                        shrink: true,\n                    }}\n                    InputProps={{\n                        autoComplete: 'new-password',\n                        endAdornment: (\n                            <InputAdornment position=\"start\">\n                                <Icon icon='toc' />\n                            </InputAdornment>\n                        ),\n                        onChange: (d) => {\n                            setData({\n                                ...data,\n                                description: d.target.value\n                            })\n                        },\n                    }}\n                    placeholder={translate(props.toTemplate ? '$__templateDescription_placeholder' : '$__planDescription_placeholder', 1)}\n                    multiline\n                />\n            </div>\n\n            <div\n                style={{\n                    position: \"relative\",\n                    width: \"100%\",\n                    clear: \"both\",\n                    padding: \"7px\",\n                    backgroundColor: \"#4caf50\",\n                    marginTop: \"7px\",\n                    cursor: \"pointer\"\n                }}\n                onClick={(e) => {\n                    installTemplate()\n                    e.stopPropagation()\n                }}>\n\n                <IconButton\n                    text={translate(\"$__ready\", '*')}\n                    icon=\"done_all\"\n                    iconColor={'#FFFFFF'}\n                    textColor={'#FFFFFF'}\n                />\n            </div>\n            <div style={{\n                position: \"relative\",\n                width: \"100%\",\n                clear: \"both\",\n                padding: \"7px\",\n                backgroundColor: \"lightgrey\",\n                cursor: \"pointer\"\n            }}\n                onClick={(e) => {\n                    props.onComplete()\n                    e.stopPropagation()\n                }}>\n                <IconButton\n                    text={translate(\"$__cancel\", '*')}\n                    icon=\"close\"\n                    iconColor={'#FFFFFF'}\n                    textColor={'#FFFFFF'}\n                    onClick={props.onComplete ? () => {\n                        props.onComplete()\n                    } : null}\n                />\n            </div>\n        </Paper >\n    )\n}\n\n//REACT\nconst mapStateToProps = () => ({});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Card));","import React, { memo, useRef, useEffect } from \"react\"\nimport moment from \"moment-timezone\"\nimport styled from \"styled-components\"\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport history from \"store/history\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//COMPONENTS\nimport Badge from \"components/Icon/Badge\"\nimport CardTags from \"components/Tags/Card\"\nimport CustomButton from \"components/Buttons/custom\"\nimport HeaderWithIcon from \"components/Header/card\"\nimport Icon from \"components/Icon\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport Navigation from \"components/Navigation\"\nimport ProgressLinear from \"components/Progress/linear\"\nimport QuickUsers_List from \"components/User/avatarList\"\nimport TextField from \"components/TextField\"\nimport Timer from \"components/Timer/timer\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport ClickAwayListener from \"@material-ui/core/ClickAwayListener\"\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport Modal from '@material-ui/core/Modal'\nimport Tooltip from \"@material-ui/core/Tooltip\"\n\n//DEPENDENCIES\nimport FakeExpanded from \"./FakeExpanded\"\nimport CardExpanded from \"./cardExpanded\"\nimport UseTemplate from \"./useTemplate\"\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Card.js\"\n\n\n//FUNCTIONS\nimport apims from \"apims\"\n\nimport {\n    setCompletedStep,\n    cardStatus,\n    copyCards,\n    deleteCard,\n    getCardColor,\n    getUserAccess,\n    kpiTimerStart,\n    restoreCard,\n    saveCard,\n    saveMATRIX,\n    selectSWOT,\n    setMyDay,\n    updateCard,\n    updateCardStatus,\n} from \"functions/cards\"\n\nimport {\n    action\n} from \"functions/kanban\"\n\nimport {\n    Highlighted,\n    appAlert,\n    customApp,\n    favoriteNode,\n    getAppAccess,\n    getDate,\n    translate,\n} from \"functions/\"\n\nfunction Card(props) {\n    const classes = useStyles()\n    const { db, session } = reduxStore.getState()\n    const data = props.data\n    const [isExpanded, setExpanded] = React.useState(false)\n    const [globalExpanded, setGlobalExpanded] = React.useState(props.cardsExpanded)\n    const [useTemplate, setUseTemplate] = React.useState(false)\n    const [showMoreButton, setShowMoreButton] = React.useState(false)\n    const [showPrivateCard, setShowPrivateCard] = React.useState(false)\n    const [cardColor, setCardColor] = React.useState(props.cardColorPicker ? getCardColor(data) : {})\n    const [duplicate, setDuplicate] = React.useState(false)\n    const [move, setMove] = React.useState(false)\n    const [copyName, setCopyName] = React.useState(data?.name || \"\")\n    const [copyModel, setCopyModel] = React.useState(false)\n    const [copyRel, setCopyRel] = React.useState({})\n    const [selectTarget, setSelectTarget] = React.useState(false)\n    const [duplicateLoader, setDuplicateLoader] = React.useState(false)\n    const [combine, setCombine] = React.useState(false)\n\n    const cardRef = useRef({});\n    const combineRef = useRef({})\n\n    useEffect(() => {\n        if (cardRef.current) {\n            if (props.onResize) {\n                let newSize = cardRef.current.clientHeight\n                if (props.separator)\n                    newSize = newSize + 55\n                props.onResize(newSize, isExpanded)\n                cardRef.current.addEventListener(\"DOMNodeInserted\", () => {\n                    let newSize = cardRef.current.clientHeight\n                    if (props.separator)\n                        newSize = newSize + 55\n                    props.onResize(newSize, isExpanded)\n                })\n            }\n        }\n        // eslint-disable-next-line\n    }, [cardRef, isExpanded, props.manualExpanded, combine]);\n\n\n    useEffect(() => {\n        if (props?.snapshot?.combineTargetFor)\n            setCombine(true)\n        if (!props?.snapshot?.combineTargetFor && combine)\n            setCombine(false)\n    }, [props?.snapshot?.combineTargetFor])\n\n\n    React.useEffect(() => {\n        let isMounted = true\n        if (isMounted && String(props.unlockedPrivates) === \"0\" && showPrivateCard) {\n            setShowPrivateCard(false)\n        }\n        return () => {\n            isMounted = false\n        }\n    }, [props.unlockedPrivates])\n\n    React.useEffect(() => {\n        let isSubscribed = true\n        if (isSubscribed)\n            setGlobalExpanded(props.cardsExpanded)\n\n        return () => {\n            isSubscribed = false\n        }\n    }, [props.cardsExpanded])\n\n    React.useEffect(() => {\n        if (props.onExpand)\n            props.onExpand(globalExpanded)\n    }, [globalExpanded])\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    React.useEffect(() => {\n        let isMounted = true\n        if (isMounted && props.cardColorPicker && hashs && hashs[1] === 'overview')\n            setCardColor(getCardColor(data))\n        return () => {\n            isMounted = false\n        }\n    }, [props.cards])\n\n    if (data === {} || !data)\n        return (<React.Fragment></React.Fragment>)\n\n    let AppAccess = getAppAccess()\n    let CardAccess = getUserAccess(data._id)\n\n\n\n    if (!data || !props.data || !props.data._id)\n        return null\n\n    const selectThis = async () => {\n        let activeCards = {}\n\n        Object.keys(db.cards).filter(a =>\n            db.cards[a]\n            && !db.cards[a].deleted\n            && (\n                db.cards[a]._planId === hashs[0]\n                || db.cards[a]._parent === hashs[0]\n            )\n        ).map(a => {\n            activeCards = {\n                ...activeCards,\n                [a]: db.cards[a]\n            }\n        })\n\n        let cards = { ...reduxStore.getState().db.cards }\n        let selected = data._selected ? false : true\n\n        if (db.dataType.filter(fil => fil.name === data.type)[0].module !== \"swot\") {\n            Object.keys(activeCards).filter(a => activeCards[a]._id !== data._id && activeCards[a].type && activeCards[a].type === data.type).map(a => {\n                if (activeCards[a]._selected)\n                    activeCards[a]._selected = false\n            })\n        }\n\n        if (data.type.indexOf(\"guideline\") > -1) {\n            Object.keys(activeCards).map(a => {\n                if (activeCards[a]._selected)\n                    activeCards[a]._selected = false\n            })\n        }\n        if (data.type.indexOf(\"objective\") > -1) {\n            Object.keys(activeCards).filter(a => activeCards[a].type === \"goal\").map(a => {\n                if (activeCards[a]._selected)\n                    activeCards[a]._selected = false\n            })\n        }\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...cards,\n                ...activeCards,\n                [data._id]: {\n                    ...reduxStore.getState().db.cards[data._id],\n                    ...activeCards[data._id],\n                    _selected: selected\n                }\n            }\n        })\n\n\n        if (reduxStore.getState().db.dataType.filter(a => a.name === data.type)[0].module === \"swot\") {\n            saveMATRIX(props)\n        }\n        if (selected && reduxStore.getState().db.dataType.filter(a => a.name === data.type)[0].module === \"matrix\") {\n            selectSWOT(props, data._id)\n        }\n    }\n\n    const openSideModule = async (module = \"cardEdit\") => {\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...reduxStore.getState().sideModule,\n            db: props.db,\n            id: data._id,\n            module: \"cardEdit\",\n            activeModule: reduxStore.getState().db.dataType.filter(a => a.name === data.type)[0].iniModule || module,\n            data: data,\n        })\n    }\n\n    const setCompleted = async () => {\n        //Executa Automação\n        if (data._hasStep) {\n            action({\n                ...props,\n                nodeId: data._id,\n            })\n        }\n\n        //Conclui atividade\n        if (!data._hasStep) {\n            const countChildrens = await apims.post(\"/Card_Count\", { id: data._id })\n            if (parseInt(countChildrens.data) > 0) {\n                appAlert({\n                    message: translate('$__concludeWithChildrensNotConcludedConfirm', 1),\n                    autoClose: 50000,\n                    buttons: [\n                        {\n                            shadow: true,\n                            title: translate(\"$__concludeAll\"),\n                            text: translate(\"$__concludeAll\"),\n                            color: \"green\",\n                            icon: \"close\",\n                            size: \"25px\",\n                            onClick: () => {\n                                updateCardStatus(\n                                    {\n                                        ...props,\n                                        data: { _id: data._id }\n                                    }, { status: data.status === 'completed' ? 'inProgress' : 'completed' })\n                                if (countChildrens && parseInt(countChildrens.data) > 0)\n                                    cardStatus(props, data._id, data.status === 'completed' ? 'inProgress' : 'completed')\n                            },\n                            style: { marginLeft: 15 }\n                        },\n                        {\n                            shadow: true,\n                            title: translate(\"$__cancel\"),\n                            text: translate(\"$__cancel\"),\n                            color: \"red\",\n                            icon: \"close\",\n                            size: \"25px\",\n                            onClick: () => {\n                                // toast.dismiss(key)\n                            },\n                            style: { marginLeft: 15 }\n                        }],\n                    variant: 'warning',\n                    persist: false,\n                    horizontal: 'right',\n                })\n            } else {\n                updateCardStatus(\n                    {\n                        ...props,\n                        data: { _id: data._id }\n                    }, { status: data.status === 'completed' ? 'inProgress' : 'completed' })\n                if (countChildrens && parseInt(countChildrens.data) > 0)\n                    cardStatus(props, data._id, data.status === 'completed' ? 'inProgress' : 'completed')\n            }\n        }\n    }\n\n    const openPlan = async (id) => {\n        if (\n            parseInt(CardAccess) > 2\n            ||\n            (AppAccess.owner\n                ||\n                (\n                    AppAccess.plan\n                    && (\n                        AppAccess.planAdmin\n                        || AppAccess.planModerate\n                    )\n                )\n            )\n        ) {\n            history.push(`sp#${id}/dashboard`)//#CORRECT\n        } else {\n            openSideModule(\"timeline\")\n        }\n    }\n\n    const deleteThis = async () => {\n        appAlert({\n            message: translate(\"$__confirmDeleteThis\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                // deleteNode(props, { _id: data._id })\n                deleteCard(props, { _id: data._id }, false)\n                if (!props.directDeletion)\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n            }\n        })\n    }\n    const restoreThis = async () => {\n        appAlert({\n            message: translate(\"$__confirmRestoreThis\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                restoreCard(props, { _id: data._id })\n            }\n        })\n    }\n\n\n    const selectable = Object.keys(reduxStore.getState().db.cards)\n        .filter(a =>\n            reduxStore.getState().db.cards[a]\n            && reduxStore.getState().db.cards[a]._selected === true\n            && reduxStore.getState().db.cards[a].type\n            && reduxStore.getState().db.cards[a].type.indexOf(\"guideline\") > -1\n        ).length > 0\n        ? true\n        : false\n\n    const cardClick = () => {\n        if (props.disabled)\n            return\n        if (props.selectable) {\n            selectThis()\n        } else if (!props.onClick && ((!props.locked && props.showSelected && selectable) || props.selectable)) {\n            selectThis()\n        } else if (props.onClick && !props.selectable && !props.locked) {\n            props.onClick()\n        } else if (!props.locked && !props.onlyOption && data.type === 'plan') {\n            openPlan(data._id)\n        } else if (!props.locked) {\n            openSideModule()\n        }\n    }\n\n    const expanded = props.noExpanded ? false : isExpanded || !props.notGlobalExpanded && (props.manualExpanded || props.expanded || data._expanded || props.cardsExpanded ? true : false)\n\n    let permission = (\n        (\n            AppAccess\n            &&\n            (AppAccess.owner\n                ||\n                (\n                    AppAccess.plan\n                    && (\n                        AppAccess.planAdmin\n                        || AppAccess.planModerate\n                    )\n                )\n            )\n        )\n        ||\n        (\n            CardAccess > 2\n        )\n    )\n        ? true : false\n\n    const openContextMenu = () => {\n        // console.log('OPENNNNNN')\n    }\n\n    const duplicateCard = async () => {\n        setDuplicateLoader(true)\n        let newData = {}\n        Object.keys(data).map(x => {\n            if (x.indexOf(\"_\") === -1 && x !== \"created_at\" && x !== \"updated_at\")\n                newData = {\n                    ...newData,\n                    [x]: data[x]\n                }\n        })\n\n        newData = {\n            ...newData,\n            idRel: copyRel && copyRel._id ? copyRel._id : data._parent ? data._parent : null,\n            name: copyName,\n            ...copyModel ? { isModel: true } : {},\n            status: \"notStarted\"\n        }\n\n        try {\n            const request = await saveCard(props, true, newData, newData.idRel);\n            if (request && request._id) {\n                let copyResult = await copyCards(props, data._id, request._id);\n                if (copyResult) {\n                    setDuplicate(false)\n                    setCopyRel({})\n                    setCopyName(data.name)\n                    setSelectTarget(false)\n                    setDuplicateLoader(false)\n                }\n            }\n        } catch (e) {\n            console.log(\"ERROR\", e)\n        }\n    }\n\n    const moveCard = async () => {\n        let newData = {}\n        Object.keys(data).map(x => {\n            if (x.indexOf(\"_\") === -1 && x !== \"created_at\" && x !== \"updated_at\")\n                newData = {\n                    ...newData,\n                    [x]: data[x]\n                }\n        })\n\n        newData = {\n            ...newData,\n            idRel: copyRel && copyRel._id ? copyRel._id : data._parent ? data._parent : null,\n            name: copyName,\n            ...copyModel ? { isModel: true } : {},\n            status: \"notStarted\"\n        }\n\n        // try {\n        //     const request = await saveCard(props, true, newData, newData.idRel);\n        //     if (request && request._id) {\n        //         await copyCards(props, data._id, request._id);\n        //         setDuplicate(false)\n        //     }\n        // } catch (e) {\n        //     console.log(\"ERROR\", e)\n        // }\n    }\n\n\n    //MYDAY\n    let myDay = { button: false, date: null }\n    if (data && data._users\n        && Object.keys(data._users).filter(fil => fil === session._id).length > 0\n        && db.dataType.filter(c => c.name === data.type).length > 0\n        && db.dataType.filter(c => c.name === data.type)[0].modules.indexOf(\"myDay\") > -1) {\n        if (data._users[Object.keys(data._users).filter(fil => fil === session._id)[0]].myDay) {\n            myDay = {\n                button: true,\n                date: data._users[Object.keys(data._users).filter(fil => fil === session._id)[0]].myDay\n            }\n        } else {\n            myDay = {\n                button: true,\n                date: null\n            }\n        }\n    } else {\n        myDay = {\n            button: false,\n            date: null\n        }\n    }\n    if (data && data.private && (\n        !data._users\n        || (\n            data._users\n            && !data._users[session._id]\n        )\n    ))\n        return (<React.Fragment></React.Fragment>)\n\n    if (useTemplate) {\n        return (\n            <UseTemplate cardId={data._id}\n                toTemplate={!data.isTemplate ? true : false}\n                onComplete={() => {\n                    setUseTemplate(false)\n                }} />\n        )\n    }\n\n    let locked = false\n\n    const planningTypes = [\"guideline\", \"guidelineD\", \"guidelineR\", \"guidelineC\", \"guidelineE\", \"objective\", \"goal\"]\n    return (\n        <Container\n            ref={cardRef}\n            separator={props.separator || false}\n            plan={expanded && data.type === 'plan' ? true : false}\n            isDragging={props.snapshot && props.snapshot.isDragging}\n            isDragDisable={data.isDragDisable || props.isDragDisable || false}\n            inLine={data.type !== \"plan\" && props.inLine ? true : false}\n            className={!props.noShadow ? classes.container : classes.containerNoShadow}\n            selectable={props.showSelected}\n            selected={data._selected}\n            priority={data.priority && db.priority.filter(a => String(a.value) === String(data.priority)).length > 0 ? db.priority.filter(a => String(a.value) === String(data.priority))[0].color : null}\n            locked={props.locked || false}\n            snapshot={props.snapshot || null}\n            isCombining={props.snapshot && props.snapshot.combineTargetFor ? true : false}\n            onMouseOver={() => {\n                setShowMoreButton(true)\n            }}\n            onMouseLeave={() => {\n                setTimeout(() => {\n                    setShowMoreButton(false)\n                }, 100)\n            }}\n            onClick={(e) => {\n                cardClick()\n            }}\n            onContextMenu={(e) => {\n                openContextMenu(e)\n            }}\n        >\n            {(data.status === 'completed' || (props.cardColorPicker && cardColor.color)) &&\n                <div style={{\n                    position: 'absolute',\n                    top: 0,\n                    left: 0,\n                    right: 0,\n                    bottom: 0,\n                    display: 'flex',\n                    alignItems: 'center',\n                    cursor: \"pointer\"\n                }}>\n                    <div style={{\n                        position: 'absolute',\n                        backgroundColor: props.cardColorPicker && cardColor.color ? cardColor.color : 'rgba(0,0,0,1)',\n                        opacity: cardColor.color ? 0.2 : 0.1,\n                        top: 0,\n                        left: 0,\n                        right: 0,\n                        bottom: 0,\n                        display: 'flex',\n                        alignItems: 'center',\n                        cursor: \"pointer\"\n                    }}>\n                    </div>\n\n                </div>\n            }\n\n            <React.Fragment>\n                {props.snapshot && props.snapshot.combineTargetFor &&\n                    <div style={{ backgroundColor: customApp('menu'), padding: '7px 3px', color: '#FFFFFF', fontWeight: 'bold', textAlign: 'center' }}>\n                        {translate('$__dropHereToLink')}\n                    </div>\n                }\n                {((data.type === 'insight' || data.type === 'link') && data._createdBy && db.users[data._createdBy]) &&\n                    <div style={{\n                        width: 'calc(100% - 0px)',\n                        alignItems: 'center',\n                        padding: '7px',\n                        display: 'inline-flex',\n                        borderBottom: 'solid 1px rgba(0,0,0,0.03)'\n                    }}>\n                        <div style={{\n                            position: 'relative',\n                            float: 'left'\n                        }}>\n                            <Tooltip\n                                title={db.users[data._createdBy].name}\n                            >\n                                <Avatar alt={db.users[data._createdBy].name} src={db.users[data._createdBy].image || null} >\n                                    {db.users[data._createdBy].name.substr(0, 1)}\n                                </Avatar>\n                            </Tooltip>\n                        </div>\n                        <div style={{\n                            position: 'relative',\n                            float: 'left',\n                            width: 'calc(100% - 70px)',\n                            flexDirection: 'column',\n                            paddingLeft: '7px'\n                        }}>\n                            <div style={{\n                                color: customApp('menu'),\n                                fontWeight: 'bold',\n                                fontSize: '16px'\n                            }}>\n                                {db.users[data._createdBy].displayName ? db.users[data._createdBy].displayName : db.users[data._createdBy].name.split(' ')[0]}\n                            </div>\n                            <div>\n                                {moment(new Date()).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") === moment(data.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") ?\n                                    `${moment(data.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"H:mm\")}`\n                                    :\n                                    moment(new Date()).tz(\"America/Sao_Paulo\").format(\"YYYY\") === moment(data.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"YYYY\") ?\n                                        `${moment(data.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM H:mm\")}`\n                                        :\n                                        `${moment(data.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")}`\n                                }\n                            </div>\n                        </div>\n                        <div\n                            style={{\n                                width: '24px',\n                                float: 'right'\n                            }}\n                        >\n                            <Icon\n                                icon={\n                                    (\n                                        data.type\n                                        && db\n                                        && db.dataType\n                                        && db.dataType.filter(a =>\n                                            a.name === data.type)[0]\n                                        && db.dataType.filter(a =>\n                                            a.name === data.type)[0].icon\n                                    )\n                                    || \"$__topic\"\n                                }\n                            />\n                        </div>\n                    </div>\n                }\n\n                {/* {console.log(data, Object.keys(reduxStore.getState().db.cards).filter(fil => reduxStore.getState().db.cards[fil]\n                    && reduxStore.getState().db.cards[fil].type === \"step\"\n                    && reduxStore.getState().db.cards[fil]._parent === data._id\n                ).length)} */}\n                <HeaderWithIcon\n                    private={(data.private || data.parentPrivate) ? true : false}\n                    unlockedPrivates={props.unlockedPrivates}\n                    setPrivate={(a) => {\n                        let value = a ? 1 : -1\n                        if (!a && props.unlockedPrivates === 0)\n                            value = 0\n                        props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\n                            ...reduxStore.getState().controls,\n                            unlockedPrivates: reduxStore.getState().controls.unlockedPrivates + value,\n                        })\n                        setShowPrivateCard(a)\n                        if (props.setPrivate)\n                            props.setPrivate(a)\n                    }}\n                    viewAllName={props.viewAllName}\n                    title={`${data?.name || translate(\"$__new\", 1)} `}\n                    searchText={props?.searchText || null}\n                    icon={data?.icon || (data.type && db && db.dataType && db.dataType.filter(a => a.name === data.type)[0] && db.dataType.filter(a => a.name === data.type)[0].icon) || \"$__topic\"}\n                    iconTitle={`$__${data.type}`}\n                    color={customApp('medium')}\n                    editable={!data.name && (!props.onlyOption || props.editable) ? true : false}\n                    _id={data._id}\n                    locked={data.type === \"link\" || props.locked ? true : false}\n                    colorPicker={permission && props.cardColorPicker && cardColor && !cardColor.parent ? (color) => {\n                        if (\n                            (!cardColor.color && color)\n                            || (cardColor.color && cardColor.color !== color)\n                        )\n                            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                                ...reduxStore.getState().db,\n                                cards: {\n                                    ...reduxStore.getState().db.cards,\n                                    [data._id]: {\n                                        ...reduxStore.getState().db.cards[data._id],\n                                        color\n                                    },\n                                }\n                            })\n                    } : null}\n                    onEdit={\n                        (data.status !== 'completed' && (CardAccess && parseInt(CardAccess) > 1) || (AppAccess && AppAccess.plan && (AppAccess.owner || AppAccess.planAdmin || AppAccess.planEdit || AppAccess.planModerate))) ? (res) => {\n                            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                                ...reduxStore.getState().db,\n                                cards: {\n                                    ...reduxStore.getState().db.cards,\n                                    [data._id]: {\n                                        ...reduxStore.getState().db.cards[data._id],\n                                        name: res\n                                    },\n                                }\n                            })\n                        } : null}\n                    moreButton={showMoreButton}\n                    options={\n\n                        data.deleted ? [\n                            {\n                                name: translate(`$__restoreThis`, 1),\n                                icon: 'restore_from_trash',\n                                onClick: () => {\n                                    restoreThis()\n                                },\n                                show: \"hover\",\n                                color: customApp('medium'),\n                            }\n                        ]\n                            : !props.onlyOption && (!props.showSelected && !props.locked) ? [\n                                Object.keys(reduxStore.getState().db.cards).filter(fil => reduxStore.getState().db.cards[fil]\n                                    && reduxStore.getState().db.cards[fil].type === \"step\"\n                                    && reduxStore.getState().db.cards[fil]._parent === data._id\n                                ).length > 0\n                                && {\n                                    name: \"$__openTaskList\",\n                                    icon: \"schema\",\n                                    show: \"fixed\",\n                                    onClick: () => {\n                                        props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\n                                            ...reduxStore.getState().control,\n                                            board: data._id,\n                                        })\n                                    },\n                                },\n                                data.url &&\n                                {\n                                    name: \"$__openLinkinNewTab\",\n                                    icon: \"launch\",\n                                    onClick: () => {\n                                        window.open(data.url, '_blank')\n                                    },\n                                },\n                                !data.archived\n                                && !data.isTemplate\n                                && data.type === 'plan'\n                                && {\n                                    name: !data._isFavorite ? \"$__addToFavorite\" : \"$__removeFromFavorite\",\n                                    icon: !data._isFavorite ? \"favorite_border\" : \"favorite\",\n                                    color: customApp('medium'),\n                                    onClick: async () => {\n                                        favoriteNode(props, data._id, !data._isFavorite ? false : true)\n                                        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                                            ...reduxStore.getState().db,\n                                            cards: {\n                                                ...reduxStore.getState().db.cards,\n                                                [data._id]: {\n                                                    ...reduxStore.getState().db.cards[data._id],\n                                                    _isFavorite: !data._isFavorite ? true : false\n                                                },\n                                            }\n                                        })\n                                    },\n                                },\n                                !data.archived\n                                && data.status !== 'completed'\n                                && myDay\n                                && myDay.button\n                                && {\n                                    name: moment(new Date(myDay.date * 1000)).format(\"YYYY/MM/DD\") === moment().format(\"YYYY/MM/DD\") ? \"$__removeOfMyDate\" : \"$__addOnMyDay\",\n                                    icon: moment(new Date(myDay.date * 1000)).format(\"YYYY/MM/DD\") === moment().format(\"YYYY/MM/DD\") ? \"auto_delete\" : \"alarm_add\",\n                                    color: moment(new Date(myDay.date * 1000)).format(\"YYYY/MM/DD\") === moment().format(\"YYYY/MM/DD\") ? \"red\" : \"lightblue\",\n                                    show: \"hover\",\n                                    onClick: () => {\n                                        let myDayOption = (!myDay || !myDay.date) || (myDay && myDay.date && moment(new Date(myDay.date * 1000)).format(\"YYYY/MM/DD\") !== moment().format(\"YYYY/MM/DD\")) ? true : false\n                                        setMyDay(props, {\n                                            _id: data._id,\n                                            userId: session._id,\n                                            option: myDayOption\n                                        })\n                                        if (props.myDayClick)\n                                            props.myDayClick()\n                                    },\n                                },\n                                !data.archived && !props.onlyOption && ((CardAccess && parseInt(CardAccess) > 1) || AppAccess.owner || AppAccess.planAdmin || AppAccess.planEdit || AppAccess.planModerate) &&\n                                {\n                                    name: \"$__edit\",\n                                    icon: \"edit\",\n                                    onClick: () => {\n                                        if (props.onAction)\n                                            props.onAction()\n                                        openSideModule()\n                                    },\n                                    show: \"hover\"\n                                },\n                                (\n                                    !data.archived\n                                    && !data.isTemplate\n                                    && data._users\n                                    && data.status !== 'completed'\n                                    && data._users[session._id]\n                                    &&\n                                    (\n                                        !data._kpiTimer\n                                        ||\n                                        Object.keys(data._kpiTimer).length === 0\n                                        ||\n                                        (\n                                            data._kpiTimer\n                                            && Object.keys(data._kpiTimer).length > 0\n                                            && Object.keys(data._kpiTimer).filter(at =>\n                                                session\n                                                && session._id\n                                                && at\n                                                && data._kpiTimer[at]\n                                                && data._kpiTimer[at].userId\n                                                && data._kpiTimer[at].userId === session._id\n                                            ).length === 0\n                                        )\n                                    )\n                                )\n                                &&\n                                {\n                                    name: \"$__timerStart\",\n                                    icon: \"play_circle_outline\",\n                                    color: 'blue',\n                                    show: 'hover',\n                                    onClick: () => {\n                                        appAlert({\n                                            message: translate('$__confirmStartTimer', 1),\n                                            variant: 'warning',\n                                            persist: false,\n                                            horizontal: 'right',\n                                            confirm: () => {\n                                                kpiTimerStart(props, data._id)\n                                                let myDayOption = (!myDay || !myDay.date) || (myDay && myDay.date && moment(new Date(myDay.date * 1000)).format(\"YYYY/MM/DD\") !== moment().format(\"YYYY/MM/DD\")) ? true : false\n                                                if (myDayOption)\n                                                    setMyDay(props, {\n                                                        _id: data._id,\n                                                        userId: session._id,\n                                                        option: true\n                                                    })\n                                                if (props.myDayClick)\n                                                    props.myDayClick()\n                                            }\n                                        })\n                                    },\n                                },\n                                // data._hasStep && {\n                                //     name: \"$__completeStep\",\n                                //     icon: \"rule\",\n                                //     color: 'green',\n                                //     show: 'hover',\n                                //     onClick: async () => {\n                                //         setCompletedStep(data._id)\n                                //     },\n                                // },\n\n                                //CONCLUDE OPTIONS\n                                (\n                                    data._users\n                                    && data.status !== 'completed'\n                                    && data._users[session._id]\n                                )\n                                &&\n                                {\n                                    name: data._hasStep ? \"$__completeStep\" : \"$__complete\",\n                                    icon: \"check_circle\",\n                                    color: 'green',\n                                    show: 'hover',\n                                    onClick: async () => {\n                                        setCompleted()\n                                    },\n                                },\n\n                                (\n                                    !data.archived\n                                    && !props.onlyOption && (props.selectOption || props.viewButton) && (data.type.indexOf(\"guideline\") > -1\n                                        || data.type.indexOf(\"objective\") > -1\n                                        || data.type.indexOf(\"goal\") > -1)\n                                ) && {\n                                    name: data._selected ? \"$__removeSelection\" : \"$__selectThis\",\n                                    icon: data._selected ? \"visibility_off\" : \"visibility\",\n                                    hide: true,\n                                    onClick: () => {\n                                        selectThis()\n                                    },\n                                },\n                                {\n                                    name: \"$__duplicate\",\n                                    icon: \"content_copy\",\n                                    onClick: () => {\n                                        setDuplicate(true)\n                                        setCopyName(data.name)\n                                    },\n                                },\n                                // {\n                                //     name: \"$__move\",\n                                //     icon: \"drive_file_move\",\n                                //     onClick: () => {\n                                //         setMove(true)\n                                //         setCopyName(data.name)\n                                //     },\n                                // },\n                                !data.isTemplate && data.type === 'plan' &&\n                                {\n                                    name: \"$__copyToTemplates\",\n                                    icon: \"copy_all\",\n                                    onClick: () => {\n                                        setUseTemplate(true)\n                                    },\n                                },\n                                (\n                                    data\n                                    && !data.isTemplate\n                                    && data.type === 'plan'\n                                    && !data.archived\n                                    && (\n                                        (\n                                            data._users\n                                            && data._users[session._id]\n                                            && data._users[session._id].access\n                                            && parseInt(data._users[session._id].access) === 5\n                                        )\n                                        ||\n                                        (\n                                            AppAccess\n                                            && AppAccess.planAdmin\n                                        )\n                                    )\n                                ) && {\n                                    name: translate('$__shelve'),\n                                    icon: 'archive',\n                                    onClick: () => {\n                                        updateCard(props, {\n                                            _id: data._id,\n                                            archived: true,\n                                        })\n                                    },\n                                },\n                                ((CardAccess && parseInt(CardAccess) === 5) || AppAccess.owner || AppAccess.planAdmin || AppAccess.planEdit) && !props.disableDelete &&\n                                {\n                                    name: \"$__delete\",\n                                    icon: \"delete_forever\",\n                                    color: 'red',\n                                    onClick: () => {\n                                        if (\n                                            props.directDeletion\n                                            || data.archived\n                                            || (\n                                                db.dataType.filter(c => c.name === data.type).length === 0\n                                                ||\n                                                (\n                                                    db.dataType.filter(c => c.name === data.type).length > 0\n                                                    && db.dataType.filter(c => c.name === data.type)[0].module === 'swot'\n                                                )\n                                            )\n                                        ) {\n                                            deleteThis()\n                                        } else {\n                                            openSideModule('delete')\n                                        }\n                                        if (props.onAction)\n                                            props.onAction()\n                                    },\n                                    show: \"hover\"\n                                },\n                                (\n                                    data\n                                    && !data.isTemplate\n                                    && data.type === 'plan'\n                                    && data.archived\n                                    && (\n                                        data._users\n                                        && data._users[session._id]\n                                        && data._users[session._id].access\n                                        && parseInt(data._users[session._id] === 5\n                                        )\n                                        ||\n                                        (AppAccess\n                                            &&\n                                            AppAccess.planAdmin\n                                        )\n                                    )\n                                ) && {\n                                    name: translate('$__unarchive'),\n                                    icon: 'archive',\n                                    onClick: () => {\n                                        updateCard(props, {\n                                            _id: data._id,\n                                            archived: null,\n                                        })\n                                    },\n                                },\n                                !data.isTemplate\n                                && !data.archived\n                                && (props.my || props.showCompleteOption) && {\n                                    name: data.status !== \"$__completed\" ? \"$__markasdone\" : \"$__concluded\",\n                                    icon: \"check_circle_outline\",\n                                    color: data.status !== \"completed\" ? \"lightgray\" : \"green\",\n                                    onClick: async () => {\n                                        setCompleted()\n                                    },\n                                }\n                            ] : []}\n                    isExpanded={props.noExpanded ? false : expanded}\n                    noExpanding={props.expanded || reduxStore.getState().db.cardsExpanded || false}\n                    onExpanding={() => {\n                        if (props.onExpand) {\n                            props.onExpand(!expanded)\n                        }\n                        if (!props.expanded && !reduxStore.getState().db.cardsExpanded) {\n                            setExpanded((prevExpanded) => !prevExpanded)\n                        }\n                    }\n                    }\n                    onClick={(e) => {\n                        // e.preventDefault()\n                        // cardClick()\n                    }}\n                />\n                {/* {console.log(data)} */}\n                {data && data._cardCode ?\n                    <div\n                        style={{\n                            // position: \"relative\",\n                            // width: \"auto\",\n                            marginLeft: 36,\n                            fontSize: 11,\n                            marginTop: -9,\n                            color: \"gray\",\n                            // padding: \"3px 5px\",\n                            // backgroundColor: \"lightgray\",\n                            // borderRadius: 7,\n                        }}>\n                        # {data._cardCode}\n                    </div>\n                    : <React.Fragment></React.Fragment>\n                }\n                {data._kpiTimer && Object.keys(data._kpiTimer).length > 0 && Object.keys(data._kpiTimer).filter(a => data._kpiTimer[a].userId === session._id).length !== 0 &&\n                    <div\n                        style={{\n                            position: 'relative',\n                            width: '100%',\n                            float: 'left'\n                        }}\n                        onClick={(e) => {\n                            e.stopPropagation()\n                        }}\n                    >\n                        <Timer data={data} />\n                    </div>\n                }\n                {(\n                    !props.noExpanded\n                    && expanded\n                    && (\n                        !data.private\n                        || (\n                            data.private\n                            && (showPrivateCard || reduxStore.getState().controls.lockPrivate)\n                        )\n                    )\n                ) ?\n                    <React.Fragment>\n                        <CardExpanded\n                            {...props}\n                            private={data.private ? true : false}\n                            expanded\n                            onClick={(e) => {\n                                // e.preventDefault()\n                                // cardClick()\n                                // e.stopPropagation()\n                            }}\n                            Resume={true}\n                        // onExpand={() => {\n                        //     if (props.onExpand)\n                        //         props.onExpand()\n                        // }}\n                        />\n                        {/* {\n                            (\n                                (\n                                    (\n                                        props.resume\n                                        && props.showChildrens\n                                    )\n                                    ||\n                                    expanded\n                                )\n                                &&\n                                Object.keys(childrensIndicators).length > 0\n                            )\n                            &&\n                            <AvatarGroup max={100} className={classes.indicators} style={{\n                                flexFlow: 'wrap'\n                            }}>\n                                {Object.keys(childrensIndicators)\n                                    .map((a, i) => (\n                                        String(a) !== \"null\" && String(a) !== \"undefined\" ?\n                                            <Badge\n                                                overlap=\"rectangular\"\n                                                key={`${i}_${a}`}\n                                                className={classes.indicatorsIcon}\n                                                icon={db.dataType.filter(c => c.name === a)[0].icon}\n                                                title={translate(`$__${a}`, 1)}\n                                                size=\"16px\"\n                                                count={indicators[a]}\n                                                disabled\n                                                onClick={props.onClickChildrens ? () => {\n                                                    props.onClickChildrens(a)\n                                                } : null}\n                                            />\n                                            : null\n                                    ))}\n                            </AvatarGroup>\n                        } */}\n                        <div>\n                            {props.searchText && data.description &&\n                                <div className={classes.description}>\n                                    {Highlighted(data.description, props.searchText)}\n                                </div>\n                            }\n\n                        </div>\n                    </React.Fragment>\n                    : expanded ? <React.Fragment>\n                        <FakeExpanded />\n                    </React.Fragment>\n                        : <React.Fragment></React.Fragment>\n                }\n                {!data.isTemplate ?\n                    <div\n                        style={{\n                            display: \"flex\",\n                            justifyContent: \"space-between\",\n                            alignItems: \"center\",\n                            width: \"100%\"\n                        }}\n                    >\n                        {\n                            (\n                                (\n                                    data.startDate\n                                    && moment(data.startDate).isValid()\n                                )\n                                ||\n                                (\n                                    data.endDate\n                                    && moment(data.endDate).isValid()\n                                )\n                            )\n                                ?\n                                <div style={{\n                                    position: 'relative',\n                                    display: 'flex',\n                                    width: '100%',\n                                    ...expanded ? { height: '45px' } : {}\n                                }}>\n                                    <div className={data.endDate && moment(new Date(data.endDate * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") < moment().format(\"YYYY-MM-DD\") ? classes.lateDates : classes.dates}>\n                                        {data.startDate && moment(data.startDate).isValid() &&\n                                            <div className={classes.dateInfo}>\n                                                <Badge\n                                                    overlap=\"rectangular\"\n                                                    className={classes.dateIco} icon=\"insert_invitation\" title={\"$__startDate\"} size=\"14px\" disabled />\n                                                {(new Date(data.startDate * 1000) instanceof Date && !isNaN(new Date(data.startDate * 1000))) ?\n                                                    moment(new Date(data.startDate * 1000)).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\n                                                    :\n                                                    moment(data.startDate).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\n                                                }\n                                            </div>\n                                        }\n                                        {data.endDate && moment(data.endDate).isValid() ?\n                                            <div className={classes.dateInfo}>\n                                                <Badge\n                                                    overlap=\"rectangular\"\n                                                    className={classes.dateIco} icon=\"event_available\" title={\"$__endDate\"} size=\"14px\" disabled />\n                                                {(new Date(data.endDate * 1000) instanceof Date && !isNaN(new Date(data.endDate * 1000))) ?\n                                                    moment(new Date(data.endDate * 1000)).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\n                                                    :\n                                                    moment(data.endDate).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")\n                                                }\n                                            </div>\n                                            : <React.Fragment></React.Fragment>\n                                        }\n                                    </div>\n                                </div>\n                                : <React.Fragment></React.Fragment>\n\n                        }\n\n                    </div>\n                    : <React.Fragment></React.Fragment>\n                }\n                {data._tags && data._tags.filter(a => a.value).length > 0 ?\n                    <div\n                        style={{\n                            marginBottom: 33\n                        }}\n                    >\n                        <CardTags options={data._tags}\n                            expanded={props.showTags || (\n                                expanded\n                                && data.type !== 'plan'\n                                && data.type !== 'link'\n                                && data.type !== 'insight'\n                            )\n                                ? true\n                                : false\n                            }\n                        />\n                    </div> : <React.Fragment></React.Fragment>\n                }\n                {\n                    data._recurrenceId &&\n                    <div\n                        style={{\n                            position: 'absolute',\n                            width: \"100%\",\n                            bottom: '3px',\n                            left: '3px',\n                            display: 'flex',\n                            fontSize: '11px',\n                            color: 'lightgrey',\n                            alignItems: 'center'\n                        }}\n                    >\n                        <Badge\n                            overlap=\"rectangular\"\n                            className={classes.indicatorsIcon}\n                            icon={'history'}\n                            color={'lightgrey'}\n                            size={\"25px\"}\n                            title={!props.noShowRecurrenceCard ? (\n                                <div style={{ maxWidth: \"280px\" }}>\n                                    {translate('$__recurrentActivityFrom')}:\n                                    <Card db=\"cards\" data={db.cards[data._recurrenceId]} Avatar ignoreList onlyOption />\n                                </div>\n                            ) : `${translate('$__recurrence')}${data.recurrenceCreatedDate ? `: ${moment(data.recurrenceCreatedDate).format(\"DD/MM/YYYY\")}` : ``}`}\n                        />\n                        {data.recurrenceCreatedDate ? moment(data.recurrenceCreatedDate).format(\"DD/MM/YYYY\") : ``}\n                    </div>\n\n                }\n                {data.name === \"A.1.1 Avulso\" ? console.log(Object.keys(data._users).filter(a => String(a) !== null).length, data) : console.log()}\n                {(\n                    data._users\n                    && Object.keys(data._users).filter(a => String(a) !== null).length > 0\n                    &&\n                    (\n                        !data._users[session._id]\n                        ||\n                        (\n                            data._users[session._id]\n                            && Object.keys(data._users).length > 1\n                        )\n                    )\n                )\n                    ?\n                    <React.Fragment>\n                        <div style={{\n                            width: \"100%\",\n                            marginTop: expanded ? 37 : 7\n                        }}>\n                            <div className={classes.usersContent}>\n                                <div className={classes.users}>\n                                    <QuickUsers_List _id={data._id} data={data} permission={permission} transparent myDay limit={3} />\n                                </div>\n                            </div>\n                        </div>\n                        <div style={{ clear: 'both' }}></div>\n                    </React.Fragment>\n                    : <React.Fragment></React.Fragment>\n                }\n            </React.Fragment>\n            {\n                data.isTemplate &&\n                <div style={{\n                    position: \"relative\",\n                    width: \"100%\",\n                    clear: \"both\",\n                    padding: \"7px\",\n                    backgroundColor: customApp(\"menu\"),\n                    marginTop: \"7px\",\n                    cursor: \"pointer\"\n                }}\n                    onClick={(e) => {\n                        e.stopPropagation()\n                        setUseTemplate(true)\n                    }}>\n                    <IconButton\n                        text={translate(\"$__useThisTemplate\", '*')}\n                        icon=\"auto_awesome\"\n                        iconColor={'#FFFFFF'}\n                        textColor={'#FFFFFF'}\n                    />\n                </div>\n            }\n\n            {\n                !showMoreButton && data.status === 'completed' &&\n                <div style={{\n                    backgroundColor: 'rgba(0,0,0,0.4)',\n                    position: 'absolute',\n                    height: '2px',\n                    left: 0,\n                    right: 0,\n                    top: '20px'\n                }}>\n                    <div\n                        style={{\n                            position: \"absolute\",\n                            right: 0,\n                            bottom: -12,\n                            color: \"#FFF\",\n                            fontSize: 10,\n                            padding: 3,\n                            backgroundColor: \"rgba(0,0,0,0.66)\",\n                        }}\n                    >\n                        {translate(\"$__completeDate\")}:\n                        {getDate(data.completed_at || data.updated_at)}\n                    </div>\n                </div>\n            }\n            {\n                (data.type !== 'plan' && data.deleted) ?\n                    <div style={{\n                        position: 'absolute',\n                        top: 0,\n                        left: 0,\n                        right: 0,\n                        bottom: 0,\n                        display: 'flex',\n                        alignItems: 'center',\n                        cursor: \"pointer\"\n                    }}>\n                        <div style={{\n                            position: 'absolute',\n                            backgroundColor: '#71389da6',\n                            top: 0,\n                            left: 0,\n                            right: 0,\n                            bottom: 0,\n                            paddingRight: 7,\n                            display: 'flex',\n                            alignItems: 'center',\n                            cursor: \"pointer\",\n                            justifyContent: \"right\"\n                        }}>\n                            <CustomButton\n                                title={translate(`$__restoreThis`, 1)}\n                                text={translate(`$__restoreThis`, 1)}\n                                color=\"#FFFFFF\"\n                                icon={\"restore_from_trash\"}\n                                onClick={() => {\n                                    restoreThis()\n                                }}\n                                size={\"17px\"}\n                                textSize={\"17px\"}\n                                transparent\n                            />\n                        </div>\n\n                    </div>\n                    : <React.Fragment></React.Fragment>\n            }\n            {locked ?\n                <div style={{\n                    position: \"absolute\",\n                    backgroundColor: \"rgba(233,233,233,0.88)\",\n                    top: 0,\n                    left: 0,\n                    right: 0,\n                    bottom: 0,\n                    display: \"flex\",\n                    alignItems: \"center\",\n                    justifyContent: \"center\"\n                }}>\n                    <div style={{\n                        display: \"flex\"\n                    }}>\n                        <Icon color=\"lightgray\" icon=\"lock\" size={\"22px\"} />\n                    </div>\n\n                </div>\n                :\n                <React.Fragment></React.Fragment>\n            }\n            {(duplicate || move) ?\n                <Modal\n                    open={true}\n                    onClose={() => {\n                        setDuplicate(false)\n                        setDuplicate(false)\n                    }\n                    }\n                    aria-labelledby=\"simple-modal-title\"\n                    aria-describedby=\"simple-modal-description\"\n                >\n                    <ClickAwayListener\n                        onClickAway={() => {\n                            setDuplicate(false)\n                        }}\n                    >\n                        <div\n                            style={{\n                                position: 'absolute',\n                                top: '0px',\n                                left: '0px',\n                                right: '0px',\n                                bottom: '0px',\n                                display: 'flex',\n                                justifyContent: \"center\",\n                                alignItems: \"center\"\n                            }}\n                            onClick={(e) => {\n                                e.preventDefault()\n                                e.stopPropagation()\n                            }}\n                        >\n\n                            <div style={{\n                                position: \"relative\",\n                                width: '400px',\n                                backgroundColor: '#FFFFFF',\n                                margin: 'auto',\n                                boxShadow: \"0px 0px 10px 3px rgba(0,0,0,0.2)\",\n                            }}>\n                                <div style={{\n                                    position: \"relative\",\n                                    width: '400px',\n                                    backgroundColor: '#FFFFFF',\n                                    padding: '9px',\n                                    height: \"40px\",\n                                    margin: 'auto',\n                                    background: customApp('ColumnTitleColor'),\n                                }}>\n                                    <div\n                                        style={{\n                                            fontSize: \"14px\",\n                                            color: customApp(\"color\")\n                                        }}\n                                    >{translate(\"$__duplicate\")}</div>\n                                    <div style={{\n                                        position: \"absolute\",\n                                        right: 5,\n                                        top: 5\n                                    }}>\n                                        <CustomButton\n                                            id={`close_duplicate`}\n                                            title={translate(`$__close`, \"*\")}\n                                            color={customApp(\"color\")}\n                                            icon={\"close\"}\n                                            onClick={() => {\n                                                setDuplicate(false)\n                                            }}\n                                            size={\"25px\"}\n                                            transparent\n                                        />\n                                    </div>\n                                </div>\n                                <div\n                                    style={{\n                                        position: \"relative\",\n                                        padding: '9px',\n                                    }}\n                                >\n                                    {selectTarget ?\n                                        <div\n                                            style={{\n                                                position: 'relative',\n                                                float: 'left',\n                                                width: \"370px\",\n                                                marginBottom: \"15px\"\n                                            }}\n                                        >\n                                            <Navigation\n                                                onSelect={(e) => {\n                                                    setCopyRel(e)\n                                                }}\n                                                ignoreTypes={['chatGroup']}\n                                            />\n                                        </div>\n                                        :\n                                        <div\n                                            style={{\n                                                width: \"100%\",\n                                                display: \"flex\",\n                                                justifyContent: \"flex-end\"\n                                            }}\n                                        >\n                                            <CustomButton\n                                                title={translate(`$__selectTarget`, 1)}\n                                                text={translate(`$__selectTarget`, 1)}\n                                                color={customApp(\"menu\")}\n                                                icon={\"assistant_navigation\"}\n                                                onClick={() => {\n                                                    setSelectTarget(true)\n                                                }}\n                                                size={\"14px\"}\n                                                textSize={\"14px\"}\n                                            />\n                                        </div>\n                                    }\n\n                                    <div\n                                        style={{\n                                            position: \"relative\",\n                                            width: \"100%\",\n                                            display: \"grid\"\n                                        }}\n                                    >\n                                        {!move ?\n                                            <React.Fragment>\n                                                {(\n                                                    copyRel\n                                                    && copyRel.type\n                                                    && planningTypes.indexOf(copyRel.type) > -1\n                                                    && (\n                                                        copyRel.type.indexOf(data.type) > -1\n                                                        ||\n                                                        data.type.indexOf(copyRel.type) > -1\n                                                    )\n                                                ) ?\n                                                    <div style={{\n                                                        color: \"red\",\n                                                        fontSize: 12,\n                                                        marginBottom: 15,\n                                                        textTransform: \"uppercase\",\n                                                        textAlign: \"center\"\n                                                    }}>\n                                                        {translate(`$__youAreDuplicating`)}: {translate(`$__${copyRel.type}`)} {translate(`$__for`)}: {translate(`$__${copyRel.type}`)}.\n                                                        {translate(`$__thisWillBeTurnedIntoAnActivity`)}\n                                                    </div>\n                                                    : <React.Fragment></React.Fragment>\n                                                }\n                                                <TextField\n                                                    label={translate(\"$__copyAs\", 1)}\n                                                    variant={customApp(\"fieldVariant\")}\n                                                    name={\"copyAs\"}\n                                                    InputLabelProps={{\n                                                        shrink: true,\n                                                    }}\n                                                    InputProps={{\n                                                        autoComplete: \"new-password\",\n                                                        endAdornment: (\n                                                            <InputAdornment position=\"end\">\n                                                                <Icon icon=\"clear\" onClick={() => {\n                                                                    setCopyName(data.name)\n                                                                }} />\n                                                            </InputAdornment>\n                                                        ),\n                                                        onChange: (d) => {\n                                                            setCopyName(d.target.value)\n                                                        },\n                                                    }}\n                                                    value={copyName}\n                                                    placeholder={translate(\"$__copyAs_placeholder\", 1)}\n                                                />\n                                            </React.Fragment>\n                                            : <React.Fragment>\n                                                {(\n                                                    copyRel\n                                                    && copyRel.type\n                                                    && planningTypes.indexOf(copyRel.type) > -1\n                                                    && (\n                                                        copyRel.type.indexOf(data.type) > -1\n                                                        ||\n                                                        data.type.indexOf(copyRel.type) > -1\n                                                    )\n                                                ) ?\n                                                    <div style={{\n                                                        color: \"red\",\n                                                        fontSize: 12,\n                                                        marginBottom: 15,\n                                                        textTransform: \"uppercase\",\n                                                        textAlign: \"center\"\n                                                    }}>\n                                                        {translate(`$__youAreMove`)}: {translate(`$__${copyRel.type}`)} {translate(`$__for`)}: {translate(`$__${copyRel.type}`)}.\n                                                        {translate(`$__thisWillBeTurnedIntoAnActivity`)}\n                                                    </div>\n                                                    : <React.Fragment></React.Fragment>\n                                                }\n\n                                            </React.Fragment>\n                                        }\n\n                                        {!duplicateLoader ?\n\n                                            <div\n                                                style={{\n                                                    display: \"flex\",\n                                                    justifyContent: \"space-between\",\n                                                    alignItems: \"center\",\n                                                    marginTop: 40\n                                                }}\n                                            >\n                                                <CustomButton\n                                                    title={translate(`$__cancel`, 1)}\n                                                    text={translate(`$__cancel`, 1)}\n                                                    color={\"lightgray\"}\n                                                    icon={\"cancel\"}\n                                                    onClick={() => {\n                                                        setDuplicate(false)\n                                                        setDuplicate(false)\n                                                    }}\n                                                    size={\"12px\"}\n                                                    textSize={\"12px\"}\n                                                />\n                                                {duplicate ?\n                                                    <CustomButton\n                                                        title={translate(`$__duplicateAllLinkedItems`, 1)}\n                                                        text={translate(`$__duplicateAllLinkedItems`, 1)}\n                                                        color={customApp(\"menu\")}\n                                                        icon={\"dynamic_feed\"}\n                                                        onClick={() => {\n                                                            duplicateCard(true)\n                                                        }}\n                                                        size={\"12px\"}\n                                                        textSize={\"12px\"}\n                                                        transparent\n                                                    />\n                                                    :\n                                                    <CustomButton\n                                                        title={translate(`$__confirmMoveCard`, 1)}\n                                                        text={translate(`$__confirmMoveCard`, 1)}\n                                                        color={customApp(\"menu\")}\n                                                        icon={\"dynamic_feed\"}\n                                                        onClick={() => {\n                                                            moveCard(true)\n                                                        }}\n                                                        size={\"12px\"}\n                                                        textSize={\"12px\"}\n                                                        transparent\n                                                    />\n                                                }\n                                            </div>\n                                            :\n                                            <div\n                                                style={{\n                                                    display: \"flex\",\n                                                    justifyContent: \"space-between\",\n                                                    alignItems: \"center\",\n                                                    marginTop: 40\n                                                }}\n                                            >\n                                                <ProgressLinear />\n                                            </div>\n                                        }\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </ClickAwayListener>\n                </Modal>\n                : <React.Fragment></React.Fragment>\n            }\n            <div style={{ clear: \"both\" }}></div>\n        </Container >\n    )\n}\n\nconst useStyles = makeStyles(styles)\n\nconst Container = styled.div`\n            minWidth:200px;\n            background-color:#fff;\n            marginBottom:7px;\n\n            ${props =>\n        props.separator ? `marging-top:30px;` : ``\n    }\n            ${props =>\n        props.selectable && props.selected ? `\n        opacity:1;`\n            : props.selectable ? `\n        opacity:0.5;`\n                : ``\n    }\n            ${props =>\n        props.locked ?\n            `cursor:no-drop !important;`\n            : `cursor:pointer;`\n    }\n            ${props =>\n        props.selected ?\n            `border-bottom:solid 5px ${customApp(\"color\")} !important;`\n            : ``\n    }\n            ${props =>\n        props.isDragDisable\n            ? \"\"\n            : props.isDragging\n                ? `opacity:0.88;\n                 max-width:320px;\n                 border:solid 10px red;`\n                : ``\n    }\n            ${props =>\n        props.inLine ?\n            `position:relative;\n            float:left;\n            margin:3.5px;\n            width:calc(20% - 7px);\n            // maxWidth:320px;\n            `\n            : `\n            width:calc(100%) !important;\n            margin:7px 0px 12px 0px;\n            `\n    }\n            width:calc(100%) !important;\n\n            ${props =>\n        props.priority ?\n            `border-left:5px solid ${props.priority} !important;`\n            : ``\n    }\n            ${props => props.isCombining ? `border:solid 3px ${customApp('menu')} !important;` : ``}\n            `\n\n\n//REACT\nconst mapStateToProps = (store) => ({\n    cardsExpanded: store.db.cardsExpanded,\n    showPrivate: store.controls.lockPrivate,\n    cards: store.db.cards,\n    unlockedPrivates: store.controls.unlockedPrivates,\n    controls: store.controls\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(Card)","import React from 'react';\nimport Badge from '@material-ui/core/Badge';\nimport { makeStyles, withStyles } from '@material-ui/core/styles';\n\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\nconst StyledBadge = withStyles((theme) => ({\n    badge: {\n        backgroundColor: '#44b700',\n        color: '#44b700',\n        boxShadow: `0 0 0 2px ${theme.palette.background.paper}`,\n        '&::after': {\n            position: 'absolute',\n            top: 0,\n            left: 0,\n            width: '100%',\n            height: '100%',\n            borderRadius: '50%',\n            animation: '$ripple 1.2s infinite ease-in-out',\n            border: '1px solid currentColor',\n            content: '\"\"',\n        },\n    },\n    '@keyframes ripple': {\n        '0%': {\n            transform: 'scale(.8)',\n            opacity: 1,\n        },\n        '100%': {\n            transform: 'scale(2.4)',\n            opacity: 0,\n        },\n    },\n}))(Badge);\n\nconst StyledBadgeAway = withStyles((theme) => ({\n    badge: {\n        backgroundColor: '#ffb100',\n        color: '#ffb100',\n        boxShadow: `0 0 0 2px ${theme.palette.background.paper}`,\n        '&::after': {\n            position: 'absolute',\n            top: 0,\n            left: 0,\n            width: '100%',\n            height: '100%',\n            borderRadius: '50%',\n            animation: '$ripple 1.2s infinite ease-in-out',\n            border: '1px solid currentColor',\n            content: '\"\"',\n        },\n    },\n    '@keyframes ripple': {\n        '0%': {\n            transform: 'scale(.8)',\n            opacity: 1,\n        },\n        '100%': {\n            transform: 'scale(2.4)',\n            opacity: 0,\n        },\n    },\n}))(Badge);\n\nconst useStyles = makeStyles((theme) => ({\n    root: {\n        display: 'flex',\n        '& > *': {\n            margin: theme.spacing(1),\n        },\n    },\n}));\n\nfunction BadgeAvatars(props) {\n    const classes = useStyles();\n    const [status, setStatus] = React.useState(props.status)\n    const [user, setUser] = React.useState(props.userId)\n\n    React.useEffect(() => {\n        if (props.status !== status)\n            setStatus(props.status)\n        return () => {\n\n        }\n    }, [props.status])\n\n    return (\n        <div className={classes.root}>\n            {(!props.status || props.status === 'online') ?\n                <StyledBadge\n                    overlap=\"circular\"\n                    anchorOrigin={props.anchorOrigin ? props.anchorOrigin : {\n                        vertical: 'bottom',\n                        horizontal: 'left',\n                    }}\n                    variant={props.status ? \"dot\" : \"standard\"}\n                >\n                    {props.children}\n                </StyledBadge>\n                :\n                <StyledBadgeAway\n                    overlap=\"circular\"\n                    anchorOrigin={props.anchorOrigin ? props.anchorOrigin : {\n                        vertical: 'bottom',\n                        horizontal: 'left',\n                    }}\n                    variant={props.status ? \"dot\" : \"standard\"}\n                >\n                    {props.children}\n                </StyledBadgeAway>\n            }\n        </div>\n    );\n}\n\nconst mapStateToProps = (store, props) => {\n    return ({\n        status: store.usersStatus && store.usersStatus.users && store.usersStatus.users[props.userId] && store.usersStatus.users[props.userId].status ? store.usersStatus.users[props.userId].status : null,\n    })\n}\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(BadgeAvatars)","import {\r\n  infoColor,\r\n  primaryColor,\r\n  successColor,\r\n  dangerColor,\r\n  warningColor,\r\n  whiteColor,\r\n  blackColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport { customApp } from \"functions/\";;\r\nconst timelineStyle = theme => ({\r\n  root: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    overflowY: 'auto'\r\n  },\r\n  content: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    overflowY: 'auto',\r\n    backgroundColor: 'rgba(249,249,249,1)'\r\n  },\r\n  timeline: {\r\n    listStyle: \"none\",\r\n    padding: \"0\",\r\n    position: \"absolute\",\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    display: 'flex',\r\n    width: '100%',\r\n    '& .file-drop-target': {\r\n      width: '100%'\r\n    }\r\n  },\r\n  scrollEnd: {\r\n    marginTop: '160px',\r\n    position: 'relative',\r\n    width: '100%',\r\n    height: '0px',\r\n    marginBottom: '-100px'\r\n  },\r\n  scrollEndNoEditor: {\r\n    marginTop: '30px',\r\n    position: 'relative',\r\n    width: '100%',\r\n    height: '0px',\r\n    marginBottom: '-100px'\r\n  },\r\n  timelineSimple: {\r\n    position: 'relative',\r\n    // overflowX: 'auto',\r\n    overflow: \"hidden\",\r\n    marginTop: \"0px\",\r\n    padding: \"0\",\r\n    width: '-webkit-fill-available',\r\n    \"&:before\": {\r\n      left: \"15px\"\r\n    },\r\n  },\r\n  timelineSimpleWithHeader: {\r\n    position: 'relative',\r\n    overflowX: 'auto',\r\n    marginTop: \"60px\",\r\n    padding: \"0 0 0\",\r\n    width: '-webkit-fill-available',\r\n    \"&:before\": {\r\n      left: \"15px\"\r\n    },\r\n  },\r\n  item: {\r\n    marginBottom: \"15px\",\r\n    paddingBottom: \"33px\",\r\n    position: \"relative\",\r\n    paddingLeft: \"15px\",\r\n    width: 'calc(100% - 15px)',\r\n    \"&:before,&:after\": {\r\n      content: '\" \"',\r\n      display: \"table\"\r\n    },\r\n    \"&:after\": {\r\n      clear: \"both\"\r\n    }\r\n  },\r\n  timelineBadge: {\r\n    color: whiteColor,\r\n    width: \"30px\",\r\n    height: \"30px\",\r\n    lineHeight: \"25px\",\r\n    fontSize: \"12px\",\r\n    textAlign: \"center\",\r\n    position: \"absolute\",\r\n    bottom: \"23px\",\r\n    left: \"50%\",\r\n    marginLeft: \"-7px\",\r\n    zIndex: \"1\",\r\n    borderTopRightRadius: \"50%\",\r\n    borderTopLeftRadius: \"50%\",\r\n    borderBottomRightRadius: \"50%\",\r\n    borderBottomLeftRadius: \"50%\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\"\r\n\r\n  },\r\n  timelineSimpleBadge: {\r\n    left: \"7px\"\r\n  },\r\n  timelineBadgeInverted: {\r\n    color: whiteColor,\r\n    width: \"30px\",\r\n    height: \"30px\",\r\n    lineHeight: \"25px\",\r\n    fontSize: \"12px\",\r\n    textAlign: \"center\",\r\n    position: \"absolute\",\r\n    bottom: \"23px\",\r\n    right: \"50%\",\r\n    marginRight: \"-7px\",\r\n    zIndex: \"1\",\r\n    borderTopRightRadius: \"50%\",\r\n    borderTopLeftRadius: \"50%\",\r\n    borderBottomRightRadius: \"50%\",\r\n    borderBottomLeftRadius: \"50%\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\"\r\n\r\n  },\r\n  timelineSimpleBadgeInverted: {\r\n    right: \"7px\"\r\n  },\r\n  custom: {\r\n    backgroundColor: customApp('color'),\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.4)\"\r\n  },\r\n  info: {\r\n    backgroundColor: infoColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(infoColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  success: {\r\n    backgroundColor: successColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(successColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  danger: {\r\n    backgroundColor: dangerColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(dangerColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  warning: {\r\n    backgroundColor: warningColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(warningColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  primary: {\r\n    backgroundColor: primaryColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(primaryColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  badgeIcon: {\r\n    width: \"14px\",\r\n    height: \"14px\"\r\n  },\r\n  timelinePanel: {\r\n    maxWidth: \"calc(100% - 70px)\",\r\n    float: \"right\",\r\n    padding: \"7px\",\r\n    marginBottom: \"5px\",\r\n    marginRight: \"40px\",\r\n    position: \"relative\",\r\n    boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n    borderRadius: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n    background: customApp('timelineMyMessage'),\r\n  },\r\n  timelinePanelInverted: {\r\n    maxWidth: \"calc(100% - 70px)\",\r\n    float: \"left\",\r\n    padding: \"7px\",\r\n    marginLeft: \"40px\",\r\n    marginBottom: \"5px\",\r\n    position: \"relative\",\r\n    boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n    borderRadius: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n    background: '#ffffff',\r\n  },\r\n\r\n\r\n  timelineHeading: {\r\n    marginBottom: \"0px\",\r\n    display: \"flex\",\r\n    alignItems: \"center\"\r\n  },\r\n  timelineDate: {\r\n    display: 'flex',\r\n    alignItems: \"center\",\r\n    padding: '5px',\r\n    backgroundColor: '#CCCCCC'\r\n  },\r\n  timelineBody: {\r\n    overflowWrap: \"anywhere\",\r\n    fontSize: \"12px\",\r\n    lineHeight: \"21px\",\r\n    position: 'relative',\r\n    width: '100%',\r\n    float: 'left',\r\n  },\r\n  timelineLog: {\r\n    fontSize: \"12px\",\r\n    lineHeight: \"21px\",\r\n    // display: 'flex',\r\n  },\r\n  timelineFooter: {\r\n    zIndex: \"1\",\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    width: '100%',\r\n    display: \"inline-flex\",\r\n    justifyContent: \"space-between\"\r\n  },\r\n  footerUser: {\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    fontSize: '12px',\r\n    fontWeight: 'bold',\r\n    color: customApp('medium'),\r\n    padding: '0 7px',\r\n  },\r\n  footerLine: {\r\n    position: 'relative',\r\n    marginTop: \"10px\",\r\n    marginBottom: \"5px\"\r\n  },\r\n  dropFile: {\r\n    display: 'none',\r\n  },\r\n  onDropFile: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    justifyContent: 'center',\r\n    color: '#FFFFFF',\r\n    backgroundColor: 'rgba(0,0,0,0.77)',\r\n    zIndex: 1,\r\n  },\r\n  editor: {\r\n    position: 'absolute',\r\n    bottom: '0px',\r\n    padding: '10px',\r\n    height: 'auto',\r\n    width: 'calc(100% - 0px)',\r\n    zIndex: 10,\r\n    padding: '7px',\r\n  },\r\n  files: {\r\n    display: 'inline-table',\r\n    position: 'relative'\r\n  },\r\n  textEditorIcon: {\r\n    cursor: 'pointer',\r\n    color: customApp('color'),\r\n  },\r\n  progressBar: {\r\n    backgroundColor: `${customApp('color', '0.1')} !important`,\r\n    '& .MuiLinearProgress-indeterminate': {\r\n      backgroundColor: `${customApp('color')} !important`\r\n    },\r\n    '& .MuiLinearProgress-bar': {\r\n      backgroundColor: `${customApp('color')} !important`\r\n    },\r\n  },\r\n  actionButton: {\r\n    alignItems: 'center',\r\n    cursor: 'pointer',\r\n    float: 'left',\r\n    height: '30px',\r\n    position: 'relative',\r\n    textAlign: 'center',\r\n    width: '30px',\r\n  },\r\n  sendingMessage: {\r\n    width: '100%'\r\n  },\r\n  valuePositive: {\r\n    positive: 'relative',\r\n    float: 'left',\r\n    color: 'blue',\r\n  },\r\n  valueNegative: {\r\n    positive: 'relative',\r\n    float: 'left',\r\n    color: 'red',\r\n  },\r\n  lastValue: {\r\n    positive: 'relative',\r\n    float: 'right',\r\n    color: 'grey',\r\n  },\r\n  timeInfo: {\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    color: 'grey',\r\n    width: '100%',\r\n    position: 'relative',\r\n    float: 'left',\r\n    marginBottom: '7px',\r\n    '& .text': {\r\n      marginLeft: '7px',\r\n    }\r\n  },\r\n  urlPreview: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    marginBottom: '33px',\r\n    '& img': {\r\n      maxWidth: '20%',\r\n      minWidth: '177px',\r\n      height: 'auto',\r\n      marginTop: '30px',\r\n      marginRight: '7px'\r\n    },\r\n    '& .data': {\r\n      '& .title': {\r\n        fontSize: '16px',\r\n        fontWeight: 'bold',\r\n      },\r\n      '& .siteName': {\r\n        fontSize: '14px',\r\n        fontWeight: 'bold',\r\n        color: '#909090'\r\n      },\r\n      '& .contentSnippet': {\r\n        fontSize: '12px',\r\n        color: '#909090'\r\n      }\r\n    }\r\n  },\r\n  users: {\r\n    position: 'relative',\r\n    bottom: '0px',\r\n    right: '2px',\r\n    fontSize: '10px',\r\n    '& .MuiAvatarGroup-root': {\r\n      justifyContent: 'flex-end',\r\n    },\r\n    '& .MuiAvatar-root': {\r\n      width: '25px',\r\n      height: '25px',\r\n      fontSize: '10px',\r\n    }\r\n  }\r\n});\r\n\r\nexport default timelineStyle;\r\n","import {\r\n  defaultFont,\r\n  primaryColor,\r\n  primaryBoxShadow,\r\n  infoColor,\r\n  infoBoxShadow,\r\n  successColor,\r\n  successBoxShadow,\r\n  warningColor,\r\n  warningBoxShadow,\r\n  dangerColor,\r\n  dangerBoxShadow,\r\n  roseColor,\r\n  roseBoxShadow,\r\n  whiteColor,\r\n  blackColor,\r\n  grayColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst customDropdownStyle = theme => ({\r\n  popperClose: {\r\n    pointerEvents: \"none\",\r\n    display: \"none !important\"\r\n  },\r\n  popperNav: {\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      position: \"static !important\",\r\n      left: \"unset !important\",\r\n      top: \"unset !important\",\r\n      transform: \"none !important\",\r\n      willChange: \"unset !important\",\r\n      \"& > div\": {\r\n        boxShadow: \"none !important\",\r\n        marginLeft: \"0rem\",\r\n        marginRight: \"0rem\",\r\n        transition: \"none !important\",\r\n        marginTop: \"0px !important\",\r\n        marginBottom: \"0px !important\",\r\n        padding: \"0px !important\",\r\n        backgroundColor: \"transparent !important\",\r\n        \"& ul li\": {\r\n          color: whiteColor + \" !important\",\r\n          margin: \"10px 15px 0!important\",\r\n          padding: \"10px 15px !important\",\r\n          \"&:hover\": {\r\n            backgroundColor: \"hsla(0,0%,78%,.2)\",\r\n            boxShadow: \"none\"\r\n          }\r\n        }\r\n      }\r\n    }\r\n  },\r\n  manager: {\r\n    \"& > div > button:first-child > span:first-child, & > div > a:first-child > span:first-child\": {\r\n      width: \"100%\"\r\n    }\r\n  },\r\n  innerManager: {\r\n    \"& > div > button,& > div > a\": {\r\n      margin: \"0px !important\",\r\n      color: \"inherit !important\",\r\n      padding: \"10px 20px !important\",\r\n      \"& > span:first-child\": {\r\n        width: \"100%\",\r\n        justifyContent: \"flex-start\"\r\n      }\r\n    }\r\n  },\r\n  target: {\r\n    \"& > button:first-child > span:first-child, & > a:first-child > span:first-child\": {\r\n      display: \"inline-block\"\r\n    },\r\n    \"& $caret\": {\r\n      marginLeft: \"0px\"\r\n    }\r\n  },\r\n  dropdown: {\r\n    borderRadius: \"3px\",\r\n    border: \"0\",\r\n    boxShadow: \"0 2px 5px 0 rgba(\" + hexToRgb(blackColor) + \", 0.26)\",\r\n    top: \"100%\",\r\n    zIndex: \"1000\",\r\n    minWidth: \"160px\",\r\n    padding: \"5px 0\",\r\n    margin: \"2px 0 0\",\r\n    fontSize: \"12px\",\r\n    textAlign: \"left\",\r\n    listStyle: \"none\",\r\n    backgroundColor: whiteColor,\r\n    backgroundClip: \"padding-box\"\r\n  },\r\n  menuList: {\r\n    padding: \"0\"\r\n  },\r\n  popperResponsive: {\r\n    zIndex: \"1200\",\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      zIndex: \"1640\",\r\n      position: \"static\",\r\n      float: \"none\",\r\n      width: \"auto\",\r\n      marginTop: \"0\",\r\n      backgroundColor: \"transparent\",\r\n      border: \"0\",\r\n      boxShadow: \"none\",\r\n      color: \"black\"\r\n    }\r\n  },\r\n  dropdownItem: {\r\n    ...defaultFont,\r\n    fontSize: \"13px\",\r\n    padding: \"10px 20px\",\r\n    margin: \"0 5px\",\r\n    borderRadius: \"2px\",\r\n    position: \"relative\",\r\n    transition: \"all 150ms linear\",\r\n    display: \"block\",\r\n    clear: \"both\",\r\n    fontWeight: \"400\",\r\n    height: \"100%\",\r\n    color: grayColor[7],\r\n    whiteSpace: \"nowrap\",\r\n    minHeight: \"unset\"\r\n  },\r\n  darkHover: {\r\n    \"&:hover\": {\r\n      boxShadow:\r\n        \"0 4px 20px 0px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.14), 0 7px 10px -5px rgba(\" +\r\n        hexToRgb(grayColor[16]) +\r\n        \", 0.4)\",\r\n      backgroundColor: grayColor[16],\r\n      color: whiteColor\r\n    }\r\n  },\r\n  primaryHover: {\r\n    \"&:hover\": {\r\n      backgroundColor: primaryColor[0],\r\n      color: whiteColor,\r\n      ...primaryBoxShadow\r\n    }\r\n  },\r\n  infoHover: {\r\n    \"&:hover\": {\r\n      backgroundColor: infoColor[0],\r\n      color: whiteColor,\r\n      ...infoBoxShadow\r\n    }\r\n  },\r\n  successHover: {\r\n    \"&:hover\": {\r\n      backgroundColor: successColor[0],\r\n      color: whiteColor,\r\n      ...successBoxShadow\r\n    }\r\n  },\r\n  warningHover: {\r\n    \"&:hover\": {\r\n      backgroundColor: warningColor[0],\r\n      color: whiteColor,\r\n      ...warningBoxShadow\r\n    }\r\n  },\r\n  dangerHover: {\r\n    \"&:hover\": {\r\n      backgroundColor: dangerColor[0],\r\n      color: whiteColor,\r\n      ...dangerBoxShadow\r\n    }\r\n  },\r\n  roseHover: {\r\n    \"&:hover\": {\r\n      backgroundColor: roseColor[0],\r\n      color: whiteColor,\r\n      ...roseBoxShadow\r\n    }\r\n  },\r\n  dropdownItemRTL: {\r\n    textAlign: \"right\"\r\n  },\r\n  dropdownDividerItem: {\r\n    margin: \"5px 0\",\r\n    backgroundColor: \"rgba(\" + hexToRgb(blackColor) + \", 0.12)\",\r\n    height: \"1px\",\r\n    overflow: \"hidden\"\r\n  },\r\n  buttonIcon: {\r\n    width: \"20px\",\r\n    height: \"20px\"\r\n  },\r\n  caret: {\r\n    transition: \"all 150ms ease-in\",\r\n    display: \"inline-block\",\r\n    width: \"0\",\r\n    height: \"0\",\r\n    marginLeft: \"4px\",\r\n    verticalAlign: \"middle\",\r\n    borderTop: \"4px solid\",\r\n    borderRight: \"4px solid transparent\",\r\n    borderLeft: \"4px solid transparent\"\r\n  },\r\n  caretActive: {\r\n    transform: \"rotate(180deg)\"\r\n  },\r\n  caretDropup: {\r\n    transform: \"rotate(180deg)\"\r\n  },\r\n  caretRTL: {\r\n    marginRight: \"4px\"\r\n  },\r\n  dropdownHeader: {\r\n    display: \"block\",\r\n    padding: \"0.1875rem 1.25rem\",\r\n    fontSize: \"0.75rem\",\r\n    lineHeight: \"1.428571\",\r\n    color: grayColor[1],\r\n    whiteSpace: \"nowrap\",\r\n    fontWeight: \"inherit\",\r\n    marginTop: \"10px\",\r\n    minHeight: \"unset\",\r\n    \"&:hover,&:focus\": {\r\n      backgroundColor: \"transparent\",\r\n      cursor: \"auto\"\r\n    }\r\n  },\r\n  noLiPadding: {\r\n    padding: \"0\"\r\n  }\r\n});\r\n\r\nexport default customDropdownStyle;\r\n","import React from \"react\";\nimport classNames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport MenuItem from \"@material-ui/core/MenuItem\";\nimport MenuList from \"@material-ui/core/MenuList\";\nimport ClickAwayListener from \"@material-ui/core/ClickAwayListener\";\nimport Paper from \"@material-ui/core/Paper\";\nimport Grow from \"@material-ui/core/Grow\";\nimport Divider from \"@material-ui/core/Divider\";\nimport Popper from \"@material-ui/core/Popper\";\n\n//COMPONENTS\nimport Button from \"components/CustomButtons/Button.js\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/customDropdownStyle.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function CustomDropdown(props) {\n  const [anchorEl, setAnchorEl] = React.useState(null);\n  const classes = useStyles();\n  const handleClick = event => {\n    if (anchorEl && anchorEl.contains(event.target)) {\n      setAnchorEl(null);\n    } else {\n      setAnchorEl(event.currentTarget);\n    }\n  };\n  const handleClose = event => {\n    if (anchorEl.contains(event.target)) {\n      return;\n    }\n    setAnchorEl(null);\n  };\n  const handleCloseMenu = param => {\n    setAnchorEl(null);\n    if (props && props.onClick) {\n      props.onClick(param);\n    }\n  };\n  const {\n    buttonText,\n    buttonIcon,\n    dropdownList,\n    buttonProps,\n    dropup,\n    dropdownHeader,\n    caret,\n    hoverColor,\n    dropPlacement,\n    rtlActive,\n    noLiPadding,\n    innerDropDown,\n    navDropdown\n  } = props;\n  const caretClasses = classNames({\n    [classes.caret]: true,\n    [classes.caretDropup]: dropup && !anchorEl,\n    [classes.caretActive]: Boolean(anchorEl) && !dropup,\n    [classes.caretRTL]: rtlActive\n  });\n  const dropdownItem = classNames({\n    [classes.dropdownItem]: true,\n    [classes[hoverColor + \"Hover\"]]: true,\n    [classes.noLiPadding]: noLiPadding,\n    [classes.dropdownItemRTL]: rtlActive\n  });\n  const dropDownMenu = (\n    <MenuList role=\"menu\" className={classes.menuList}>\n      {dropdownHeader !== undefined ? (\n        <MenuItem\n          onClick={() => handleCloseMenu(dropdownHeader)}\n          className={classes.dropdownHeader}\n        >\n          {dropdownHeader}\n        </MenuItem>\n      ) : null}\n      {dropdownList.map((prop, key) => {\n        if (prop.divider) {\n          return (\n            <Divider\n              key={key}\n              onClick={() => handleCloseMenu(\"divider\")}\n              className={classes.dropdownDividerItem}\n            />\n          );\n        } else if (\n          prop.props !== undefined &&\n          prop.props[\"data-ref\"] === \"multi\"\n        ) {\n          return (\n            <MenuItem\n              key={key}\n              className={dropdownItem}\n              style={{ overflow: \"visible\", padding: 0 }}\n            >\n              {prop}\n            </MenuItem>\n          );\n        }\n        return (\n          <MenuItem\n            key={key}\n            onClick={() => handleCloseMenu(prop)}\n            className={dropdownItem}\n          >\n            {prop}\n          </MenuItem>\n        );\n      })}\n    </MenuList>\n  );\n  return (\n    <div className={innerDropDown ? classes.innerManager : classes.manager}>\n      <div className={buttonText !== undefined ? \"\" : classes.target}>\n        <Button\n          aria-label=\"Notifications\"\n          aria-owns={anchorEl ? \"menu-list\" : null}\n          aria-haspopup=\"true\"\n          {...buttonProps}\n          onClick={handleClick}\n        >\n          {buttonIcon !== undefined ? (\n            <props.buttonIcon className={classes.buttonIcon} />\n          ) : null}\n          {buttonText !== undefined ? buttonText : null}\n          {caret ? <b className={caretClasses} /> : null}\n        </Button>\n      </div>\n      <Popper\n        open={Boolean(anchorEl)}\n        anchorEl={anchorEl}\n        transition\n        disablePortal\n        placement={dropPlacement}\n        className={classNames({\n          [classes.popperClose]: !anchorEl,\n          [classes.popperResponsive]: true,\n          [classes.popperNav]: Boolean(anchorEl) && navDropdown\n        })}\n      >\n        {() => (\n          <Grow\n            in={Boolean(anchorEl)}\n            id=\"menu-list\"\n            style={\n              dropup\n                ? { transformOrigin: \"0 100% 0\" }\n                : { transformOrigin: \"0 0 0\" }\n            }\n          >\n            <Paper className={classes.dropdown}>\n              {innerDropDown ? (\n                dropDownMenu\n              ) : (\n                  <ClickAwayListener onClickAway={handleClose}>\n                    {dropDownMenu}\n                  </ClickAwayListener>\n                )}\n            </Paper>\n          </Grow>\n        )}\n      </Popper>\n    </div>\n  );\n}\n\nCustomDropdown.defaultProps = {\n  caret: true,\n  dropup: false,\n  hoverColor: \"primary\"\n};\n\nCustomDropdown.propTypes = {\n  hoverColor: PropTypes.oneOf([\n    \"dark\",\n    \"primary\",\n    \"info\",\n    \"success\",\n    \"warning\",\n    \"danger\",\n    \"rose\"\n  ]),\n  buttonText: PropTypes.node,\n  buttonIcon: PropTypes.object,\n  dropdownList: PropTypes.array,\n  buttonProps: PropTypes.object,\n  dropup: PropTypes.bool,\n  dropdownHeader: PropTypes.node,\n  rtlActive: PropTypes.bool,\n  caret: PropTypes.bool,\n  dropPlacement: PropTypes.oneOf([\n    \"bottom\",\n    \"top\",\n    \"right\",\n    \"left\",\n    \"bottom-start\",\n    \"bottom-end\",\n    \"top-start\",\n    \"top-end\",\n    \"right-start\",\n    \"right-end\",\n    \"left-start\",\n    \"left-end\"\n  ]),\n  noLiPadding: PropTypes.bool,\n  innerDropDown: PropTypes.bool,\n  navDropdown: PropTypes.bool,\n  onClick: PropTypes.func\n};\n","import React from \"react\";\n\n// @material-ui/icons\nimport CardTravel from \"@material-ui/icons/CardTravel\";\nimport Extension from \"@material-ui/icons/Extension\";\nimport Fingerprint from \"@material-ui/icons/Fingerprint\";\nimport FlightLand from \"@material-ui/icons/FlightLand\";\nimport Build from \"@material-ui/icons/Build\";\n\n// core components\nimport CustomDropdown from \"components/CustomDropdown/CustomDropdown.js\";\n\n// ##############################\n// // // stories for RTLSupport view\n// #############################\n\nconst rtlStories = [\n  {\n    // First story\n    inverted: true,\n    badgeColor: \"danger\",\n    badgeIcon: CardTravel,\n    title: \"جهة أي\",\n    titleColor: \"danger\",\n    body: (\n      <p>\n        قام كل ماذا العصبة اوروبا. أي جورج العالمي أخر, كان تم أطراف القوى\n        استبدال. أسر ميناء تكتيكاً الجديدة، كل. جُل اللا التكاليف بـ, عرفها\n        النزاع لليابان بـ أضف. انتهت المدن الثالث من وقد.وقبل قادة إحتار عن أخر.\n        حين ونتج أخرى قد. بالعمل بالمطالبة فقد قد. عن جنوب ومضى الشتاء.\n      </p>\n    ),\n    footerTitle: \"مدن أن هُزم سكان, مكن.\"\n  },\n  {\n    // Second story\n    inverted: true,\n    badgeColor: \"success\",\n    badgeIcon: Extension,\n    title: \"جُل حكومة\",\n    titleColor: \"success\",\n    body: (\n      <p>\n        عل فكانت الثقيلة بلا. شيء بخطوط بالرّغم التبرعات عن, يطول بأيدي لم كلّ.\n        معقل الغالي واتّجه لم وتم, أن الصفحة بالمحور حول, بال مرمى الصفحات\n        قُدُماً و. الأخذ سبتمبر العالم من ذلك. ان يبق شدّت الأبرياء, الى الربيع،\n        والمانيا كل. ودول الأهداف التقليدي عل أضف, كلا يقوم الأخذ الآلاف بل.\n      </p>\n    )\n  },\n  {\n    // Third story\n    inverted: true,\n    badgeColor: \"info\",\n    badgeIcon: Fingerprint,\n    title: \"هذا غينيا\",\n    titleColor: \"info\",\n    body: (\n      <p>\n        جهة المارق والديون التقليدية في, هو وترك المجتمع بريطانيا ذلك, لمّ ما\n        العالم، اليابان،. ٣٠ فقامت أوروبا مشاركة بعد, ٢٠٠٤ الجو مساعدة ما حدى.\n        في عليها وبحلول معارضة بعض. عن الأرض وبداية العمليات ولم. الجو جديداً\n        الأوروبيّون أم به،. ثم التي نتيجة الآلاف جعل, عن المارق السادس قام. ما\n        أخر فقامت الأجل الشرق،, فصل كل وسوء الأرواح. ثم بعد وشعار بأيدي. قبل\n        وكسبت الغالي الولايات بل, ٣٠ أمّا أخرى لأداء أضف. هو منتصف معزّزة على.\n        بـ أفريقيا التغييرات مما, أثره،.\n      </p>\n    ),\n    footer: (\n      <CustomDropdown\n        rtlActive\n        buttonIcon={Build}\n        buttonProps={{\n          round: true,\n          style: { marginBottom: \"0\" },\n          color: \"info\"\n        }}\n        dropdownList={[\n          \"ان\",\n          \"إجلاء لفرنسا\",\n          \"أواخر الأرض بل\",\n          { divider: true },\n          \"عل اليها\"\n        ]}\n      />\n    )\n  }\n];\n\n// ##############################\n// // // stories for Widgets view\n// #############################\n\nconst widgetStories = [\n  {\n    // First story\n    inverted: true,\n    badgeColor: \"danger\",\n    badgeIcon: CardTravel,\n    title: \"Some Title\",\n    titleColor: \"danger\",\n    body: (\n      <p>\n        Wifey made the best Father{\"'\"}s Day meal ever. So thankful so happy so\n        blessed. Thank you for making my family We just had fun with the\n        “future” theme !!! It was a fun night all together ... The always rude\n        Kanye Show at 2am Sold Out Famous viewing @ Figueroa and 12th in\n        downtown.\n      </p>\n    ),\n    footerTitle: \"11 hours ago via Twitter\"\n  },\n  {\n    // Second story\n    inverted: true,\n    badgeColor: \"success\",\n    badgeIcon: Extension,\n    title: \"Another One\",\n    titleColor: \"success\",\n    body: (\n      <p>\n        Thank God for the support of my wife and real friends. I also wanted to\n        point out that it’s the first album to go number 1 off of streaming!!! I\n        love you Ellen and also my number one design rule of anything I do from\n        shoes to music to homes is that Kim has to like it....\n      </p>\n    )\n  },\n  {\n    // Third story\n    inverted: true,\n    badgeColor: \"info\",\n    badgeIcon: Fingerprint,\n    title: \"Another Title\",\n    titleColor: \"info\",\n    body: (\n      <div>\n        <p>\n          Called I Miss the Old Kanye That’s all it was Kanye And I love you\n          like Kanye loves Kanye Famous viewing @ Figueroa and 12th in downtown\n          LA 11:10PM\n        </p>\n        <p>\n          What if Kanye made a song about Kanye Royère doesn{\"'\"}t make a Polar\n          bear bed but the Polar bear couch is my favorite piece of furniture we\n          own It wasn’t any Kanyes Set on his goals Kanye\n        </p>\n      </div>\n    ),\n    footer: (\n      <CustomDropdown\n        buttonIcon={Build}\n        buttonProps={{\n          round: true,\n          style: { marginBottom: \"0\" },\n          color: \"info\"\n        }}\n        dropdownList={[\n          \"Action\",\n          \"Another action\",\n          \"Something else here\",\n          { divider: true },\n          \"Separated link\"\n        ]}\n      />\n    )\n  }\n];\n\n// ##############################\n// // // stories for Timeline view\n// #############################\n\nconst stories = [\n  {\n    // First story\n    inverted: true,\n    badgeColor: \"danger\",\n    badgeIcon: CardTravel,\n    title: \"Some Title\",\n    titleColor: \"danger\",\n    body: (\n      <p>\n        Wifey made the best Father{\"'\"}s Day meal ever. So thankful so happy so\n        blessed. Thank you for making my family We just had fun with the\n        “future” theme !!! It was a fun night all together ... The always rude\n        Kanye Show at 2am Sold Out Famous viewing @ Figueroa and 12th in\n        downtown.\n      </p>\n    ),\n    footerTitle: \"11 hours ago via Twitter\"\n  },\n  {\n    // Second story\n    badgeColor: \"success\",\n    badgeIcon: Extension,\n    title: \"Another One\",\n    titleColor: \"success\",\n    body: (\n      <p>\n        Thank God for the support of my wife and real friends. I also wanted to\n        point out that it’s the first album to go number 1 off of streaming!!! I\n        love you Ellen and also my number one design rule of anything I do from\n        shoes to music to homes is that Kim has to like it....\n      </p>\n    )\n  },\n  {\n    // Third story\n    inverted: true,\n    badgeColor: \"info\",\n    badgeIcon: Fingerprint,\n    title: \"Another Title\",\n    titleColor: \"info\",\n    body: (\n      <div>\n        <p>\n          Called I Miss the Old Kanye That’s all it was Kanye And I love you\n          like Kanye loves Kanye Famous viewing @ Figueroa and 12th in downtown\n          LA 11:10PM\n        </p>\n        <p>\n          What if Kanye made a song about Kanye Royère doesn{\"'\"}t make a Polar\n          bear bed but the Polar bear couch is my favorite piece of furniture we\n          own It wasn’t any Kanyes Set on his goals Kanye\n        </p>\n      </div>\n    ),\n    footer: (\n      <CustomDropdown\n        buttonIcon={Build}\n        buttonProps={{\n          round: true,\n          style: { marginBottom: \"0\" },\n          color: \"info\"\n        }}\n        dropdownList={[\n          \"Action\",\n          \"Another action\",\n          \"Something else here\",\n          { divider: true },\n          \"Separated link\"\n        ]}\n      />\n    )\n  },\n  {\n    // Fourth story\n    badgeColor: \"warning\",\n    badgeIcon: FlightLand,\n    title: \"Another One\",\n    titleColor: \"warning\",\n    body: (\n      <p>\n        Tune into Big Boy{\"'\"}s 92.3 I{\"'\"}m about to play the first single from\n        Cruel Winter also to Kim’s hair and makeup Lorraine jewelry and the\n        whole style squad at Balmain and the Yeezy team. Thank you Anna for the\n        invite thank you to the whole Vogue team\n      </p>\n    )\n  }\n];\n\n// ##############################\n// // // data for populating the calendar in Calendar view\n// #############################\n\nvar today = new Date();\nvar y = today.getFullYear();\nvar m = today.getMonth();\nvar d = today.getDate();\n\nconst events = [\n  {\n    title: \"All Day Event\",\n    allDay: true,\n    start: new Date(y, m, 1),\n    end: new Date(y, m, 1),\n    color: \"default\"\n  },\n  {\n    title: \"Meeting\",\n    start: new Date(y, m, d - 1, 10, 30),\n    end: new Date(y, m, d - 1, 11, 30),\n    allDay: false,\n    color: \"green\"\n  },\n  {\n    title: \"Lunch\",\n    start: new Date(y, m, d + 7, 12, 0),\n    end: new Date(y, m, d + 7, 14, 0),\n    allDay: false,\n    color: \"red\"\n  },\n  {\n    title: \"Nud-pro Launch\",\n    start: new Date(y, m, d - 2),\n    end: new Date(y, m, d - 2),\n    allDay: true,\n    color: \"azure\"\n  },\n  {\n    title: \"Birthday Party\",\n    start: new Date(y, m, d + 1, 19, 0),\n    end: new Date(y, m, d + 1, 22, 30),\n    allDay: false,\n    color: \"azure\"\n  },\n  {\n    title: \"Click for Creative Tim\",\n    start: new Date(y, m, 21),\n    end: new Date(y, m, 22),\n    color: \"orange\"\n  },\n  {\n    title: \"Click for Google\",\n    start: new Date(y, m, 21),\n    end: new Date(y, m, 22),\n    color: \"rose\"\n  }\n];\n\n// ##############################\n// // // Tasks for TasksCard - see Widget view\n// #############################\n\nvar bugs = [\n  'Sign contract for \"What are conference organizers afraid of?\"',\n  \"Lines From Great Russian Literature? Or E-mails From My Boss?\",\n  \"Flooded: One year later, assessing what was lost and what was found when a ravaging rain swept through metro Detroit\",\n  \"Create 4 Invisible User Experiences you Never Knew About\"\n];\nvar website = [\n  \"Flooded: One year later, assessing what was lost and what was found when a ravaging rain swept through metro Detroit\",\n  'Sign contract for \"What are conference organizers afraid of?\"'\n];\nvar server = [\n  \"Lines From Great Russian Literature? Or E-mails From My Boss?\",\n  \"Flooded: One year later, assessing what was lost and what was found when a ravaging rain swept through metro Detroit\",\n  'Sign contract for \"What are conference organizers afraid of?\"'\n];\n\n// ##############################\n// // // Tasks for TasksCard - see RTLSupport view\n// #############################\n\nvar rtlBugs = [\n  \"فقد لمحاكم الاندونيسية, بلاده بالتوقيع تم يبق. جعل السبب وفرنسا الصينية أي.\",\n  \"بحث. كل مما ٢٠٠٤ شاسعة العسكري جعل السبب وفرنسا الصينية أي.\",\n  \"تسبب أفريقيا ضرب عن, عن إنطلاق جعل السبب وفرنسا الصينية أي.\",\n  \"قدما مليون بين عن, مرجع منتصف الأمريكية جعل السبب وفرنسا الصينية أي.\"\n];\nvar rtlWebsite = [\n  \"قدما مليون بين عن, مرجع منتصف الأمريكية جعل السبب وفرنسا الصينية أي.\",\n  \"قدما مليون بين عن, مرجع منتصف الأمريكية جعل السبب وفرنسا الصينية أي.\"\n];\nvar rtlServer = [\n  \"قدما مليون بين عن, مرجع منتصف الأمريكية جعل السبب وفرنسا الصينية أي.\",\n  \"قدما مليون بين عن, مرجع منتصف الأمريكية جعل السبب وفرنسا الصينية أي.\",\n  \"قدما مليون بين عن, مرجع منتصف الأمريكية جعل السبب وفرنسا الصينية أي.\"\n];\n\n// ##############################\n// // // data for datatables.net in DataTables view\n// #############################\n\nconst dataTable = {\n  headerRow: [\"Name\", \"Position\", \"Office\", \"Age\", \"Actions\"],\n  footerRow: [\"Name\", \"Position\", \"Office\", \"Age\", \"Actions\"],\n  dataRows: [\n    [\"Tiger Nixon\", \"System Architect\", \"Edinburgh\", \"61\"],\n    [\"Garrett Winters\", \"Accountant\", \"Tokyo\", \"63\"],\n    [\"Ashton Cox\", \"Junior Technical Author\", \"San Francisco\", \"66\"],\n    [\"Cedric Kelly\", \"Senior Javascript Developer\", \"Edinburgh\", \"22\"],\n    [\"Airi Satou\", \"Accountant\", \"Tokyo\", \"33\"],\n    [\"Brielle Williamson\", \"Integration Specialist\", \"New York\", \"61\"],\n    [\"Herrod Chandler\", \"Sales Assistant\", \"San Francisco\", \"59\"],\n    [\"Rhona Davidson\", \"Integration Specialist\", \"Tokyo\", \"55\"],\n    [\"Colleen Hurst\", \"Javascript Developer\", \"San Francisco\", \"39\"],\n    [\"Sonya Frost\", \"Software Engineer\", \"Edinburgh\", \"23\"],\n    [\"Jena Gaines\", \"Office Manager\", \"London\", \"30\"],\n    [\"Quinn Flynn\", \"Support Lead\", \"Edinburgh\", \"22\"],\n    [\"Charde Marshall\", \"Regional Director\", \"San Francisco\", \"36\"],\n    [\"Haley Kennedy\", \"Senior Marketing Designer\", \"London\", \"43\"],\n    [\"Tatyana Fitzpatrick\", \"Regional Director\", \"London\", \"19\"],\n    [\"Michael Silva\", \"Marketing Designer\", \"London\", \"66\"],\n    [\"Paul Byrd\", \"Chief Financial Officer (CFO)\", \"New York\", \"64\"],\n    [\"Gloria Little\", \"Systems Administrator\", \"New York\", \"59\"],\n    [\"Bradley Greer\", \"Software Engineer\", \"London\", \"41\"],\n    [\"Dai Rios\", \"Personnel Lead\", \"Edinburgh\", \"35\"],\n    [\"Jenette Caldwell\", \"Development Lead\", \"New York\", \"30\"],\n    [\"Yuri Berry\", \"Chief Marketing Officer (CMO)\", \"New York\", \"40\"],\n    [\"Caesar Vance\", \"Pre-Sales Support\", \"New York\", \"21\"],\n    [\"Doris Wilder\", \"Sales Assistant\", \"Sidney\", \"23\"],\n    [\"Angelica Ramos\", \"Chief Executive Officer (CEO)\", \"London\", \"47\"],\n    [\"Gavin Joyce\", \"Developer\", \"Edinburgh\", \"42\"],\n    [\"Jennifer Chang\", \"Regional Director\", \"Singapore\", \"28\"],\n    [\"Brenden Wagner\", \"Software Engineer\", \"San Francisco\", \"28\"],\n    [\"Fiona Green\", \"Chief Operating Officer (COO)\", \"San Francisco\", \"48\"],\n    [\"Shou Itou\", \"Regional Marketing\", \"Tokyo\", \"20\"],\n    [\"Michelle House\", \"Integration Specialist\", \"Sidney\", \"37\"],\n    [\"Suki Burks\", \"Developer\", \"London\", \"53\"],\n    [\"Prescott Bartlett\", \"Technical Author\", \"London\", \"27\"],\n    [\"Gavin Cortez\", \"Team Leader\", \"San Francisco\", \"22\"],\n    [\"Martena Mccray\", \"Post-Sales support\", \"Edinburgh\", \"46\"],\n    [\"Unity Butler\", \"Marketing Designer\", \"San Francisco\", \"47\"],\n    [\"Howard Hatfield\", \"Office Manager\", \"San Francisco\", \"51\"],\n    [\"Hope Fuentes\", \"Secretary\", \"San Francisco\", \"41\"],\n    [\"Vivian Harrell\", \"Financial Controller\", \"San Francisco\", \"62\"],\n    [\"Timothy Mooney\", \"Office Manager\", \"London\", \"37\"],\n    [\"Jackson Bradshaw\", \"Director\", \"New York\", \"65\"],\n    [\"Olivia Liang\", \"Support Engineer\", \"Singapore\", \"64\"]\n  ]\n};\n\nexport {\n  // data for React Big Calendar in Calendar view\n  events,\n  // stories for RTLSupport view\n  rtlStories,\n  // stories for Widgets view\n  widgetStories,\n  // stories for Timeline view\n  stories,\n  // these 3 are used to create the tasks lists in TasksCard - Widget view\n  bugs,\n  website,\n  server,\n  // these 3 are used to create the tasks lists in TasksCard - RTLSupport view\n  rtlBugs,\n  rtlWebsite,\n  rtlServer,\n  // data for datatables.net in DataTables view\n  dataTable\n};\n","import React, { memo, useEffect, useRef } from \"react\"\nimport moment from \"moment-timezone\"\nimport ReactAudioPlayer from \"react-audio-player\"\nimport Reactions from \"components/Reactions_V2\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Card from \"components/Card\"\nimport CardTags from \"components/Tags/Card\"\nimport CustomButton from \"components/Buttons/custom\"\nimport HeaderWithIcon from \"components/Header/card\"\nimport Icon from \"components/Icon\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport ReplyMessage from \"./message\"\nimport MoreVert from \"components/MoreMenu/\"\nimport SelectUsers from \"components/User/select\"\nimport TextField from \"components/TextField\"\nimport UserBadge from \"components/Badge/user\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\"\nimport Dialog from \"@material-ui/core/Dialog\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\nimport { makeStyles } from \"@material-ui/core/styles\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/timelineStyle.js\"\n\n//FUNCTIONS\nimport {\n    translate,\n    formatNumber,\n    customApp,\n    Highlighted,\n    links,\n    appAlert\n} from \"functions/\"\n\nimport {\n    interact,\n    deleteMessage,\n    forwardMessage\n} from \"functions/chat\"\n\n//IMAGES\nimport defaultAvatar from \"assets/img/fundo-sonne.png\"\nimport SVGIcon from \"assets/icons/svg.png\"\nimport { stories } from \"variables/general\"\n\nconst useStyles = makeStyles(styles);\n\n\nconst Message = (props) => {\n    const classes = useStyles()\n    const {\n        db,\n        session,\n        functions,\n        timeline\n    } = reduxStore.getState()\n\n    const { socket } = functions\n    const [hideImage, setHideImage] = React.useState(false)\n    const [overOptions, setOverOptions] = React.useState(false)\n    const [cancelReason, setCancelReason] = React.useState(null)\n    const [goCancel, setGoCancel] = React.useState(null)\n    const [forward, setForward] = React.useState(false)\n    const [saveLoading, setSaveLoading] = React.useState(false)\n    const [forwardToId, setForwardToId] = React.useState(null)\n    const { storie } = props\n\n    const messageRef = useRef()\n\n    useEffect(() => {\n        if (!messageRef.current) return; // wait for the elementRef to be available\n        const resizeObserver = new ResizeObserver(() => {\n            // Do what you want to do when the size of the element changes\n            if (props.onResize)\n                props.onResize(messageRef.current.clientHeight)\n        });\n        resizeObserver.observe(messageRef.current);\n        return () => resizeObserver.disconnect(); // clean up \n    }, []);\n\n    useEffect(() => {\n        if (messageRef.current) {\n            if (props.onResize) {\n                let newSize = messageRef.current.clientHeight\n                if (props.separator)\n                    newSize = newSize + 50\n                props.onResize(newSize)\n                // messageRef.current.addEventListener(\"DOMNodeInserted\", () => {\n                //     // let newSize = messageRef.current.clientHeight\n                //     props.onResize(messageRef.current.clientHeight)\n                // })\n                // messageRef.current.addEventListener(\"resize\", () => {\n                //     // let newSize = messageRef.current.clientHeight\n                //     props.onResize(messageRef.current.clientHeight)\n                // })\n            }\n        }\n        // eslint-disable-next-line\n    }, [messageRef]);\n\n    let timer = null\n    let cardId\n\n    if (storie && storie._parent && db.cards[storie._parent]) {\n        cardId = storie._parent\n    } else if (storie && storie.idRel && db.cards[storie.idRel]) {\n        cardId = storie.idRel\n    }\n    if (storie.filesCount\n        && storie.filesCount > 0\n        && stories.user\n        && stories.user._id\n        && stories.user._id !== session._id\n        && (\n            !stories.files\n            || (\n                stories.files\n                && stories.files.length < storie.filesCount\n            )\n        ))\n        return (<React.Fragment></React.Fragment>)\n\n    const mentionedUsers = (text) => {\n        let cardId\n        if (storie && storie._parent && db.cards[storie._parent]) {\n            cardId = storie._parent\n        } else if (storie && storie.idRel && db.cards[storie.idRel]) {\n            cardId = storie.idRel\n        }\n\n        let newText\n        newText = text\n        if (text) {\n            const test1 = text.split(\"@[\")\n            if (test1.length > 0)\n                test1.map(a => {\n                    if (a) {\n                        let toReplace = `@[${a.split(\")\")[0]})`\n                        let id = a.split(\"](\")[1]\n                        if (id) {\n                            id = id.split(\")\")[0]\n                            if (\n                                id\n                                && id.length === 36\n                                && db.cards[cardId]\n                                && db.cards[cardId]._users\n                                && db.cards[cardId]._users[id]\n                            ) {\n                                let userName = db.cards[cardId]._users\n                                    && db.cards[cardId]._users[id]\n                                    && db.cards[cardId]._users[id].name\n                                    ? db.cards[cardId]._users[id].name\n                                    : db.cards[cardId]._users\n                                        && db.cards[cardId]._users[id]\n                                        && db.cards[cardId]._users[id].name\n                                        ? db.cards[cardId]._users[id].name\n                                        : a.split(\"](\")[0]\n                                newText = newText.replace(toReplace, `<span style=\"color:${customApp(\"menu\")}\"><b>${userName}</b></span>`)\n                            } else if (\n                                id\n                                && id.length === 36\n                                && db.users[id]\n                            ) {\n                                let userName = db.users[id] && db.users[id].name\n                                    ? db.users[id].name : a.split('](')[0]\n                                newText = newText.replace(toReplace, `<span style=\"color:${customApp(\"menu\")}\"><b>${userName}</b></span>`)\n                            } else {\n                                let userName = a.split('](')[0]\n                                newText = newText.replace(toReplace, `<span style=\"color:${customApp(\"menu\")}\"><b>${userName}</b></span>`)\n                            }\n                        }\n                    }\n                    return true\n                })\n        }\n\n        return newText\n    }\n\n    const overOptionsHandle = (mouse = false) => {\n        setOverOptions(true)\n        if (mouse)\n            clearTimeout(timer)\n    }\n    const closeOptionsHandle = (time = 0) => {\n        timer = setTimeout(() => {\n            setOverOptions(false)\n        }, time)\n    }\n\n    const reactThis = (react) => {\n        let nodeId = props.storie.idRel ? props.storie.idRel : props.storie._parent ? props.storie._parent : props.nodeId ? props.nodeId : null\n        let data = {\n            chatId: reduxStore.getState().chat.id,\n            react: react,\n            user: session._id,\n            db: props.db,\n            nodeId: nodeId,\n            message: props.storie._id\n        }\n\n        interact(props, data)\n        socket.emit(\"data\", {\n            module: \"timeline\",\n            method: \"post\",\n            action: \"interact\"\n        }, data)\n    }\n\n\n    if (!storie)\n        return null\n\n    let time = \"\"\n    if (storie.type === \"timer\" && String(storie.ini) && String(storie.fin))\n        time = storie.fin - storie.ini\n\n    let urlPreview = null\n\n    if (storie.urlPreview)\n        urlPreview = JSON.parse(storie.urlPreview)\n\n    let message = translate(mentionedUsers(storie.message))\n\n    let reaction\n    if (storie._reactions && Object.keys(storie._reactions).length > 0)\n        Object.keys(storie._reactions).map(re => {\n            if (Object.keys(storie._reactions[re]).length > 0)\n                Object.keys(storie._reactions[re]).map(us => {\n                    if (us === session._id)\n                        reaction = re\n                })\n        })\n\n    let my = false\n    if (props.storie && props.storie.user && props.storie.user._id === session._id)\n        my = true\n\n    // if (props.storie.message.indexOf(\"Primeira Entrevistas\") > -1)\n    //     console.log(props.storie)\n\n    const cancelConfirm = () => {\n        appAlert({\n            message: translate('$__confirmCancel', 1),\n            variant: 'warning',\n            persist: false,\n            horizontal: 'right',\n            confirm: () => {\n                deleteMessage(props, {\n                    id: storie._id,\n                    idRel: storie.idRel,\n                    deletedReason: cancelReason,\n                    deleted: true\n                })\n                storie.deleted = true\n                setGoCancel(false)\n                setCancelReason(null)\n            }\n        })\n\n    }\n    const renderMessage = () => {\n        if (storie.type === \"comment\" && storie.message) {\n            return (\n                <div>\n                    {storie.urlPreview && urlPreview.img && urlPreview.title && urlPreview.contentSnippet ?\n                        <GridContainer style={{ marginBottom: 15 }}>\n                            {!hideImage && urlPreview.img &&\n                                <GridItem\n                                    xs={12}\n                                    sm={6}\n                                    md={4}\n                                    lg={3}\n                                    xl={2}\n                                >\n                                    <img\n                                        style={{\n                                            width: \"-webkit-fill-available\"\n                                        }}\n                                        src={`${urlPreview.img}`}\n                                        onError={(e) => {\n                                            setHideImage(true)\n                                        }}\n                                        alt={urlPreview.title || urlPreview.link}\n                                    />\n                                </GridItem>\n                            }\n                            <GridItem\n                                xs={12}\n                                sm={6}\n                                md={8}\n                                lg={9}\n                                xl={10}\n                            >\n                                <div style={{\n                                    fontSize: \"14px\",\n                                    color: customApp(\"menu\"),\n                                    fontWeight: \"bold\"\n                                }}>{urlPreview.title}</div>\n                                {urlPreview.site && <div\n                                    style={{\n                                        fontSize: \"12px\",\n                                    }}\n                                >{urlPreview.site}</div>}\n                                {urlPreview.contentSnippet && <div\n                                    style={{\n                                        fontSize: \"12px\",\n                                        color: \"gray\",\n                                    }}>{urlPreview.contentSnippet}</div>}\n                                <a style={{\n                                    marginTop: \"15px\",\n                                    fontWeight: \"bold\",\n                                    fontSize: \"12px\",\n                                }\n                                } href={urlPreview.link} target=\"_blank\">{translate(\"$__openLink\", \"*\")}</a>\n                            </GridItem>\n                        </GridContainer>\n                        : <React.Fragment></React.Fragment>}\n                    <GridItem\n                        xs={12}\n                        sm={12}\n                        md={12}\n                        lg={12}\n                        xl={12}\n                    >\n                        {Highlighted(links(message), props.searchText)}\n                    </GridItem>\n                    <div style={{ clear: \"both\" }}></div>\n                </div>\n            )\n        } else if (storie.type === \"comment\" && !storie.message && storie.cardId !== props.nodeId && reduxStore.getState().db.cards[storie.cardId]) {\n            return (\n                <Card db=\"cards\" data={reduxStore.getState().db.cards[storie.cardId]} Avatar expanded ignoreList />\n            )\n        }\n        if (storie.type === \"log\") {\n            let newData = {}\n            if (storie.message === \"$__updated\") {\n                newData = JSON.parse(storie.newData)\n                return (\n                    <div>\n\n                        <div style={{ position: \"relative\", width: \"100%\", display: \"flex\" }}>\n                            <Icon color=\"color\" icon=\"history\" style={{ marginRight: \"10px\" }} />\n                            {storie.message.indexOf(\"$__\") > -1 ? translate(storie.message, 1) : storie.message}{` `}\n                        </div>\n                        {storie.newData &&\n                            <ul style={{\n                                position: \"relative\",\n                                width: \"98%\"\n                            }}>\n                                {Object.keys(newData).map((a, i) => {\n                                    if (a === \"icon\") {\n                                        return (\n                                            <li key={i} style={{ display: \"flex\" }}>\n                                                {translate(`$__icon`, 1)}:<Icon icon={newData[a]} color={customApp(\"color\")} size={\"17px\"} />\n                                            </li>\n                                        )\n                                    } else\n                                        if (a === \"customColumns\") {\n                                            let columns = JSON.parse(newData[a])\n                                            return (<li key={i}>{translate(`$__customColumns`, 1)}:\n                                                <ul>\n                                                    {Object.keys(columns).map((a, ai) =>\n                                                        <li key={ai}>{translate(`$__${a}`)}{`=>`} <span style={{ color: customApp('menu'), fontWeight: \"bold\" }}>{translate(`${columns[a].name}`)}</span></li>\n                                                    )}\n\n                                                </ul>\n                                            </li>)\n                                        } else if (\n                                            a === \"_id\"\n                                            || a === \"id\"\n                                            || a === \"client\"\n                                            || a === \"planId\"\n                                            || a === \"_parent\"\n                                            || a === \"owner\"\n                                            || a === \"image\"\n                                        ) {\n                                        } else if (a === \"status\") {\n                                            return (<li key={i}>{translate(`$__status`, 1)}: {translate(`$__${newData[a]}`, 1)}</li>)\n                                        } else if (a === 'note') {\n                                            return (<li key={i}>{translate(`$__note`, 1)}: <div>{Highlighted(links(newData[a]), props.searchText)}</div></li>)\n                                        } else if (\n                                            a === \"kpi_type\"\n                                            || a === \"priority\"\n                                            || a === \"risk\"\n                                            || a === \"complexity\"\n                                            || a === \"impact\"\n                                        ) {\n                                            return (<li key={i}>{translate(`$__${a}`, 1)}: {translate(`$__${newData[a]}`, 1)}</li>)\n                                        } else if (\n                                            a === \"name\" || a === 'description'\n                                        ) {\n                                            return (\n                                                <li key={i}>{translate(`$__${a}`, 1)}: {newData[a]}</li>\n                                            )\n                                        } else if (\n                                            a === \"url\"\n                                        ) {\n                                            return (\n                                                <li key={i}>{\"url\"}:\n                                                    <a href={newData[a]} target=\"blank\"\n                                                        style={{\n\n                                                        }}\n                                                    >\n                                                        {Highlighted(links(newData[a]), props.searchText)}\n                                                    </a>\n                                                </li>\n                                            )\n                                        } else if (\n                                            a !== \"_tags\"\n                                            && (typeof newData[a] === \"string\")\n                                            && (\n                                                a !== \"kpi_ini\"\n                                                && a !== \"kpi_fin\"\n                                                && a !== \"startDate\"\n                                                && a !== \"endDate\"\n                                                && a !== \"updated_at\"\n                                                && a !== \"created_at\"\n                                                && a !== \"content\"\n                                            )\n                                        ) {\n\n                                            return (\n                                                <li key={i}>{translate(`$__${a}`, 1)}: {newData[a].indexOf(\"$__\") > -1 ? translate(`$__${newData[a]}`, 1) : newData[a]}</li>\n                                            )\n                                        } else if (\n                                            a === \"kpi_ini\"\n                                            || a === \"kpi_fin\"\n                                        ) {\n                                            let kpiType = newData[\"kpi_type\"] ? newData[\"kpi_type\"] : db.cards[storie.idRel] && db.cards[storie.idRel].kpi_type ? db.cards[storie.idRel].kpi_type : null\n                                            return (\n                                                <li key={i}>{translate(`$__${a}`, 1)}: {formatNumber(newData[a], storie.kpi_type ? storie.kpi_type : \"decimal\")}</li>\n                                            )\n                                        } else if (\n                                            a === \"startDate\"\n                                            || a === \"endDate\"\n                                            || a === \"updated_at\"\n                                            || a === \"created_at\"\n                                        ) {\n                                            return (\n                                                <li key={i}>{translate(`$__${a}`, 1)}: {!newData[a] ? translate(\"$__removed\") : moment(new Date(newData[a] * 1000)).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY HH:mm\")}</li>\n                                            )\n                                        } else if (\n                                            typeof newData[a] === \"boolean\"\n                                        ) {\n                                            return (\n                                                <li key={i}>{translate(`$__${a}`, 1)}: {newData[a] ? translate(`$__enable`, 1) : translate(`$__disable`, 1)}</li>\n                                            )\n                                        } else if (a === \"_tags\") {\n                                            return (<li key={i}>TAGS: <CardTags options={newData[a]} showOptions={true} /></li>)\n                                        }\n                                }\n                                )}\n                                <div style={{ clear: \"both\" }}></div>\n                            </ul>\n                        }\n                        <div style={{ clear: \"both\" }}></div>\n                    </div>\n                )\n            } else {\n                return (\n                    <div style={{ position: \"relative\", width: \"100%\" }}>\n                        <div style={{ position: \"relative\", width: \"100%\", display: \"flex\" }}>\n                            <Icon color=\"color\" icon=\"history\" style={{ marginRight: \"10px\" }} />\n                            {storie.approval && storie.message.indexOf(\"$__approved\") > -1 ?\n                                <Icon icon=\"verified\" color={\"green\"} />\n                                : storie.approval && storie.message.indexOf(\"$__rejected\") > -1 ?\n                                    <Icon icon=\"gpp_bad\" color={\"red\"} />\n                                    : <React.Fragment></React.Fragment>\n                            }\n                            <div style={{ wordBreak: \"break-word\" }}>\n                                {Highlighted(links(message), props.searchText)}\n                            </div>\n                            <div style={{ clear: \"both\" }}></div>\n                        </div>\n                        {storie.cardId ?\n                            <div\n                                style={{\n                                    position: \"relative\",\n                                    maxWidth: \"285px\",\n                                    ...props.boxStyle && props.boxStyle.maxWidth ? { maxWidth: props.boxStyle.maxWidth } : {},\n                                    width: \"100%\",\n                                    display: \"block\"\n                                }}>\n                                <Card\n                                    db=\"cards\"\n                                    data={reduxStore.getState().db.cards[storie.cardId]}\n                                    ignoreList\n                                    onlyOption\n                                    notGlobalExpanded\n                                    noExpanding\n                                    disabled\n                                />\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                        <div style={{ clear: \"both\" }}></div>\n                    </div>\n                )\n            }\n        }\n        if (storie.type === \"timer\") {\n            // if (storie.message === \"Dsf\")\n            //     console.log(storie)\n            let diff = time\n            let diffText = ``\n            if (time < 60) {\n                diffText = `${diff} ${translate(\"$__seconds\", 1)}`\n            } else if (time > 3600) {\n                let hours = Math.trunc(diff / 3600)\n                diff = diff - (hours * 3600)\n                let minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\n                diff = diff - (minutes * 60)\n                let seconds = diff > 0 ? diff : 0\n                diffText = `${hours} hora${hours > 1 ? \"s\" : \"\"} ${minutes} ${translate(\"$__minutes\", 1)} ${seconds} ${translate(\"$__seconds\", 1)}`\n            } else {\n                let minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\n                diff = diff - (minutes * 60)\n                let seconds = diff > 0 ? diff : 0\n                diffText = `${minutes} ${translate(\"$__minutes\", 1)} ${seconds} ${translate(\"$__seconds\", 1)}`\n            }\n            if (goCancel)\n                return (\n                    <div>\n                        <div style={{ position: \"relative\", width: \"100%\", marginTop: \"33px\" }}>\n                            <TextField\n                                label={translate('$__cancelReason', 1)}\n                                variant={customApp('standard')}\n                                name=\"cancelReason\"\n                                InputProps={{\n                                    autoComplete: 'new-password',\n                                    multiline: true,\n                                    minRows: 3,\n                                    onChange: (d) => {\n                                        setCancelReason(d.target.value)\n                                    },\n                                }}\n                                placeholder={translate('$__cancelReason_placeholder', 1)}\n                            />\n                        </div>\n                        <div style={{ position: \"absolute\", right: \"7px\", top: \"7px\", display: 'flex' }}>\n                            <CustomButton\n                                transparent\n                                title={translate(`$__cancel`, '*')}\n                                color={customApp('lightgrey')}\n                                icon={'cancel'}\n                                onClick={() => {\n                                    setGoCancel(false)\n                                    setCancelReason(null)\n                                }}\n                                size={'25px'}\n                            />\n                            <CustomButton\n                                transparent\n                                title={translate(`$__save`, 1)}\n                                color='green'\n                                icon={'playlist_add_check'}\n                                onClick={() => {\n                                    cancelConfirm()\n                                }}\n                                size={'25px'}\n                            />\n                        </div>\n                        <div style={{ clear: \"both\" }}></div>\n                    </div>\n                )\n            return (\n                <div>\n                    <div\n                        style={{\n                            position: \"relative\",\n\n                        }}\n                    >\n                        {storie && storie._toUser && Object.keys(storie._toUser).length > 0 &&\n                            <div className={classes.timeInfo}>\n                                <AvatarGroup\n                                    max={300}\n                                    style={{\n                                        flexWrap: \"wrap\",\n                                        display: \"inline-flex\",\n                                        border: \"none\"\n                                    }}\n                                >\n                                    {Object.keys(storie._toUser).map(selectedUserId =>\n                                        <Tooltip\n                                            key={selectedUserId}\n                                            title={storie._toUser[selectedUserId].displayName ? storie._toUser[selectedUserId].displayName : storie._toUser[selectedUserId].name}\n                                        >\n                                            <Avatar\n                                                alt={storie._toUser[selectedUserId].name}\n                                                src={storie._toUser[selectedUserId].image || null}\n                                                style={{ width: 27, height: 27, border: \"none\" }}>\n                                                {storie._toUser[selectedUserId].name.substr(0, 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                    )}\n                                </AvatarGroup>\n                            </div>\n                        }\n                        {storie.manualEntry ?\n                            <div className={classes.timeInfo}>\n                                <Icon color=\"color\" icon=\"schedule\" />\n                                <div className=\"text\">{moment(storie.ini * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")}</div>\n                            </div>\n                            : <React.Fragment>\n                                {parseInt(moment(storie.ini * 1000).tz(\"America/Sao_Paulo\").format(\"YYYY\")) > 2021 ?\n                                    <div className={classes.timeInfo}>\n                                        <Icon color=\"color\" icon=\"schedule\" />\n                                        <div className=\"text\">{moment(storie.ini * 1000).tz(\"America/Sao_Paulo\").format(\"YYYY/MM/DD HH:mm:ss\")}</div>\n                                    </div>\n                                    :\n                                    <React.Fragment></React.Fragment>\n                                }\n                                {parseInt(moment(storie.fin * 1000).tz(\"America/Sao_Paulo\").format(\"YYYY\")) > 2021 ?\n                                    <div className={classes.timeInfo}>\n                                        <Icon color=\"color\" icon=\"watch_later\" />\n                                        <div className=\"text\">{moment(storie.fin * 1000).tz(\"America/Sao_Paulo\").format(\"YYYY/MM/DD HH:mm:ss\")}</div>\n                                    </div>\n                                    :\n                                    <React.Fragment></React.Fragment>\n                                }\n                            </React.Fragment>\n                        }\n\n                        <div className={classes.timeInfo}>\n                            <Icon color=\"color\" icon=\"hourglass_full\" />\n                            <div className=\"text\">\n                                {diffText}\n                            </div>\n                        </div>\n                        <div style={{ clear: 'both' }}></div>\n                        {storie.deleted ? <div\n                            style={{\n                                position: \"absolute\",\n                                top: 0,\n                                left: 0,\n                                right: 0,\n                                bottom: 0,\n                                backgroundColor: \"rgba(255,255,255,0.66)\",\n                                display: \"flex\",\n                                justifyContent: \"center\",\n                                alignItems: \"center\",\n                                fontWeight: \"bold\",\n                                color: customApp(\"menu\")\n                            }}\n                        >\n                            {translate(\"$__cancelled\")}\n                        </div> : <React.Fragment></React.Fragment>}\n                    </div>\n                    <div>{message}</div>\n                    {storie.deleted && storie.deletedReason &&\n                        <div style={{ color: \"red\" }}>{translate(\"$__cancelReason\", 1)}: {storie.deletedReason}</div>\n                    }\n                    <div style={{ clear: \"both\" }}></div>\n                    {\n                        (\n                            !storie.deleted &&\n                            (\n                                overOptions ||\n                                (\n                                    moment(storie.created_at).unix('x')\n                                )\n                            )\n                        ) ?\n                            <div style={{ position: \"absolute\", right: \"7px\", top: \"7px\" }}>\n                                <MoreVert\n                                    transparent\n                                    options={[\n                                        {\n                                            name: \"$__cancelThis\",\n                                            icon: \"cancel\",\n                                            onClick: () => {\n                                                setGoCancel(true)\n                                            },\n                                            show: \"hover\"\n                                        },\n                                    ]}\n                                />\n                                <div style={{ clear: \"both\" }}></div>\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                    }\n                    <div style={{ clear: \"both\" }}></div>\n                </div>\n            )\n        }\n        if (storie.type === \"kpi\") {\n            let balance = storie && storie.balance ? storie.balance : 0\n            return (\n                <div>\n                    {storie.cardId ? <Card db=\"cards\" data={reduxStore.getState().db.cards[storie.cardId]} ignoreList noOptions /> : <React.Fragment></React.Fragment>}\n                    <div>{message}</div>\n                    <div className={parseFloat(storie.value) > 0 ? classes.valuePositive : classes.valueNegative}>{formatNumber(storie.value, storie.kpi_type ? storie.kpi_type : \"decimal\")}</div>\n\n                    {!props.stories &&\n                        <div className={classes.lastValue}>{translate(\"$__balance\", 1)}: {formatNumber(balance, storie.kpi_type ? storie.kpi_type : \"decimal\")}</div>\n                    }\n                    <div style={{ clear: \"both\" }}></div>\n                </div>\n            )\n        }\n    }\n\n\n    if (!storie.filesCount && storie.message === \"\" && storie.cardId && storie.cardId !== props.nodeId && !reduxStore.getState().db.cards[storie.cardId])\n        return null\n\n    const renderFile = (file) => {\n        let fileName = file.name.split(\".\")\n        let ext = fileName[fileName.length - 1]\n\n        let img = `attachment`\n        if (db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0) {\n            img = db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].icon\n                || `https://fl.machen.ai/?arq=${file.file.replace('&', '||MCH-ECOM||')}&name=${file.name.replace('&', '||MCH-ECOM||')}`\n        }\n\n        let viewer = \"img\"\n        if (db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0 && db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].viewer)\n            viewer = db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].viewer\n\n        return (\n            <div key={file._id}\n                style={{\n                    position: \"relative\",\n                    display: \"flex\",\n                    marginBottom: \"5px\",\n                    whiteSpace: \"nowrap\",\n                    textOverflow: \"ellipsis\",\n                    cursor: \"pointer\",\n                    overflow: \"hidden\",\n                    padding: \"7px\",\n                    zIndex: \"10 !important\",\n                    borderRadius: \"15px\",\n                    alignItems: \"center\",\n                    justifyContent: \"center\",\n                    ...viewer === \"audio\" ? {\n                        width: \"350px\",\n                        height: \"50px\",\n                    } : viewer === \"movie\" ? {\n                        width: \"350px\",\n                        height: \"280px\",\n                    } : {\n                        width: \"150px\",\n                        height: \"150px\",\n                    }\n                }}\n                onClick={(e) => {\n                    if (props.openLightBox) {\n                        props.openLightBox(file._id)\n                    }\n                    e.preventDefault()\n                }}\n                title={file.name}\n            >\n                {(viewer === \"img\"\n                    ||\n                    (\n                        (viewer !== \"movie\" && viewer !== \"audio\" && typeof img === \"string\" && img.indexOf(\"blob:\") === -1 && img.indexOf(\"svg\") === -1)\n                        || viewer !== \"movie\" && viewer !== \"audio\" && !(viewer === \"img\" && img && img.indexOf(\"svg\") > -1)\n                    )) &&\n                    <Tooltip\n                        title={file.name}>\n                        <div style={{\n                            position: \"absolute\",\n                            bottom: \"7px\",\n                            left: \"7px\",\n                            right: \"7px\",\n                            padding: \"3px\",\n                            background: \"rgba(0,0,0,0.8)\",\n                            color: \"#FFFFFF\",\n                            borderRadius: \"0px 0px 15px 15px\",\n                            overflow: \"hidden\",\n                            textOverflow: \"ellipsis\",\n                        }}>{file.name}</div>\n                    </Tooltip>\n                }\n                {/* IMAGES */}\n                {(viewer === \"img\" && img === \"attachment\") &&\n                    <Icon icon={img} size=\"50px\" />\n                }\n                {(viewer === \"img\"\n                    &&\n                    (\n                        typeof img === \"string\"\n                        && img.indexOf(\"https\") > -1\n                        && img.indexOf(\"svg\") === -1\n                    )\n                ) &&\n                    <img\n                        src={`${img}`}\n                        style={\n                            {\n                                borderRadius: \"15px\",\n                                boxShadow: `0 1px 2px 2px rgba(0,0,0,0.1)`,\n                                maxWidth: \"100%\",\n                                height: \"100%\",\n                                maxHeight: \"33vh\"\n                            }}\n                        onError={(e) => {\n                            if (\n                                storie.created_at\n                                && typeof storie.created_at === \"string\"\n                                && parseInt(storie.created_at) > moment().unix(\"X\") - 60\n                            )\n                                e.target.src = img\n                        }\n                        }\n                    />\n                }\n\n                {(viewer !== \"movie\" && viewer !== \"img\" && typeof img === \"string\" && img.indexOf(\"blob:\") === -1 && img.indexOf(\"svg\") === -1) ?\n                    <Icon icon={img} size=\"50px\" />\n                    : (viewer !== \"movie\" && viewer !== \"img\" && !(viewer === \"img\" && img && img.indexOf(\"svg\") > -1)) ?\n                        <img src={img} style={{ width: \"100%\", height: \"100%\" }} />\n                        : <React.Fragment></React.Fragment>\n                }\n\n                {/* IMAGES */}\n                {(viewer === \"img\" && img && img.indexOf(\".svg\") > -1) ?\n                    <img\n                        src={SVGIcon}\n                        style={\n                            {\n                                borderRadius: \"15px\",\n                                boxShadow: `0 1px 2px 2px rgba(0,0,0,0.1)`,\n                                maxWidth: \"100%\",\n                                height: \"100%\",\n                                maxHeight: \"33vh\"\n                            }}\n                    />\n                    : <React.Fragment></React.Fragment>\n                }\n\n                {viewer === \"movie\"\n                    &&\n                    <video\n                        style={{\n                            width: \"100%\"\n                        }}\n                        controlsList=\"nodownload\"\n                        src={`https://machen.azureedge.net/${file.file}`} ></video>\n                }\n                {viewer === \"audio\"\n                    &&\n                    <ReactAudioPlayer\n                        src={`https://machen.azureedge.net/${file.file}`}\n                        // autoPlay\n                        controls\n                    />\n                }\n                <div style={{ clear: \"both\" }}></div>\n            </div>\n        )\n    }\n\n    return (\n        <div\n            style={{\n                maxWidth: \"calc(100% - 15px)\",\n                marginLeft: \"7px\",\n                ...props.messageClick ? { cursor: \"pointer\" } : {},\n                ...props.boxStyle ? props.boxStyle : {}\n            }}\n            onClick={props.messageClick ? (e) => {\n                props.messageClick()\n                e.preventDefault()\n            } : null\n            }\n            ref={messageRef}\n        >\n            <div\n                className=\"message\"\n                style={{\n                    position: \"relative\",\n                    maxWidth: \"calc(88% - 15px)\",\n                    float: my ? \"right\" : \"left\",\n                    ...my ? {\n                        marginRight: \"15px\"\n                    } : {\n                        marginLeft: \"15px\"\n                    },\n                    width: \"auto\",\n                    minWidth: \"303px\",\n                    marginBottom: \"20px\"\n                }}\n\n                onMouseLeave={() => { closeOptionsHandle(1000) }}\n                onMouseOver={() => {\n                    if (!props.isReply)\n                        overOptionsHandle(true)\n                }}\n                onClick={() => {\n                    if (!props.isReply)\n                        overOptionsHandle(true)\n                }}\n            >\n                {(props.showUserName && !my) &&\n                    <div style={{\n                        position: \"relative\",\n                        width: \"100%\",\n                        fontWeight: \"bold\",\n                        fontSize: \"12px\",\n                        color: customApp('menu'),\n                    }}>\n                        {storie.user.name ? storie.user.name : storie.user.fullName}\n                    </div>\n                }\n                <div style={{\n                    position: \"relative\",\n                    float: my ? \"right\" : \"left\",\n                    padding: \"7px 15px\",\n                    width: \"100%\",\n                    background: my ? \"linear-gradient(33deg, rgba(237, 237, 237, 1), rgba(196, 196, 196, 1))\" : \"linear-gradient(33deg, rgba(250, 250, 250, 1), rgba(240,240,240, 1))\",\n                    borderRadius: \"15px\",\n                    boxShadow: \"rgb(0 0 0 / 5%) 0px 2px 2px 2px\",\n                    ...storie.approval ? {\n                        border: `solid 4px ${storie.message.indexOf(\"$__approved\") > -1 ? `green` : `red`}`\n                    } : {}\n                }}\n                >\n\n                    {(storie && storie.filesCount && storie && storie.user && storie.user._id === session._id && parseInt(storie.filesCount) > 0 && storie.files && Object.keys(storie.files).length === 0) ?\n                        <React.Fragment>\n                            <div style={{\n                                position: \"relative\",\n                                justifyContent: \"center\",\n                                alignItems: \"center\",\n                                color: \"lightgray\",\n                            }}>\n                                {translate(`$__transferringFile${parseInt(storie.filesCount) > 1 ? `s` : ``}`)}\n                            </div>\n                            <div\n                                className=\"files\"\n                                style={{\n                                    position: \"relative\",\n                                    maxWidth: \"calc(100% - 15px)\",\n                                    width: \"100%\",\n                                    display: \"flex\",\n                                }}>\n                                {\n                                    parseInt(storie.created_at) > moment().unix('x') - 60\n                                        ?\n                                        <React.Fragment>\n                                            {/* HOUVE UM PROBLEMA AO ENVIAR OS ARQUIVOS */}\n                                        </React.Fragment>\n                                        :\n                                        <React.Fragment>\n\n                                        </React.Fragment>\n                                }\n                            </div>\n                        </React.Fragment>\n                        :\n                        <React.Fragment></React.Fragment>\n                    }\n                    {\n                        storie.files && Object.keys(storie.files).length > 0 ?\n                            <div className=\"files\"\n                                style={{\n                                    position: \"relative\",\n                                    maxWidth: \"calc(100% - 15px)\",\n                                    float: my ? \"right\" : \"left\",\n                                    ...my ? {\n                                        marginRight: \"15px\"\n                                    } : {\n                                        marginLeft: \"15px\"\n                                    },\n                                    width: \"100%\",\n                                    display: \"flex\",\n                                    justifyContent: my ? `flex-end` : `none`,\n                                    flexWrap: \"wrap\"\n                                }}>\n                                {Object.keys(storie.files).map((id, i) => renderFile(storie.files[id]))}\n                            </div>\n                            : storie.files && storie.files.length > 0 ?\n                                <div className=\"files\"\n                                    style={{\n                                        position: \"relative\",\n                                        maxWidth: \"calc(100% - 15px)\",\n                                        float: my ? \"right\" : \"left\",\n                                        ...my ? {\n                                            marginRight: \"15px\"\n                                        } : {\n                                            marginLeft: \"15px\"\n                                        },\n                                        width: \"100%\",\n                                        display: \"flex\",\n                                        justifyContent: my ? `flex-end` : `none`,\n                                        flexWrap: \"wrap\"\n                                    }}>\n                                    {storie.files.map((ff, i) => renderFile(ff))}\n                                </div>\n                                : <React.Fragment></React.Fragment>\n                    }\n                    {(!props.isReply\n                        && props.storie\n                        && props.storie.reply\n                        && timeline\n                        && (\n                            (\n                                timeline[props.nodeId]\n                                && timeline[props.nodeId][props.storie.reply]\n                            ) ||\n                            (\n                                timeline[session._id]\n                                && timeline[session._id][props.storie.reply]\n                            )\n                        )\n                    ) &&\n                        <div\n                            style={{\n                                position: \"relative\",\n                                width: \"calc(100% - 20px)\",\n                                opacity: 0.66,\n                                display: \"flex\",\n                                justifyContent: \"center\",\n                                marginBottom: \"7px\"\n                            }}>\n                            <ReplyMessage\n                                isReply={true}\n                                storie={timeline[props.nodeId] && timeline[props.nodeId][props.storie.reply] ? timeline[props.nodeId][props.storie.reply] : timeline[session._id][props.storie.reply]}\n                                db={props.db}\n                                nodeId={props.nodeId}\n                                openLightBox={(e) => {\n                                    if (props.openLightBox)\n                                        props.openLightBox(e)\n                                }}\n                                messageClick={() => {\n                                    if (props.replyClick)\n                                        props.replyClick()\n                                }}\n                            />\n                        </div>\n                    }\n                    {(!storie.deleted || storie.type === 'timer') ?\n                        renderMessage()\n                        :\n                        <div\n                            style={{\n                                // position: \"absolute\",\n                                // top: 0,\n                                // left: 0,\n                                // right: 0,\n                                // bottom: 0,\n                                // backgroundColor: \"rgba(0,0,0,0.1)\",\n                                // borderRadius: 15,\n                                color: 'lightGray',\n                                height: 33,\n                                padding: 7,\n                            }}\n                        >\n                            {translate(\"$__removed\", \"*\")}*\n                        </div>\n                    }\n                </div>\n                {\n                    storie.user &&\n                    <div\n                        style={{\n                            position: \"absolute\",\n                            ...my ? {\n                                right: \"-20px\"\n                            } : {\n                                left: \"-20px\"\n                            },\n                            bottom: 0,\n                        }}\n                    >\n                        <UserBadge\n                            overlap=\"circular\"\n                            anchorOrigin={{\n                                vertical: \"bottom\",\n                                horizontal: \"right\",\n                            }}\n                            userId={storie.user._id}\n                        >\n                            <Avatar alt={storie.user.displayName ? storie.user.displayName : storie.user.name} src={`${storie.user.image}`}\n                                style={{\n                                    width: \"22px\",\n                                    height: \"22px\"\n                                }} />\n                        </UserBadge>\n                    </div>\n                }\n                <div style={{\n                    position: \"absolute\",\n                    ...my ? {\n                        left: \"15px\"\n                    } : {\n                        right: \"15px\"\n                    },\n                    bottom: \"-26px\",\n                    color: \"rgba(0,0,0,0.77)\",\n                    background: \"linear-gradient(33deg, rgba(233, 233, 233, 1), rgba(211,211,211, 1))\",\n                    display: \"flex\",\n                    padding: \"1px 7px\",\n                    alignItems: \"center\",\n                    borderRadius: \"0 0 7px 7px\",\n                    fontSize: \"10px\",\n                    width: \"fit-content\"\n                }}\n                >\n\n                    {moment(new Date()).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") === moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") ?\n                        `${moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"H:mm\")}`\n                        :\n                        moment(new Date()).tz(\"America/Sao_Paulo\").format(\"YYYY\") === moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"YYYY\") ?\n                            `${moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM H:mm\")}`\n                            :\n                            `${moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")}`\n                    }\n\n                    {(\n                        storie.readedBy\n                        && Object.keys(storie.readedBy).length > 0)\n                        &&\n                        <Tooltip\n                            title={(\n                                <React.Fragment>\n                                    <div className={classes.users}>\n                                        {Object.keys(storie.readedBy)\n                                            .sort((a, b) => {\n                                                if (storie\n                                                    && storie.readedBy[a]\n                                                    && storie.readedBy[a].readedDate\n                                                    && storie.readedBy[b]\n                                                    && storie.readedBy[b].readedDate\n                                                    && String(storie.readedBy[a].readedDate.low)\n                                                    && String(storie.readedBy[b].readedDate.low)\n                                                    && parseInt(storie.readedBy[a].readedDate.low) < parseInt(storie.readedBy[b].readedDate.low)\n                                                ) {\n                                                    return -1\n                                                } else if (storie\n                                                    && storie.readedBy[a]\n                                                    && storie.readedBy[a].readedDate\n                                                    && storie.readedBy[b]\n                                                    && storie.readedBy[b].readedDate\n                                                    && String(storie.readedBy[a].readedDate.low)\n                                                    && String(storie.readedBy[b].readedDate.low)\n                                                    && parseInt(storie.readedBy[a].readedDate.low) > parseInt(storie.readedBy[b].readedDate.low)\n                                                ) {\n                                                    return 1\n                                                } else {\n                                                    return 0\n                                                }\n                                            })\n                                            .map((a, i) => (\n                                                storie.user._id !== a && storie.readedBy && storie.readedBy[a] && storie.readedBy[a].name &&\n                                                <div key={a} style={{ position: \"relative\", display: \"flex\", alignItems: \"center\", }}>\n                                                    <Avatar alt={storie.readedBy[a].name} src={storie.readedBy[a].image || null} />\n                                                    <span style={{ paddingLeft: \"7px\" }}>\n                                                        {storie.readedBy[a].displayName ? storie.readedBy[a].displayName : storie.readedBy[a].name}{storie.readedBy[a].readedDate && storie.readedBy[a].readedDate.low && ` (${moment(storie.readedBy[a].readedDate.low * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")})`}\n                                                    </span>\n                                                </div>\n                                            ))}\n                                    </div>\n                                </React.Fragment>\n                            )\n                            }\n                        >\n                            <div>\n                                <Icon color={\"#FFFFFF\"} size=\"14px\" style={{ marginLeft: \"7px\" }}>done_all</Icon>\n                            </div>\n                        </Tooltip>\n                    }\n                    {!storie.deleted && storie._reactions && Object.keys(storie._reactions).length > 0 &&\n                        <div style={{\n                            display: \"flex\",\n                            alignItems: \"center\"\n                        }}>\n                            {storie && storie._reactions.like && Object.keys(storie._reactions.like).length > 0 &&\n                                <IconButton\n                                    icon={\"thumb_up\"}\n                                    iconColor={customApp(\"menu\")}\n                                    title={<React.Fragment>\n                                        <div className={classes.users}>\n                                            {Object.keys(storie._reactions.like)\n                                                .sort((a, b) => {\n                                                    if (\n                                                        storie._reactions.like[a].reactDate\n                                                        && String(storie._reactions.like[a].reactDate.low)\n                                                        && storie._reactions.like[b].reactDate\n                                                        && String(storie._reactions.like[b].reactDate.low)\n                                                        && parseInt(storie._reactions.like[a].reactDate.low) < parseInt(storie._reactions.like[b].reactDate.low)\n                                                    ) {\n                                                        return -1\n                                                    } else if (\n                                                        storie._reactions.like[a].reactDate\n                                                        && String(storie._reactions.like[a].reactDate.low)\n                                                        && storie._reactions.like[b].reactDate\n                                                        && String(storie._reactions.like[b].reactDate.low)\n                                                        && parseInt(storie._reactions.like[a].reactDate.low) > parseInt(storie._reactions.like[b].reactDate.low)\n                                                    ) {\n                                                        return 1\n                                                    } else {\n                                                        return 0\n                                                    }\n                                                })\n                                                .map((a, i) => {\n                                                    return (\n                                                        <div key={a} style={{ position: \"relative\", display: \"flex\", alignItems: \"center\", }}>\n                                                            <Avatar alt={storie._reactions.like[a].name} src={storie._reactions.like[a].image || defaultAvatar} />\n                                                            <span style={{ paddingLeft: \"7px\" }}>\n                                                                {storie._reactions.like[a].displayName ? storie._reactions.like[a].displayName : storie._reactions.like[a].name}{storie._reactions.like[a].reactDate && storie._reactions.like[a].reactDate.low && ` (${moment(storie._reactions.like[a].reactDate.low * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")})`}\n                                                            </span>\n                                                        </div>\n                                                    )\n                                                }\n                                                )}\n                                        </div>\n                                    </React.Fragment>}\n                                    style={{\n                                        fontSize: \"12px\",\n                                        margin: 0\n                                    }}\n                                />\n                            }\n                            {storie && storie._reactions && storie._reactions.nolike && Object.keys(storie._reactions.nolike).length > 0 &&\n                                <IconButton\n                                    icon={\"thumb_down\"}\n                                    iconColor={customApp(\"medium\")}\n                                    style={{\n                                        fontSize: \"12px\",\n                                        margin: 0\n                                    }}\n                                    title={<React.Fragment>\n                                        <div className={classes.users}>\n                                            {Object.keys(storie._reactions.nolike)\n                                                .sort((a, b) => {\n                                                    if (\n                                                        storie._reactions.nolike[a].reactDate\n                                                        && String(storie._reactions.nolike[a].reactDate.low)\n                                                        && storie._reactions.nolike[b].reactDate\n                                                        && String(storie._reactions.nolike[b].reactDate.low)\n                                                        && parseInt(storie._reactions.nolike[a].reactDate.low) < parseInt(storie._reactions.nolike[b].reactDate.low)\n                                                    ) {\n                                                        return -1\n                                                    } else if (\n                                                        storie._reactions.nolike[a].reactDate\n                                                        && String(storie._reactions.nolike[a].reactDate.low)\n                                                        && storie._reactions.nolike[b].reactDate\n                                                        && String(storie._reactions.nolike[b].reactDate.low)\n                                                        && parseInt(storie._reactions.nolike[a].reactDate.low) > parseInt(storie._reactions.nolike[b].reactDate.low)\n                                                    ) {\n                                                        return 1\n                                                    } else {\n                                                        return 0\n                                                    }\n                                                })\n                                                .map((a, i) => {\n                                                    return (\n                                                        <div key={a} style={{ position: \"relative\", display: \"flex\", alignItems: \"center\", }}>\n                                                            <Avatar alt={storie._reactions.nolike[a].name} src={storie._reactions.nolike[a].image || defaultAvatar} />\n                                                            <span style={{ paddingLeft: \"7px\" }}>\n                                                                {storie._reactions.nolike[a].displayName ? storie._reactions.nolike[a].displayName : storie._reactions.nolike[a].name}{storie._reactions.nolike[a].reactDate && storie._reactions.nolike[a].reactDate.low && ` (${moment(storie._reactions.nolike[a].reactDate.low * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")})`}\n                                                            </span>\n                                                        </div>\n                                                    )\n                                                }\n                                                )}\n                                        </div>\n                                    </React.Fragment>}\n                                />\n                            }\n                            {storie && storie._reactions && storie._reactions.love && Object.keys(storie._reactions.love).length > 0 &&\n                                <IconButton\n                                    icon={\"favorite\"}\n                                    iconColor={customApp(\"medium\")}\n                                    style={{\n                                        fontSize: \"12px\",\n                                        margin: 0\n                                    }}\n                                    title={<React.Fragment>\n                                        <div className={classes.users}>\n                                            {Object.keys(storie._reactions.love)\n                                                .sort((a, b) => {\n                                                    if (\n                                                        storie._reactions.love[a].reactDate\n                                                        && String(storie._reactions.love[a].reactDate.low)\n                                                        && storie._reactions.love[b].reactDate\n                                                        && String(storie._reactions.love[b].reactDate.low)\n                                                        && parseInt(storie._reactions.love[a].reactDate.low) < parseInt(storie._reactions.love[b].reactDate.low)\n                                                    ) {\n                                                        return -1\n                                                    } else if (\n                                                        storie._reactions.love[a].reactDate\n                                                        && String(storie._reactions.love[a].reactDate.low)\n                                                        && storie._reactions.love[b].reactDate\n                                                        && String(storie._reactions.love[b].reactDate.low)\n                                                        && parseInt(storie._reactions.love[a].reactDate.low) > parseInt(storie._reactions.love[b].reactDate.low)\n                                                    ) {\n                                                        return 1\n                                                    } else {\n                                                        return 0\n                                                    }\n                                                })\n                                                .map((a, i) => {\n                                                    return (\n                                                        <div key={a} style={{ position: \"relative\", display: \"flex\", alignItems: \"center\", }}>\n                                                            <Avatar alt={storie._reactions.love[a].name} src={storie._reactions.love[a].image || defaultAvatar} />\n                                                            <span style={{ paddingLeft: \"7px\" }}>\n                                                                {storie._reactions.love[a].displayName ? storie._reactions.love[a].displayName : storie._reactions.love[a].name}{storie._reactions.love[a].reactDate && storie._reactions.love[a].reactDate.low && ` (${moment(storie._reactions.love[a].reactDate.low * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")})`}\n                                                            </span>\n                                                        </div>\n                                                    )\n                                                }\n                                                )}\n                                        </div>\n                                    </React.Fragment>}\n                                />\n                            }\n                            {storie && storie._reactions && storie._reactions.approve && Object.keys(storie._reactions.approve).length > 0 &&\n                                <IconButton\n                                    icon=\"verified\"\n                                    iconColor={\"green\"}\n                                    style={{\n                                        fontSize: \"12px\",\n                                        margin: 0\n                                    }}\n                                    title={<React.Fragment>\n                                        <div className={classes.users}>\n                                            {Object.keys(storie._reactions.approve)\n                                                .sort((a, b) => {\n                                                    if (\n                                                        storie._reactions.approve[a].reactDate\n                                                        && String(storie._reactions.approve[a].reactDate.low)\n                                                        && storie._reactions.approve[b].reactDate\n                                                        && String(storie._reactions.approve[b].reactDate.low)\n                                                        && parseInt(storie._reactions.approve[a].reactDate.low) < parseInt(storie._reactions.approve[b].reactDate.low)\n                                                    ) {\n                                                        return -1\n                                                    } else if (\n                                                        storie._reactions.approve[a].reactDate\n                                                        && String(storie._reactions.approve[a].reactDate.low)\n                                                        && storie._reactions.approve[b].reactDate\n                                                        && String(storie._reactions.approve[b].reactDate.low)\n                                                        && parseInt(storie._reactions.approve[a].reactDate.low) > parseInt(storie._reactions.approve[b].reactDate.low)\n                                                    ) {\n                                                        return 1\n                                                    } else {\n                                                        return 0\n                                                    }\n                                                })\n                                                .map((a, i) => {\n                                                    return (\n                                                        <div key={a} style={{ position: \"relative\", display: \"flex\", alignItems: \"center\", }}>\n                                                            <Avatar alt={storie._reactions.approve[a].name} src={storie._reactions.approve[a].image || defaultAvatar} />\n                                                            <span style={{ paddingLeft: \"7px\" }}>\n                                                                {storie._reactions.approve[a].displayName ? storie._reactions.approve[a].displayName : storie._reactions.approve[a].name}{storie._reactions.approve[a].reactDate && storie._reactions.approve[a].reactDate.low && ` (${moment(storie._reactions.approve[a].reactDate.low * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")})`}\n                                                            </span>\n                                                        </div>\n                                                    )\n                                                }\n                                                )}\n                                        </div>\n                                    </React.Fragment>}\n                                />\n                            }\n                            {storie && storie._reactions && storie._reactions.attention && Object.keys(storie._reactions.attention).length > 0 &&\n                                <IconButton\n                                    icon=\"report_problem\"\n                                    iconColor={\"red\"}\n                                    style={{\n                                        fontSize: \"12px\",\n                                        margin: 0\n                                    }}\n                                    title={<React.Fragment>\n                                        <div className={classes.users}>\n                                            {Object.keys(storie._reactions.attention)\n                                                .sort((a, b) => {\n                                                    if (\n                                                        storie._reactions.attention[a].reactDate\n                                                        && String(storie._reactions.attention[a].reactDate.low)\n                                                        && storie._reactions.attention[b].reactDate\n                                                        && String(storie._reactions.attention[b].reactDate.low)\n                                                        && parseInt(storie._reactions.attention[a].reactDate.low) < parseInt(storie._reactions.attention[b].reactDate.low)\n                                                    ) {\n                                                        return -1\n                                                    } else if (\n                                                        storie._reactions.attention[a].reactDate\n                                                        && String(storie._reactions.attention[a].reactDate.low)\n                                                        && storie._reactions.attention[b].reactDate\n                                                        && String(storie._reactions.attention[b].reactDate.low)\n                                                        && parseInt(storie._reactions.attention[a].reactDate.low) > parseInt(storie._reactions.attention[b].reactDate.low)\n                                                    ) {\n                                                        return 1\n                                                    } else {\n                                                        return 0\n                                                    }\n                                                })\n                                                .map((a, i) => {\n                                                    return (\n                                                        <div key={a} style={{ position: \"relative\", display: \"flex\", alignItems: \"center\", }}>\n                                                            <Avatar alt={storie._reactions.attention[a].name} src={storie._reactions.attention[a].image || defaultAvatar} />\n                                                            <span style={{ paddingLeft: \"7px\" }}>\n                                                                {storie._reactions.attention[a].displayName ? storie._reactions.attention[a].displayName : storie._reactions.attention[a].name}{storie._reactions.attention[a].reactDate && storie._reactions.attention[a].reactDate.low && ` (${moment(storie._reactions.attention[a].reactDate.low * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")})`}\n                                                            </span>\n                                                        </div>\n                                                    )\n                                                }\n                                                )}\n                                            <div style={{ clear: \"both\" }}></div>\n                                        </div>\n                                    </React.Fragment>\n                                    }\n                                />\n                            }\n\n                        </div>\n                    }\n                    {!props.isReply &&\n                        <div style={{\n                            position: \"relative\",\n                            float: \"left\",\n                            marginLeft: \"7px\",\n                            marginRight: \"7px\"\n                        }}>\n\n                            {overOptions && !props.noReactions && !storie.deleted &&\n                                <div\n                                    style={{\n                                        display: \"flex\",\n                                        minWidth: \"fit-content\",\n                                        justifyContent: \"center\"\n                                    }}\n                                    onMouseOver={(e) => {\n                                        overOptionsHandle(true)\n                                    }\n                                    }\n                                    onMouseLeave={closeOptionsHandle}\n                                >\n                                    <Icon\n                                        icon={reaction && reaction === \"like\" ? \"thumb_up\" : \"thumb_up_off_alt\"}\n                                        iconColor={reaction && reaction === \"like\" ? customApp(\"menu\") : customApp(\"medium\")}\n                                        title={translate(\"$__like\", 1)}\n                                        size={\"18px\"}\n                                        onClick={() => {\n                                            reactThis(\"like\")\n                                        }}\n                                        onMouseLeave={closeOptionsHandle}\n                                    />\n                                    <Icon\n                                        icon={reaction && reaction === \"nolike\" ? \"thumb_down\" : \"thumb_down_off_alt\"}\n                                        title={translate(\"$__notlike\", 1)}\n                                        iconColor={reaction && reaction === \"nolike\" ? customApp(\"menu\") : customApp(\"medium\")}\n                                        size={\"18px\"}\n                                        onClick={() => {\n                                            reactThis(\"nolike\")\n                                        }}\n                                        onMouseLeave={closeOptionsHandle}\n                                    />\n                                    <Icon\n                                        icon={reaction && reaction === \"love\" ? \"favorite\" : \"favorite_border\"}\n                                        title={translate(\"$__love\", 1)}\n                                        iconColor={reaction && reaction === \"love\" ? customApp(\"menu\") : customApp(\"medium\")}\n                                        size={\"18px\"}\n                                        onClick={() => {\n                                            reactThis(\"love\")\n                                        }}\n                                        onMouseLeave={closeOptionsHandle}\n                                    />\n                                    <Icon\n                                        icon=\"verified\"\n                                        title={translate(\"$__approve\", 1)}\n                                        iconColor={reaction && reaction === \"approve\" ? \"green\" : customApp(\"medium\")}\n                                        size={\"18px\"}\n                                        onClick={() => {\n                                            reactThis(\"approve\")\n                                        }}\n                                        onMouseLeave={closeOptionsHandle}\n                                    />\n                                    <Icon\n                                        icon=\"report_problem\"\n                                        title={translate(\"$__attention\", 1)}\n                                        iconColor={reaction && reaction === \"attention\" ? \"red\" : customApp(\"medium\")}\n                                        size={\"18px\"}\n                                        onClick={() => {\n                                            reactThis(\"attention\")\n                                        }}\n                                        onMouseLeave={closeOptionsHandle}\n                                    />\n                                    {storie && storie.user && storie.user._id === session._id &&\n                                        <Icon\n                                            icon=\"forward\"\n                                            title={translate(\"$__forwardThisMessage\", 1)}\n                                            iconColor={\"deepskyblue\"}\n                                            size={\"18px\"}\n                                            onClick={() => {\n                                                setForward(true)\n                                            }}\n                                            onMouseLeave={closeOptionsHandle}\n                                        />\n                                    }\n                                    <Icon\n                                        icon=\"reply\"\n                                        title={translate(\"$__replyThisMessage\", 1)}\n                                        iconColor={\"deepskyblue\"}\n                                        size={\"18px\"}\n                                        onClick={() => {\n                                            props.reduxFunction(\"ASYNC\", \"SET_CHATS\", {\n                                                ...reduxStore.getState().chats,\n                                                drafts: {\n                                                    ...reduxStore.getState().chats.drafts || {},\n                                                    [props.nodeId]: {\n                                                        ...reduxStore.getState().chats.drafts && reduxStore.getState().chats.drafts[props.nodeId] ? reduxStore.getState().chats.drafts[props.nodeId] : {},\n                                                        reply: storie._id,\n                                                    }\n                                                }\n                                            })\n                                        }}\n                                        onMouseLeave={closeOptionsHandle}\n                                    />\n                                    {\n                                        (\n                                            !storie.deleted &&\n                                            storie.type === 'comment' &&\n                                            storie.user &&\n                                            storie.user._id &&\n                                            storie.user._id === session._id &&\n                                            parseInt(storie.created_at) > parseInt(moment().unix('x')) - 180\n                                        ) ?\n                                            <CustomButton\n                                                id={`chat_message_delete`}\n                                                title={translate(`$__delete`, \"*\")}\n                                                color={'red'}\n                                                icon={\"delete_forever\"}\n                                                onClick={() => { cancelConfirm() }}\n                                                size={\"18px\"}\n                                                transparent\n                                            />\n                                            :\n                                            <React.Fragment></React.Fragment>\n                                    }\n                                    <div style={{ clear: \"both\" }}></div>\n                                </div>\n                            }\n                            <div style={{ clear: \"both\" }}></div>\n                        </div>\n                    }\n                    <div style={{ clear: \"both\" }}></div>\n                </div>\n                <div style={{ clear: \"both\" }}></div>\n            </div >\n            {/* {console.log(storie)} */}\n            {forward ?\n                <Dialog\n                    fullWidth={true}\n                    // onClose={() => setEditor(false)} \n                    aria-labelledby=\"simple-dialog-title\"\n                    open={forward}\n                >\n                    <div className=\"forwardMessage\">\n                        <div style={{ position: \"relative\", marginLeft: \"10px\", marginTop: '5px', width: \"calc(100% - 10px)\" }}>\n                            <HeaderWithIcon\n                                title={translate(\"$__forwardMessage\", 1)}\n                                icon=\"forward\"\n                                onCancel={() => { setForward(false) }}\n                            />\n                        </div>\n                        <div style={{ padding: 15 }}>\n                            <SelectUsers\n                                hideSelected\n                                avatarSize=\"33px\"\n                                permission={props.permission}\n                                noLimit\n                                ignoreId={props.nodeId ? props.nodeId : props.storie.idRel ? props.storie.idRel : null}\n                                nodeId={props.nodeId}\n                                onSelect={(e) => {\n                                    setForwardToId(e)\n                                }}\n                            /></div>\n                        <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\", padding: \"15px\" }}>\n                            <CustomButton\n                                shadow\n                                title={translate(\"$__cancel\")}\n                                text={translate(\"$__cancel\")}\n                                color=\"lightgrey\"\n                                icon={\"close\"}\n                                size={\"25px\"}\n                                onClick={() => {\n                                    setForward(false)\n                                    setForwardToId(null)\n                                }}\n                            />\n                            {forwardToId &&\n                                <div style={{ marginLeft: \"15px\" }}>\n                                    <CustomButton\n                                        shadow\n                                        title={translate(\"$__forward\")}\n                                        text={translate(\"$__forward\")}\n                                        icon={\"forward\"}\n                                        size={\"25px\"}\n                                        load={saveLoading ? true : false}\n                                        onClick={() => {\n                                            setSaveLoading(true)\n                                            forwardMessage(props, {\n                                                ...storie,\n                                                _forwardToId: forwardToId\n                                            })\n\n\n                                            setTimeout(() => {\n                                                setForward(false)\n                                                setForwardToId(null)\n                                                props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                                                    ...reduxStore.getState().chat,\n                                                    db: 'users',\n                                                    nodeId: forwardToId[0],\n                                                    loading: false,\n                                                })\n                                                setSaveLoading(false)\n                                            }, 6000)\n                                        }}\n                                    />\n                                    <div style={{ clear: \"both\" }}></div>\n                                </div>\n                            }\n                            <div style={{ clear: \"both\" }}></div>\n                        </div>\n                        <div style={{ clear: \"both\" }}></div>\n                    </div>\n                </Dialog>\n                : <React.Fragment></React.Fragment>\n            }\n            <div style={{ clear: \"both\" }}></div>\n        </div >\n    )\n}\n//REACT\nconst mapStateToProps = () => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(memo(Message))","//CORE\nimport React from \"react\"\nimport Swipe from \"react-easy-swipe\"\nimport { PDFReader } from \"reactjs-pdf-reader\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport CircularProgress from \"@material-ui/core/CircularProgress\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\nimport Backdrop from \"@material-ui/core/Backdrop\"\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/LightBox.js\"\n\nfunction Component(props) {\n\n    const { classes } = props\n    const { db, lightBox } = reduxStore.getState()\n    const [mounted, setMounted] = React.useState(false);\n    const [loader, setLoader] = React.useState(false)\n    const [sideChange, setsideChange] = React.useState(false)\n    const [activeFile, setActiveFile] = React.useState(null)\n    const [path, setPath] = React.useState(null)\n    const [pdfLoader, setPDFLoader] = React.useState(true)\n    const [pdfScale, setPdfScale] = React.useState(0.5)\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true);\n            //window.addEventListener(\"keydown\", (e) => { interaction(e) }, false)\n        }\n    })\n\n    if (!reduxStore.getState().lightBox.miro && !reduxStore.getState().lightBox.miroBoard)\n        return <></>\n\n    const close = () => {\n        props.reduxFunction(\"ASYNC\", \"LIGHTBOX_CLOSE\")\n        //window.removeEventListener(\"keydown\", (e) => { interaction(e) }, false)\n    }\n\n\n    if (!reduxStore.getState().lightBox.miro && !reduxStore.getState().lightBox.miroBoard)\n        return null\n\n    return (\n        <Backdrop className={classes.backdrop} open={reduxStore.getState().lightBox.miro}>\n            <div className={classes.header}>\n                <div className={classes.btClose}>\n                    <Icon title={translate(\"$__close\", \"*\")} color={customApp(\"light\")} onClick={() => { close() }}>close</Icon>\n                </div>\n            </div>\n            <div className={classes.content} style={{ zIndex: 1000 }}>\n                {loader ?\n                    <div className={classes.loader}>\n                        <CircularProgress />\n                    </div>\n                    :\n                    <iframe\n                        style={{ position: \"absolute\", width: \"100%\", height: \"100%\" }}\n                        src={`https://miro.com/app/live-embed/${reduxStore.getState().lightBox.miroBoard}=/?embedAutoplay=true&moveToViewport=-23165,-5837,13803,7546`}\n                    ></iframe>\n\n                }\n            </div>\n        </Backdrop >\n    )\n}\n\n//REACT\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","// ID_CREATED*************************\r\n\r\n//CORE\r\nimport React from \"react\"\r\n\r\n//COMPONENTS\r\nimport CircularProgress from \"components/Progress/circular\"\r\nimport CustomButton from \"components/Buttons/custom\"\r\n\r\nimport {\r\n    translate,\r\n    customApp,\r\n} from \"functions/\"\r\n\r\nfunction Component(props) {\r\n    return (\r\n        <div\r\n            id={`sideModule_closeButton`}\r\n            style={{\r\n                position: \"fixed\",\r\n                display: \"inline-flex\",\r\n                paddingLeft: \"10px\",\r\n                top: \"7px\",\r\n                right: 0,\r\n                backgroundColor: \"#FFFFFF\",\r\n                ...props.style ? props.style : {},\r\n            }}>\r\n            {props.saveLoader &&\r\n                <React.Fragment>\r\n                    <CircularProgress size=\"25px\" />\r\n                </React.Fragment>\r\n            }\r\n            {!props.saveLoader &&\r\n                <React.Fragment>\r\n                    <div\r\n                        id={`sideModule_saveOptions`}\r\n                        style={{ display: \"flex\" }}\r\n                    >\r\n                        {props.save &&\r\n                            <CustomButton\r\n                                id={`sideModule_saveButton`}\r\n                                title={translate(`$__save`, 1)}\r\n                                color={customApp(\"color\")}\r\n                                icon={\"save\"}\r\n                                onClick={() => { props.save() }}\r\n                                size={\"25px\"}\r\n                            />\r\n                        }\r\n                        {props.saveClose &&\r\n                            <CustomButton\r\n                                id={`sideModule_saveAndCloseButton`}\r\n                                title={translate(`$__saveAndClose`, 1)}\r\n                                color=\"green\"\r\n                                icon={\"playlist_add_check\"}\r\n                                onClick={() => { props.saveClose() }}\r\n                                size={\"25px\"}\r\n                            />\r\n                        }\r\n                    </div>\r\n                    {props.close &&\r\n                        <CustomButton\r\n                            title={translate(`$__close`, 1)}\r\n                            color=\"lightgrey\"\r\n                            icon={\"cancel\"}\r\n                            onClick={() => {\r\n                                props.close()\r\n                            }}\r\n                            size={\"25px\"}\r\n                        />\r\n                    }\r\n                </React.Fragment>\r\n            }\r\n        </div>\r\n    )\r\n}\r\n\r\nexport default Component\r\n","import {\r\n  defaultFont,\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst headerStyle = () => ({\r\n  lock: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    height: '100vh',\r\n    zIndex: '3000 !important',\r\n  },\r\n  backdrop: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '440px',\r\n    bottom: '0px',\r\n    height: '100vh',\r\n    backgroundColor: 'rgba(0,0,0,0.7)',\r\n  },\r\n  module: {\r\n    ...defaultFont,\r\n    position: `absolute`,\r\n    right: `0px`,\r\n    top: `0px`,\r\n    bottom: `0px`,\r\n    // width: `440px`,\r\n    minWidth: \"500px\",\r\n    width: \"30%\",\r\n    zIndex: `1100`,\r\n    backgroundColor: `rgba(255,255,255,1)`\r\n  },\r\n  modulePopup: {\r\n    ...defaultFont,\r\n    width: '70vw',\r\n    position: 'absolute',\r\n    zIndex: '1100',\r\n    left: 'calc(50% - 35vw)',\r\n    backgroundColor: 'rgba(255,255,255,1)',\r\n    height: '80vh',\r\n    top: 'calc(50% - 40vh)',\r\n    boxShadow: '0px 0px 20px rgba(0,0,0,0.2)',\r\n    padding: '0px 5px',\r\n    border: 'solid 2px #ffffff',\r\n  },\r\n  moduleExpanded: {\r\n    ...defaultFont,\r\n    width: '90vw',\r\n    position: 'absolute',\r\n    zIndex: '1100',\r\n    left: 'calc(50% - 45vw)',\r\n    backgroundColor: 'rgba(255,255,255,1)',\r\n    height: '80vh',\r\n    bottom: '0px',\r\n    boxShadow: '0px 0px 20px rgba(0,0,0,0.2)',\r\n    padding: '0px 5px',\r\n    border: 'solid 2px #ffffff',\r\n  },\r\n  moduleFullScreen: {\r\n    ...defaultFont,\r\n    width: '100vw',\r\n    position: 'absolute',\r\n    zIndex: '1100',\r\n    left: '0px',\r\n    backgroundColor: 'rgba(255,255,255,1)',\r\n    height: '100vh',\r\n    bottom: '0px',\r\n    boxShadow: '0px 0px 20px rgba(0,0,0,0.2)',\r\n    padding: '0px 5px',\r\n    border: 'solid 2px #ffffff',\r\n  },\r\n  menu: {\r\n    position: `absolute`,\r\n    left: `0px`,\r\n    width: `45px`,\r\n    top: `0px`,\r\n    bottom: `0px`,\r\n    textAlign: `center`,\r\n  },\r\n  content: {\r\n    position: 'absolute',\r\n    top: '80px',\r\n    left: '45px',\r\n    bottom: '0px',\r\n    right: '0px',\r\n    padding: '0px',\r\n    overflowY: 'auto',\r\n    overflowX: 'hidden',\r\n    zIndex: 1\r\n  },\r\n  menuButtons_resume: {\r\n    margin: '0px auto 27px auto',\r\n    height: '40px'\r\n  },\r\n  MenuButton: {\r\n    margin: 'auto auto',\r\n    // padding: '7px',\r\n    cursor: 'pointer',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    justifyContent: 'center'\r\n  },\r\n  MenuButton_arrow: {\r\n    position: 'absolute',\r\n    right: '-8px',\r\n    fontSize: '16px',\r\n    transform: 'rotate(180deg)'\r\n  },\r\n  subTitle: {\r\n    position: `absolute`,\r\n    left: `45px`,\r\n    right: `0px`,\r\n    padding: `4px 10px`,\r\n    top: `47px`,\r\n    backgroundColor: customApp('color'),\r\n    color: customApp('light'),\r\n    // zIndex: 1\r\n  },\r\n});\r\n\r\nexport default headerStyle;\r\n","const styles = {\r\n    messagesContainer: {\r\n        height: \"100%\",\r\n        width: \"100%\",\r\n    }\r\n};\r\n\r\nexport default styles;\r\n","// MODULES\r\nimport React, { useEffect, useRef } from \"react\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store/\";\r\n\r\n// COMPONENTS\r\nimport { VariableSizeList as List } from \"react-window\";\r\nimport AutoSizer from \"react-virtualized-auto-sizer\";\r\nimport IconButton from \"components/CustomButtons/IconButton\";\r\n\r\n//DEPENDENCIES\r\nimport Message from \"./message\"\r\n\r\n// STYLES\r\nimport styles from \"./Messages.css.js\";\r\n\r\n//FUNCTIONS\r\nimport {\r\n    loadTimeline,\r\n    chatReaded,\r\n} from \"functions/chat\";\r\n\r\nconst VirtualListMessages = (props) => {\r\n    const { messages, type, nodeId } = props\r\n    const [loading, setLoading] = React.useState(false)\r\n    const [started, setStarted] = React.useState(false)\r\n\r\n    // References\r\n    const listRef = useRef({});\r\n    const loadRef = useRef({});\r\n    const rowHeights = useRef({});\r\n\r\n    useEffect(() => {\r\n        return () => {\r\n            setStarted(false)\r\n        }\r\n    }, [nodeId, type])\r\n\r\n    useEffect(() => {\r\n        if (messages.length > 0) {\r\n            if (\r\n                !started\r\n                || (loadRef?.current?.messagesLength && messages.length > loadRef.current.messagesLength)\r\n            ) {\r\n                loadRef.current = {\r\n                    ...loadRef.current,\r\n                    loading: false,\r\n                    messagesLength: messages.length,\r\n                    ...!started ? { length: messages.length } : {}\r\n                };\r\n                scrollToBottom();\r\n                setTimeout(() => {\r\n                    setLoading(false)\r\n                }, 1000)\r\n            }\r\n        }\r\n\r\n        clearMessages()\r\n\r\n        // eslint-disable-next-line\r\n    }, [messages, started]);\r\n\r\n    let unReadeds = messages.filter(msg => msg.type === type\r\n        && msg.user._id !== reduxStore.getState().session._id\r\n        && (\r\n            !msg.readedBy\r\n            || (\r\n                msg.readedBy\r\n                && !msg.readedBy[reduxStore.getState().session._id]\r\n            )\r\n        )).length\r\n\r\n    const clearMessages = async () => {\r\n        if (\r\n            started\r\n            && !(started.lock)\r\n            && loadRef?.current?.length\r\n            && unReadeds > 0) {\r\n\r\n            const { socket } = reduxStore.getState().functions\r\n            chatReaded(props, {\r\n                readedBy: reduxStore.getState().session._id,\r\n                id: nodeId,\r\n                db: props.db,\r\n                type: type\r\n            })\r\n\r\n            socket.emit(\"data\", {\r\n                module: \"chat\",\r\n                method: \"put\",\r\n                action: \"read\"\r\n            }, {\r\n                readedBy: reduxStore.getState().session._id,\r\n                id: nodeId,\r\n                db: props.db,\r\n                type: type\r\n            })\r\n\r\n            if (reduxStore.getState().chats.unreadeds[props.nodeId]) {\r\n                props.reduxFunction(\"ASYNC\", \"SET_CHATS\", {\r\n                    ...reduxStore.getState().chats,\r\n                    unreadeds: {\r\n                        ...reduxStore.getState().chats.unreadeds,\r\n                        [props.nodeId]: 0\r\n                    }\r\n                })\r\n            }\r\n        }\r\n    }\r\n\r\n    const loadMore = async () => {\r\n        const timelineDb = reduxStore.getState().db.users[props.nodeId] ? `users` : `cards`\r\n        if (!(loadRef?.current?.timelineEnd)) {\r\n\r\n            let lt = await loadTimeline(\r\n                {\r\n                    ...props,\r\n                    fnIdentification: \"Timeline/Index/scrollFunction()\"\r\n                },\r\n                {\r\n                    ids: [props.nodeId],\r\n                    db: timelineDb,\r\n                    type: \"comment\",\r\n                    limit: true,\r\n                    skip: messages.length\r\n                })\r\n\r\n            if (lt) {\r\n                let newRef = { ...loadRef.current, length: messages.length + lt.total };\r\n                if (lt.total < 20)\r\n                    newRef = { ...newRef, timelineEnd: true };\r\n                loadRef.current = { ...newRef };\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n\r\n    function getRowHeight(index) {\r\n        if (index === 4)\r\n            console.log(rowHeights.current[index])\r\n        return rowHeights.current[index] + 11 || 83;\r\n    }\r\n\r\n    function setRowHeight(index, size) {\r\n        rowHeights.current = { ...rowHeights.current, [index]: size };\r\n        if (listRef?.current?.resetAfterIndex) {\r\n            listRef.current.resetAfterIndex(0);\r\n        }\r\n    }\r\n\r\n    function Row({ index, style }) {\r\n        const data = messages[index]\r\n\r\n        return (\r\n            <div style={style}>\r\n                <Message\r\n                    storie={data}\r\n                    openLightBox={(e) => { props.openLightBox(e) }}\r\n                    hideCards={props.hideCards ? true : false}\r\n                    db={props.db}\r\n                    nodeId={props.nodeId}\r\n                    showUserName={reduxStore.getState().db?.cards[props.nodeId] ? true : false}\r\n                    onResize={(size) => {\r\n                        setRowHeight(index, size);\r\n                    }}\r\n                />\r\n            </div>\r\n        );\r\n    }\r\n\r\n\r\n\r\n    function scrollToBottom(force = false) {\r\n\r\n        let item = messages.length - 1\r\n        let position = \"end\"\r\n\r\n        let currentLength = loadRef.current.length || 0\r\n        let visibleStopIndex = loadRef?.current?.visibleStopIndex || 0\r\n\r\n\r\n        if (!force && started && loadRef?.current?.lock && loadRef?.current?.length) {\r\n            position = \"end\"\r\n            item = (messages.length - currentLength) + visibleStopIndex + 1\r\n        }\r\n\r\n        if (listRef?.current?.scrollToItem) {\r\n            listRef.current.scrollToItem(item, position);\r\n        } else {\r\n            setTimeout(() => {\r\n                scrollToBottom()\r\n            }, 100)\r\n        }\r\n    }\r\n\r\n    let timerLoad = setTimeout(() => { }, 15000)\r\n\r\n    const infinitLoadMore = (e, c) => {\r\n        let newRef = {\r\n            ...loadRef.current,\r\n            ...e,\r\n        }\r\n        if (!started && messages.length > 0 && e.visibleStopIndex + 1 === messages.length) {\r\n            setStarted(true)\r\n        }\r\n        if (started && e.visibleStopIndex < messages.length - 2 && messages.length > 10) {\r\n            newRef = {\r\n                ...newRef,\r\n                lock: true\r\n            }\r\n        }\r\n        if (started && e.visibleStopIndex + 1 === messages.length) {\r\n            newRef = {\r\n                ...newRef,\r\n                lock: false\r\n            }\r\n            setTimeout(() => {\r\n                clearMessages()\r\n            }, 100)\r\n        }\r\n\r\n        if (\r\n            started\r\n            && loadRef.current\r\n            && !loading\r\n            && !loadRef.current.loading\r\n            && e.visibleStartIndex < 10\r\n        ) {\r\n            clearTimeout(timerLoad)\r\n            setLoading(true)\r\n            newRef = {\r\n                ...newRef,\r\n                loading: true,\r\n                lock: true,\r\n            }\r\n            timerLoad = setTimeout(() => {\r\n                loadMore()\r\n            }, 1000)\r\n        } else if (\r\n            e.overscanStopIndex > messages.length - 10\r\n        ) {\r\n\r\n        }\r\n\r\n        loadRef.current = {\r\n            ...newRef\r\n        }\r\n    };\r\n\r\n    return (\r\n        <div style={styles.messagesContainer}>\r\n            <AutoSizer style={styles.messagesContainer}>\r\n                {({ height, width }) => (\r\n                    <List\r\n                        className=\"List\"\r\n                        height={height}\r\n                        itemCount={messages.length}\r\n                        itemSize={getRowHeight}\r\n                        ref={listRef}\r\n                        width={width}\r\n                        onItemsRendered={infinitLoadMore}\r\n                        overscanCount={15}\r\n\r\n                    >\r\n                        {Row}\r\n                    </List>\r\n                )}\r\n            </AutoSizer>\r\n            {unReadeds > 0 ?\r\n                <div\r\n                    style={{\r\n                        position: 'absolute',\r\n                        bottom: '33px',\r\n                        right: '15px',\r\n                        width: '33px',\r\n                        height: '33px',\r\n                    }}\r\n                >\r\n                    <IconButton\r\n                        icon=\"arrow_downward\"\r\n                        iconColor={'red'}\r\n                        size={'33px'}\r\n                        onClick={() => {\r\n                            scrollToBottom(true)\r\n                        }}\r\n                    />\r\n                </div>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n        </div>\r\n    )\r\n}\r\n\r\n\r\nconst mapStateToProps = () => ({})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch);\r\n\r\nexport default connect(\r\n    mapStateToProps,\r\n    mapDispatchToProps\r\n)(VirtualListMessages)","const style = {\r\n\r\n};\r\n\r\nexport default style;\r\n","import React from \"react\";\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport LinearProgress from \"components/Progress/linear\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\nimport Message from \"components/Timeline/message\";\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/search.js\";\n\nimport apims from \"apims/\";\n\nfunction SearchComponent(props) {\n  const [lastChange, setLastChange] = React.useState(\"\")\n  const [loader, setLoader] = React.useState(false)\n  const [filteredItems, setfilteredItems] = React.useState([]);\n  const { db, functions } = reduxStore.getState()\n  const { socket } = functions\n\n  let hashs = window.location.hash.split('/')\n  hashs[0] = hashs[0].replace('#', '')\n\n  React.useEffect(() => {\n    if (props.text.length > 1 && props.text !== lastChange) {\n      setLastChange(props.text)\n      const timer = setTimeout(() => searchMessages(), 1000);\n      setLoader(true)\n      return () => clearTimeout(timer);\n    }\n  }, [props.text])\n\n  const searchMessages = async () => {\n    try {\n      console.log({\n        text: props.text.trim(),\n        nodeId: props.nodeId,\n        db: props.db,\n        type: \"comment\"\n      })\n      let req = await apims.post(`/M_Timeline_Search`,\n        {\n          text: props.text.trim(),\n          nodeId: props.nodeId,\n          db: props.db,\n          type: \"comment\"\n        }\n      )\n      if (req && req.data) {\n        if (props.onFinish)\n          props.onFinish()\n        setfilteredItems(req.data)\n        setLoader(false)\n      }\n    } catch (e) {\n      console.log(\"COMPONENTS/TIMELINE/SEARCH/MESSAGES/SearchMessages():::\", e)\n    }\n  }\n\n  return (\n    <div\n      style={{ width: \"100%\", maxHeight: '70vh' }}\n    >\n      <div style={{ positin: 'relative', width: '100%' }}>\n        {loader &&\n          <div style={{ display: \"flex\", alignItems: \"center\" }}>\n            <LinearProgress />\n          </div>\n        }\n        <GridContainer>\n          {Object.keys(filteredItems).length > 0 &&\n            <GridItem\n              xs={12}\n              sm={12}\n              md={12}\n              lg={12}\n              xl={12}\n            >\n              {Object.keys(filteredItems)\n                .map((message, i) => {\n                  return (\n                    <div\n                      key={message}\n                      style={{ position: \"relative\", float: \"left\", width: 'calc(100% - 20px)', marginLeft: '10px', marginRight: '10px', marginBottom: '22px', clear: 'both' }}\n                    >\n                      <Message\n                        messageClick={props.onAction ? () => {\n                          // props.onAction(filteredItems[message])\n                        } : null}\n                        searchText={props.text.trim()}\n                        storie={filteredItems[message]}\n                        hideCards={props.hideCards ? true : false}\n                        db={props.db}\n                        nodeId={props.nodeId}\n                      />\n                    </div>\n                  )\n                })}\n            </GridItem>\n          }\n        </GridContainer>\n      </div>\n    </div >\n  );\n}\n\nconst mapStateToProps = (store, ownProps) => {\n  return {\n    store,\n    ownProps\n  }\n};\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch);\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(SearchComponent))","import React from \"react\"\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport CustomButton from \"components/Buttons/custom\"\nimport Icon from \"components/Icon\"\nimport LinearProgress from \"components/Progress/linear\"\nimport TextField from \"components/TextField\"\n\n//DEPENDENCIES\nimport SearchMessages from \"./messages\"\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/search.js\"\n\n//FUNCTIONS\nimport { removeSeats, translate, customApp } from \"functions/\"\n\n\nfunction SearchComponent(props) {\n  const { db } = reduxStore.getState()\n  const [searchValue, setSearchValue] = React.useState(\"\")\n  const [showText, setShowText] = React.useState(false)\n  const [loader, setLoader] = React.useState(false)\n\n  let hashs = window.location.hash.split('/')\n  hashs[0] = hashs[0].replace('#', '')\n\n  // return (<React.Fragment></React.Fragment>)\n\n\n  return (\n    <div style={{\n      position: 'relative',\n      zIndex: 10,\n      padding: 10,\n      backgroundColor: 'rgba(250,250,250,0.9)',\n      borderRadius: \"25px\"\n    }}>\n      {!showText ?\n        <CustomButton\n          title={translate(`$__search`, 1)}\n          color='grey'\n          icon={'search'}\n          onClick={(e) => {\n            setShowText(prev => !prev)\n          }}\n          transparent\n        />\n        :\n        <React.Fragment>\n          <TextField\n            label={translate(\"$__searchInChat\")}\n            variant={customApp(\"fieldVariant\")}\n            name={\"searchInChat\"}\n            InputLabelProps={{\n              shrink: true,\n            }}\n            InputProps={{\n              autoComplete: \"new-password\",\n              endAdornment: (\n                <InputAdornment position=\"end\">\n                  <Icon icon={\"close\"} color=\"lightgray\" onClick={() => {\n                    setSearchValue(\"\")\n                    setLoader(false)\n                    setShowText(false)\n                  }\n                  } />\n                </InputAdornment>\n              ),\n              onChange: (d, v) => {\n                setSearchValue(d.target.value)\n                setLoader(true)\n              },\n              onBlur: () => {\n                if (searchValue === \"\") {\n                  setSearchValue(\"\")\n                  setLoader(false)\n                  setShowText(false)\n                }\n              }\n            }}\n            placeholder={translate(\"$__searchInChat\")}\n            value={removeSeats(searchValue).toLowerCase()}\n            autoFocus\n          />\n\n        </React.Fragment>\n      }\n      {(searchValue !== \"\" && searchValue.length > 1 && loader) &&\n        <div style={{ position: \"absolute\", bottom: 0, left: \"7px\", right: \"7px\" }}>\n          <LinearProgress />\n        </div>\n      }\n      {searchValue !== \"\" && searchValue.length > 1 &&\n        <div style={{\n          position: \"absolute\",\n          top: \"50px\",\n          right: \"15px\",\n          backgroundColor: \"#FFFFFF\",\n          maxHeight: \"calc(100vh - 60px)\",\n          height: \"auto\",\n          overflow: \"hidden\",\n          overflowY: \"auto\",\n          boxShadow: \"0 3px 3px 3px rgba(0,0,0,0.1)\",\n          maxHeight: \"90vh\",\n          maxWidth: \"666px\",\n          zIndex: 2001,\n        }}>\n          <SearchMessages\n            nodeId={props.nodeId}\n            db={props.db}\n            text={searchValue}\n            onFinish={(e) => {\n              setLoader(false)\n            }}\n            onAction={(e) => {\n              if (props.onAction)\n                props.onAction(e)\n              setSearchValue(\"\")\n              setLoader(false)\n              setShowText(false)\n            }}\n          />\n        </div>\n      }\n    </div>\n  )\n}\n\nconst mapStateToProps = (store, ownProps) => {\n  return {\n    store,\n    ownProps\n  }\n}\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(SearchComponent))","import React, { memo } from \"react\";\nimport moment from \"moment\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport PreLoader from \"components/PreLoader\";\nimport IconButton from \"components/CustomButtons/IconButton\";\n\n//DEPENDENCIES\nimport Messages from \"./newMessages\";\nimport Search from \"./Search\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/timelineStyle.js\";\n\n//FUNCTIONS\nimport {\n  loadTimeline,\n} from \"functions/chat\";\n\nconst useStyles = makeStyles(styles)\n\nconst MessagesList = (props) => {\n  const classes = useStyles()\n  const { session } = reduxStore.getState()\n  const [preLoader, setPreLoader] = React.useState(false)\n\n  const { timeline } = props\n  const type = props.type || 'comment'\n\n  const data = props.nodeId ? reduxStore.getState().db[`${!props.db ? 'cards' : props.db}`][props.nodeId] : {};\n  const timelineDb = reduxStore.getState().db.users[props.nodeId] ? `users` : `cards`\n\n  let files = []; //USED IN LIGHTBOX\n\n  let stories = []\n  if (reduxStore.getState().db.cards[props.nodeId] && timeline[props.nodeId])\n    Object.keys(timeline[props.nodeId]).map(a => stories.push(timeline[props.nodeId][a]))\n\n  const reqStories = (parent) => {\n    Object.keys(reduxStore.getState().db.cards).filter(kc =>\n      reduxStore.getState().db.cards[kc]._parent === parent\n      && reduxStore.getState().db.cards[kc].kpi_useParent\n      && reduxStore.getState().db.cards[kc].kpi_type === reduxStore.getState().db.cards[parent].kpi_type)\n      .map(f => {\n        if (reduxStore.getState().timeline[f])\n          Object.keys(reduxStore.getState().timeline[f]).filter(x => reduxStore.getState().timeline[f][x].type === 'kpi' && !reduxStore.getState().timeline[f][x].deleted).map(x =>\n            stories.push(reduxStore.getState().timeline[f][x])\n          )\n        reqStories(f)\n      })\n  }\n\n  if (type === 'kpi')\n    reqStories(props.nodeId)\n\n  if (reduxStore.getState().db.users[props.nodeId]) {\n    if (timeline && timeline[session._id])\n      Object.keys(timeline[session._id])\n        .filter(a =>\n          timeline[session._id]\n          && timeline[session._id][a]\n          && timeline[session._id][a].user\n          && timeline[session._id][a].user._id === props.nodeId\n          && stories.filter(s => s._id === a).length === 0\n        )\n        .map(a => {\n          stories.push(timeline[session._id][a])\n        })\n\n    if (timeline && timeline[props.nodeId])\n      Object.keys(timeline[props.nodeId])\n        .filter(a =>\n          timeline[props.nodeId]\n        )\n        .map(a => {\n          stories.push(timeline[props.nodeId][a])\n        })\n\n    stories = Object.keys(stories)\n      .sort((a, b) => {\n        if (parseInt(stories[a].created_at) < parseInt(stories[b].created_at)) {\n          return -1\n        } else if (parseInt(stories[a].created_at) > parseInt(stories[b].created_at)) {\n          return 1\n        } else {\n          return 0\n        }\n      })\n      .filter(a =>\n        stories[a].user\n        && stories[a].user._id\n        && (\n          stories[a].user._id === session._id\n          ||\n          stories[a].user._id === props.nodeId\n        )\n      ).map(a => {\n        return stories[a]\n      })\n  }\n\n\n  if (props.kpi_type)\n    stories = Object.keys(stories).filter(a =>\n      (\n        stories[a].kpi_type === props.kpi_type\n      )\n      ||\n      (\n        stories[a].reply\n      )\n    ).map(a => {\n      return stories[a]\n    })\n\n\n  let balance = data && data.kpi_ini ? parseFloat(data.kpi_ini) : 0\n\n  React.useEffect(() => {\n    let isSubscribed = true\n    const init = async () => {\n      let type = props.type ? props.type : 'comment'\n      await loadTimeline(\n        {\n          ...props,\n          fnIdentification: \"Timeline/Index/init()\",\n          force: true\n        },\n        {\n          ids: props.nodeId,\n          db: timelineDb,\n          type: type,\n          ...props.type === \"kpi\" ? {\n            limit: false,\n            skip: false,\n            reqChildrens: true\n          } : {\n            limit: true,\n            skip: stories.filter(fil => fil.type === type).length > 0 ? stories.filter(fil => fil.type === type).length - 1 : 0,\n            reqChildrens: false\n          }\n        }\n      )\n      setPreLoader(false)\n    }\n    if (isSubscribed) {\n      if (stories.filter(a => a.type === type).length < 10) {\n        setPreLoader(true)\n        init()\n      }\n    }\n    return () => {\n      isSubscribed = false\n    }\n  }, [type, props.nodeId])\n\n\n\n\n\n  const openLightBox = (f) => {\n    props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n      open: true,\n      files: files,\n      file: f\n    })\n  }\n\n  const renderMessages = Object.keys(stories).length > 0\n    && Object.keys(stories)\n      .filter(a => {\n        if (\n          (\n            !stories[a].deleted ||\n            (\n              stories[a].deleted &&\n              stories[a].user &&\n              stories[a].user._id &&\n              stories[a].user._id === session._id\n            )\n          ) &&\n          (\n            (\n              stories[a].type === type\n            )\n            ||\n            (\n              stories[a].reply\n              && Object.keys(stories).filter(fil => stories[fil] && stories[fil]._id === stories[a].reply && stories[fil].type === type).length > 0\n            )\n          )\n        )\n          return true\n      })\n      .sort((a, b) => {\n        if (stories[a].created_at < stories[b].created_at) {\n          return -1\n        } else if (stories[a].created_at > stories[b].created_at) {\n          return 1\n        } else {\n          return 0\n        }\n      }\n      ).map((id) => {\n        let storie = stories[id]\n        balance = parseFloat(parseFloat(balance) + parseFloat(storie.value))\n        storie.balance = balance\n\n        if (storie.files && Object.keys(storie.files).length > 0)\n          Object.keys(storie.files).map((id, i) => {\n            let file = storie.files[id]\n            files.push(file)\n          })\n\n        return storie\n      })\n\n  return (\n    <div>\n      <div\n        className={classes.timeline}\n      >\n        <div\n          className={props.showHeader ? classes.timelineSimpleWithHeader : classes.timelineSimple\n          }\n          style={{ zIndex: 1 }}\n        >\n          {renderMessages && renderMessages.length > 0 ?\n            <Messages\n              messages={renderMessages}\n              hideCards={props.hideCards ? true : false}\n              db={props.db}\n              type={type}\n              nodeId={props.nodeId}\n              openLightBox={(e) => { openLightBox(e) }}\n            />\n            : <React.Fragment></React.Fragment>}\n          <div style={{ clear: 'both' }}></div>\n        </div>\n\n        {preLoader ?\n          <div\n            style={{\n              position: \"absolute\",\n              top: 0,\n              left: 0,\n              right: 0,\n              bottom: 0,\n              backgroundColor: \"rgba(250,250,250,0.7)\",\n              display: \"flex\",\n              justifyContent: \"center\",\n              alignItems: \"center\",\n              zIndex: 10\n            }}\n          >\n            <PreLoader />\n          </div>\n          : !props.noSearch ?\n            <div style={{ position: \"absolute\", top: 0, right: 0 }}>\n              <Search\n                db={timelineDb}\n                nodeId={props.nodeId}\n                onAction={(e) => {\n                  // goToMessage(e._id, true)\n                }}\n              />\n            </div>\n            : <React.Fragment></React.Fragment>\n        }\n      </div>\n    </div>\n  );\n}\n//REACT\nconst mapStateToProps = (store) => {\n  return {\n    timeline: store.timeline\n  }\n}\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n  mapStateToProps,\n  mapDispatchToProps\n)(MessagesList)","import React from \"react\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store/\";\r\n\r\n//COMPONENTS\r\nimport ErrorBoundary from \"components/ErrorBoundary\";\r\n\r\n//DEPENDENCIES\r\nimport SendingMessage from \"./sending\"\r\nimport Messages from \"./messages\"\r\n\r\n//FUNCTIONS\r\nimport {\r\n  customApp,\r\n  translate,\r\n} from \"functions/\";\r\n\r\n\r\nconst Timeline = (props) => {\r\n  const { nodeId } = props\r\n\r\n  const { session } = reduxStore.getState()\r\n\r\n  let timelineDb = reduxStore.getState().db.users[nodeId] ? `users` : `cards`\r\n\r\n  let disabledSending = props.disabledSend ? props.disabledSend : false\r\n  let userDeleted = true\r\n\r\n  if (nodeId\r\n    && props.disabledSend\r\n    && (\r\n      !reduxStore.getState().db.cards[nodeId]\r\n      || (\r\n        reduxStore.getState().db.cards[nodeId]\r\n        &&\r\n        (\r\n          reduxStore.getState().db.cards[nodeId].onlyAdminsSendMessages\r\n          && (\r\n            reduxStore.getState().db.cards[nodeId]._users\r\n            && reduxStore.getState().db.cards[nodeId]._users[session._id]\r\n            && reduxStore.getState().db.cards[nodeId]._users[session._id].access < 4\r\n          )\r\n        )\r\n      )\r\n    )) disabledSending = true\r\n\r\n  if (\r\n    (timelineDb === 'users'\r\n      && reduxStore.getState().db.users\r\n      && reduxStore.getState().db.users[nodeId]\r\n      && reduxStore.getState().db.users[nodeId].deleted\r\n    )\r\n  ) disabledSending = true\r\n\r\n  return (\r\n    <div style={{\r\n      position: 'absolute',\r\n      top: '0px',\r\n      left: '0px',\r\n      right: '0px',\r\n      bottom: '0px',\r\n      overflowY: 'auto'\r\n    }}>\r\n      <div\r\n        style={{\r\n          position: \"absolute\",\r\n          top: '0px',\r\n          left: '0px',\r\n          right: '0px',\r\n          bottom: disabledSending ? \"0px\" : \"70px\"\r\n        }}>\r\n        <ErrorBoundary>\r\n          <Messages {...props} />\r\n        </ErrorBoundary>\r\n      </div>\r\n      {!disabledSending ?\r\n        <ErrorBoundary>\r\n          <SendingMessage\r\n            db={!props.db ? 'cards' : props.db}\r\n            nodeId={nodeId}\r\n            editorStyle={{ padding: '7px' }}\r\n          />\r\n        </ErrorBoundary>\r\n        : reduxStore.getState().db.cards[nodeId] && reduxStore.getState().db.cards[nodeId].type === 'chatGroup' ?\r\n          <div style={{\r\n            position: \"absolute\",\r\n            alignItems: \"center\",\r\n            textAlign: \"center\",\r\n            bottom: 0,\r\n            left: 0,\r\n            right: 0,\r\n            padding: 15,\r\n            backgroundColor: \"linear-gradient(33deg, rgba(250, 250, 250, 1), rgba(240,240,240, 1))\",\r\n            justifyContent: \"center\",\r\n            fontSize: \"16px\",\r\n            fontWeight: \"bold\",\r\n            color: customApp(\"menu\")\r\n          }}>\r\n            {translate(\"$__onlyAdminsCanSendMessages\", 1)}\r\n          </div>\r\n          : <React.Fragment></React.Fragment>\r\n      }\r\n    </div>\r\n  );\r\n}\r\n//REACT\r\nconst mapStateToProps = () => ({})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n  bindActionCreators(reduxActions, dispatch);\r\n\r\nexport default connect(\r\n  mapStateToProps,\r\n  mapDispatchToProps\r\n)(Timeline)","//CORE\nimport React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\n\n//@MATERIAL\nimport Autocomplete from \"@material-ui/lab/Autocomplete\";\n\nimport api from \"api/\";\n//FUNCTIONS\nfunction Component(props) {\n    const changeGroups = async (d, v) => {\n        let newArray = v\n        let data = reduxStore.getState().db[props.dbNode]\n        if (props.ws) {\n            const validation = await newArray.map(async (r, i) => {\n                if (!r.value && props.dbNode && data.filter(a => (r && r.label && a.label === r.label) || (r && r === a.label)).length === 0) {\n                    let response = await api.post(props.api ? props.api : `node/add/${props.dbNode}`,\n                        { name: r.trim(), secondaryParent: props.secondaryParent ? props.secondaryParent : null })\n                    if (response) {\n                        // console.log(response)\n                        let id = response && response.data && response.data.id ? response.data.id : response.data.value\n                        if (data.filter(a => a.value === id).length === 0) {\n                            data.push({ value: id, label: r })\n                            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                                ...reduxStore.getState().db,\n                                [props.dbNode]: data\n                            });\n                        }\n                        if (newArray.filter(a => a.value === id).length === 0) {\n                            newArray.splice(i, 1)\n                            newArray.push({ value: id, label: r })\n                        }\n                    }\n                } else if (data.filter(a => (r && r.label && a.label === r.label) || (r && r === a.label)).length > 0) {\n                    let valueSelect = data.filter(a => (r && r.label && a.label === r.label) || (r && r === a.label))[0]\n                    if (valueSelect && newArray.filter(a => a.value === valueSelect.value).length === 0) {\n                        newArray.splice(i, 1)\n                        newArray.push({ value: valueSelect.value, label: valueSelect.label })\n                    }\n                }\n                var returnArray = [];\n                newArray.filter(a => {\n                    if (a && a.value)\n                        returnArray.push(a)\n                })\n                newArray = Array.from(returnArray)\n                return newArray\n            })\n            Promise.all(validation).then(() => {\n                if (props.onChange)\n                    props.onChange(d, newArray)\n            })\n        } else {\n            if (props.onChange)\n                props.onChange(d, newArray)\n        }\n    }\n    let autoCompleteProps = { ...props }\n    if (String(props.dbNode)) delete autoCompleteProps.dbNode\n    if (String(props.onChange)) delete autoCompleteProps.onChange\n    if (String(props.store)) delete autoCompleteProps.store\n    if (String(props.ownProps)) delete autoCompleteProps.ownProps\n    if (String(props.reduxFunction)) delete autoCompleteProps.reduxFunction\n    if (String(props.ws)) delete autoCompleteProps.ws\n    if (String(props.add)) delete autoCompleteProps.add\n    if (props.inNode || String(props.inNode) === 'undefined' || String(props.inNode) === 'null') delete autoCompleteProps.inNode\n    if (props.InputProps || String(props.InputProps) === 'undefined' || String(props.InputProps) === 'null') delete autoCompleteProps.InputProps\n    if (props.dark || String(props.dark) === 'undefined' || String(props.dark) === 'null') delete autoCompleteProps.dark\n    if (props.endAdornment || String(props.endAdornment) === 'undefined' || String(props.endAdornment) === 'null') delete autoCompleteProps.endAdornment\n    if (props.startAdornment || String(props.startAdornment) === 'undefined' || String(props.startAdornment) === 'null') delete autoCompleteProps.startAdornment\n    if (props.secondaryParent || String(props.secondaryParent) === 'undefined' || String(props.secondaryParent) === 'null') delete autoCompleteProps.secondaryParent\n\n    return (\n        <Autocomplete\n            {...autoCompleteProps}\n            onChange={\n                (d, v) => {\n                    changeGroups(d, v)\n                }\n            }\n        />\n    )\n}\n\nconst mapStateToProps = () => ({});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)","import React from \"react\";\nimport PropTypes from \"prop-types\";\n\n// @material-ui/core components\nimport Chip from '@material-ui/core/Chip';\nimport { withStyles } from \"@material-ui/core/styles\";\n\nconst CustomChip = withStyles((theme) => ({\n  root: {\n    border: 'none',\n    boxShadow: '0 3px 3px 3px rgba(0,0,0,0.05)',\n    '& .MuiIcon-root': {\n      color: 'rgba(250,250,250,0.33)'\n    },\n    '& .MuiIcon-root:hover': {\n      color: 'rgba(250,250,250,0.77)'\n    },\n    padding: 0\n  }\n}))(Chip);\n\nexport default function Component(props) {\n  const [over, setOver] = React.useState(false)\n  return (\n    <CustomChip\n      style={{\n        ...props.style ? props.style : {},\n        ...!over ? {\n          paddingLeft: 10,\n          paddingRight: 10\n        } : {}\n      }}\n      deleteIcon={props.deleteIcon ? props.deleteIcon : null}\n      label={props.label}\n      onMouseOver={() => { setOver(true) }}\n      onMouseLeave={() => { setOver(false) }}\n      onDelete={props.onDelete && over ? () => {\n        props.onDelete()\n      } : null}\n      onClick={props.onClick ? (e) => {\n        props.onDelete()\n      } : null}\n    />\n  );\n}\n\n\n","//@MATERIAL \nimport TextField from '@material-ui/core/TextField';\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\n//STYLES\nimport {\n    defaultFont,\n} from \"assets/jss/material-dashboard-pro-react.js\";\nconst Component = withStyles({\n    root: {\n        ...defaultFont,\n        padding: 0,\n        width: \"100%\",\n        marginTop: \"7px\",\n        marginBottom: \"7px\",\n        '& .invalid': {\n            borderBottom: 'solid 2px red !important',\n        },\n        '& .MuiOutlinedInput-input': {\n            padding: \"11px 11px\",\n            fontSize: \"12px\",\n            color: '#FFFFFF',\n        },\n        '& label': {\n            marginTop: \"-10px\",\n            fontSize: \"12px\",\n            color: customApp('color'), //customApp\n        },\n        '& label.MuiFormLabel-filled': {\n            color: customApp('color'), //customApp\n            marginTop: customApp('fieldVariant') === 'standard' ? \"-10px\" : customApp('fieldVariant') === 'filled' ? \"-10px\" : 0\n        },\n        '& label.Mui-focused': {\n            color: customApp('color'), //customApp\n            marginTop: customApp('fieldVariant') === 'standard' ? \"-10px\" : customApp('fieldVariant') === 'filled' ? \"-10px\" : 0\n        },\n        '& .MuiInput-underline:after': {\n            borderBottomColor: customApp('line'), //customApp\n        },\n        '& .MuiOutlinedInput-root': {\n            borderRadius: customApp('fieldRadius'),\n            '& fieldset': {\n                borderColor: customApp('line'), //customApp\n            },\n            '&.Mui-focused fieldset': {\n                borderColor: customApp('line'), //customApp\n            },\n        },\n        '& .MuiFilledInput-root': {\n            borderRadius: customApp('fieldRadius'),\n            '& fieldset': {\n                borderColor: customApp('line'), //customApp\n            },\n            '&::before': {\n                borderBottomColor: customApp('line')\n            },\n            '&::after': {\n                borderBottomColor: customApp('line')\n            },\n            '&.Mui-focused': {\n                borderBottomColor: customApp('line'), //customApp\n                '&::before': {\n                    borderBottomColor: customApp('line')\n                },\n                '&::after': {\n                    borderBottomColor: customApp('line')\n                },\n            },\n        },\n        '& .MuiInputLabel-outlined': {\n            marginTop: '0px',\n            // padding: \"15px\",\n            '&.Mui-focused': {\n                marginTop: '0px',\n            },\n            '&.MuiFormLabel-filled': {\n                marginTop: '0px',\n            }\n        },\n        '& .MuiInputBase-root': {\n            marginTop: customApp('fieldVariant') === 'standard' ? 0 : customApp('fieldVariant') === 'filled' ? \"-15px\" : 0,\n            borderRadius: customApp('fieldRadius'),\n            color: '#FFFFFF',\n            '& fieldset': {\n                borderColor: customApp('line'), //customApp\n            },\n            '&::before': {\n                borderBottomColor: customApp('line')\n            },\n            '&::after': {\n                borderBottomColor: customApp('line')\n            },\n            '&.Mui-focused': {\n                borderBottomColor: customApp('line'), //customApp\n                '&::before': {\n                    borderBottomColor: customApp('line')\n                },\n                '&::after': {\n                    borderBottomColor: customApp('line')\n                },\n            },\n        },\n    },\n})(TextField);\n\nexport default Component","import {\r\n    defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst textField = {\r\n    labelTop: {\r\n        ...defaultFont,\r\n        padding: \"0px\",\r\n        width: \"100%\",\r\n        marginTop: \"7px\",\r\n        marginBottom: \"7px\",\r\n        '& .invalid': {\r\n            borderBottom: 'solid 2px red !important',\r\n        },\r\n        '& .MuiOutlinedInput-input': {\r\n            padding: \"11px 11px\",\r\n            fontSize: \"12px\",\r\n            color: '#FFFFFF',\r\n        },\r\n        '& label': {\r\n            marginTop: \"-10px\",\r\n            fontSize: \"12px\",\r\n            color: customApp('color'), //customApp\r\n        },\r\n        '& label.MuiFormLabel-filled': {\r\n            color: customApp('color'), //customApp\r\n            marginTop: customApp('fieldVariant') === 'standard' ? \"-10px\" : customApp('fieldVariant') === 'filled' ? \"-10px\" : \"0px\"\r\n        },\r\n        '& label.Mui-focused': {\r\n            color: customApp('color'), //customApp\r\n            marginTop: customApp('fieldVariant') === 'standard' ? \"-10px\" : customApp('fieldVariant') === 'filled' ? \"-10px\" : \"0px\"\r\n        },\r\n        '& .MuiInput-underline:after': {\r\n            borderBottomColor: customApp('line'), //customApp\r\n        },\r\n        '& .MuiOutlinedInput-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&.Mui-focused fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n        },\r\n        '& .MuiFilledInput-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&::before': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&::after': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&.Mui-focused': {\r\n                borderBottomColor: customApp('line'), //customApp\r\n                '&::before': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n                '&::after': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n            },\r\n        },\r\n        '& .MuiInputLabel-outlined': {\r\n            marginTop: '0px',\r\n            // padding: \"15px\",\r\n            '&.Mui-focused': {\r\n                marginTop: '0px',\r\n            },\r\n            '&.MuiFormLabel-filled': {\r\n                marginTop: '0px',\r\n            }\r\n        },\r\n        '& .MuiInputBase-root': {\r\n            marginTop: customApp('fieldVariant') === 'standard' ? \"0px\" : customApp('fieldVariant') === 'filled' ? \"-15px\" : \"0px\",\r\n            borderRadius: customApp('fieldRadius'),\r\n            color: '#FFFFFF',\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&::before': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&::after': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&.Mui-focused': {\r\n                borderBottomColor: customApp('line'), //customApp\r\n                '&::before': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n                '&::after': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n            },\r\n        },\r\n    },\r\n    noLabel: {\r\n        ...defaultFont,\r\n        padding: \"0px\",\r\n        width: \"100%\",\r\n        marginTop: \"7px\",\r\n        marginBottom: \"7px\",\r\n        '& .invalid': {\r\n            borderBottom: 'solid 2px red !important',\r\n        },\r\n        '& .MuiOutlinedInput-input': {\r\n            padding: \"11px 11px\",\r\n            fontSize: \"12px\",\r\n            color: '#FFFFFF',\r\n        },\r\n        '& label': {\r\n            textAlign: \"right\",\r\n            fontSize: \"12px\",\r\n            color: customApp('color'), //customApp\r\n        },\r\n        '& label.MuiFormLabel-filled': {\r\n            display: 'none'\r\n        },\r\n        '& label.Mui-focused': {\r\n            display: 'none'\r\n        },\r\n        '& .MuiInput-underline:after': {\r\n            borderBottomColor: customApp('line'), //customApp\r\n        },\r\n        '& .MuiOutlinedInput-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&.Mui-focused fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n        },\r\n        '& .MuiFilledInput-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&::before': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&::after': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&.Mui-focused': {\r\n                borderBottomColor: customApp('line'), //customApp\r\n                '&::before': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n                '&::after': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n            },\r\n        },\r\n        '& .MuiInputLabel-outlined': {\r\n            display: 'none',\r\n            marginTop: '0px',\r\n            '&.Mui-focused': {\r\n                marginTop: '0px',\r\n            },\r\n            '&.MuiFormLabel-filled': {\r\n                marginTop: '0px',\r\n            }\r\n        },\r\n        '& .MuiInputBase-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            color: '#FFFFFF',\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&::before': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&::after': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&.Mui-focused': {\r\n                borderBottomColor: customApp('line'), //customApp\r\n                '&::before': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n                '&::after': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n            },\r\n        },\r\n    },\r\n    labelTopLight: {\r\n        ...defaultFont,\r\n        padding: \"0px\",\r\n        width: \"100%\",\r\n        marginTop: \"7px\",\r\n        marginBottom: \"7px\",\r\n        '& .invalid': {\r\n            borderBottom: 'solid 2px red !important',\r\n        },\r\n        '& .MuiOutlinedInput-input': {\r\n            padding: \"11px 11px\",\r\n            fontSize: \"12px\",\r\n            color: '#FFFFFF',\r\n        },\r\n        '& label': {\r\n            marginTop: \"-10px\",\r\n            fontSize: \"12px\",\r\n            color: customApp('color'), //customApp\r\n        },\r\n        '& label.MuiFormLabel-filled': {\r\n            color: customApp('color'), //customApp\r\n            marginTop: customApp('fieldVariant') === 'standard' ? \"-10px\" : customApp('fieldVariant') === 'filled' ? \"-10px\" : \"0px\"\r\n        },\r\n        '& label.Mui-focused': {\r\n            color: customApp('color'), //customApp\r\n            marginTop: customApp('fieldVariant') === 'standard' ? \"-10px\" : customApp('fieldVariant') === 'filled' ? \"-10px\" : \"0px\"\r\n        },\r\n        '& .MuiInput-underline:after': {\r\n            borderBottomColor: customApp('line'), //customApp\r\n        },\r\n        '& .MuiOutlinedInput-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&.Mui-focused fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n        },\r\n        '& .MuiFilledInput-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&::before': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&::after': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&.Mui-focused': {\r\n                borderBottomColor: customApp('line'), //customApp\r\n                '&::before': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n                '&::after': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n            },\r\n        },\r\n        '& .MuiInputLabel-outlined': {\r\n            marginTop: '0px',\r\n            // padding: \"15px\",\r\n            '&.Mui-focused': {\r\n                marginTop: '0px',\r\n            },\r\n            '&.MuiFormLabel-filled': {\r\n                marginTop: '0px',\r\n            }\r\n        },\r\n        '& .MuiInputBase-root': {\r\n            marginTop: customApp('fieldVariant') === 'standard' ? \"0px\" : customApp('fieldVariant') === 'filled' ? \"-15px\" : \"0px\",\r\n            borderRadius: customApp('fieldRadius'),\r\n            //color: '#FFFFFF',\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&::before': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&::after': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&.Mui-focused': {\r\n                borderBottomColor: customApp('line'), //customApp\r\n                '&::before': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n                '&::after': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n            },\r\n        },\r\n    },\r\n    noLabelLight: {\r\n        ...defaultFont,\r\n        padding: \"0px\",\r\n        width: \"100%\",\r\n        marginTop: \"7px\",\r\n        marginBottom: \"7px\",\r\n        '& .invalid': {\r\n            borderBottom: 'solid 2px red !important',\r\n        },\r\n        '& .MuiOutlinedInput-input': {\r\n            padding: \"11px 11px\",\r\n            fontSize: \"12px\",\r\n        },\r\n        '& label': {\r\n            textAlign: \"right\",\r\n            fontSize: \"12px\",\r\n            color: customApp('color'), //customApp\r\n        },\r\n        '& label.MuiFormLabel-filled': {\r\n            display: 'none'\r\n        },\r\n        '& label.Mui-focused': {\r\n            display: 'none'\r\n        },\r\n        '& .MuiInput-underline:after': {\r\n            borderBottomColor: customApp('line'), //customApp\r\n        },\r\n        '& .MuiOutlinedInput-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&.Mui-focused fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n        },\r\n        '& .MuiFilledInput-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&::before': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&::after': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&.Mui-focused': {\r\n                borderBottomColor: customApp('line'), //customApp\r\n                '&::before': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n                '&::after': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n            },\r\n        },\r\n        '& .MuiInputLabel-outlined': {\r\n            display: 'none',\r\n            marginTop: '0px',\r\n            '&.Mui-focused': {\r\n                marginTop: '0px',\r\n            },\r\n            '&.MuiFormLabel-filled': {\r\n                marginTop: '0px',\r\n            }\r\n        },\r\n        '& .MuiInputBase-root': {\r\n            borderRadius: customApp('fieldRadius'),\r\n            '& fieldset': {\r\n                borderColor: customApp('line'), //customApp\r\n            },\r\n            '&::before': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&::after': {\r\n                borderBottomColor: customApp('line')\r\n            },\r\n            '&.Mui-focused': {\r\n                borderBottomColor: customApp('line'), //customApp\r\n                '&::before': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n                '&::after': {\r\n                    borderBottomColor: customApp('line')\r\n                },\r\n            },\r\n        },\r\n    },\r\n};\r\n\r\nexport default textField;\r\n","//CORE\nimport React from \"react\";\n\n//@MATERIAL\nimport Autocomplete from \"./\";\nimport { withStyles, makeStyles } from \"@material-ui/core/styles\";\n\n//COMPONENTS\nimport Chip from 'components/Chip';\nimport TextField from \"components/TextField/index.js\";\nimport DarkTextField from \"components/TextField/dark.js\";\nimport ColorPicker from \"components/ColorPicker\";\nimport Icon from \"@material-ui/core/Icon\"\n\n//FUNCTIONS\nimport {\n    customApp,\n    textColor,\n    translate,\n} from \"functions/\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/TextField.js\";\n\nconst useStyles = makeStyles(styles);\n\nfunction Component(props) {\n    const classes = useStyles();\n    const [values, setValues] = React.useState([]);\n\n    React.useEffect(() => {\n        setValues(props.value)\n    }, [props.value])\n\n    const deleteThis = (dt) => {\n        let newValues = Array.from(values)\n        newValues.splice(newValues.findIndex(n => n.value === dt.value), 1)\n        setValues(newValues)\n        if (props.onChange)\n            props.onChange(newValues)\n    }\n\n    return (\n        <Autocomplete\n            className={props.dark ? props.noLabel ? classes.noLabel : classes.labelTop : props.noLabel ? classes.noLabelLight : classes.labelTopLight}\n            value={values}\n            options={props.options || []}\n            getOptionLabel={(option) => {\n                if (option && option.label) {\n                    return translate(option.label, 1)\n                } else {\n                    return ''\n                }\n            }}\n            name={`autoComplete_${props.name || ``}`}\n            style={{ width: \"100%\" }}\n            multiple={props.multiple || false}\n            limitTags={props.multiple ? props.limitTags ? props.limitTags : 2 : null}\n            freeSolo={props.freeSolo || false}\n            disableClearable={props.disableClearable || false}\n            disabled={props.disabled}\n            renderInput={(params) => {\n                return (\n                    !props.dark ?\n                        <TextField\n                            {...params}\n                            label={translate(props.placeholder || '$__values', '*')}\n                            variant={'standard'}\n                            InputProps={{\n                                ...params.InputProps,\n                                ...props.InputProps,\n                            }}\n                        />\n                        :\n                        <DarkTextField\n                            {...params}\n                            label={translate(props.placeholder || '$__values', '*')}\n                            variant={'standard'}\n                            InputProps={{\n                                ...params.InputProps,\n                                ...props.InputProps,\n                            }}\n                        />\n                )\n            }}\n            renderOption={(option) => {\n                return (\n                    <div style={{ zIndex: 3000, ...props.options.filter(a => a.value === option.parent)[0]?.color ? { paddingLeft: 7, borderLeft: `solid 3px ${props.options.filter(a => a.value === option.parent)[0]?.color}` } : {} }}>\n                        {option.parent && props.options.filter(a => a.value === option.parent).length > 0 ? <div style={{ fontSize: 10, color: `gray` }}>{props.options.filter(a => a.value === option.parent)[0].label}</div> : <React.Fragment></React.Fragment>}\n                        {option.label}\n                    </div>\n                )\n            }}\n            renderTags={(value, getTagProps) => {\n                return value.map((option, index) => (\n                    <div key={index}>\n                        {props.colorPicker && option && option.label ?\n                            <ColorPicker\n                                label={option && option.label ? option.label : null}\n                                color={option.color}\n                                _id={option.value}\n                                onChange={(c) => {\n                                    let newTag = option\n                                    newTag.color = c\n                                    if (props.colorPickerCallBack)\n                                        props.colorPickerCallBack(newTag)\n                                }}\n                            >\n                                <Chip\n                                    label={option && option.label ? option.label : null}\n                                    style={{\n                                        backgroundColor: option.color || '#b7b7b7',\n                                        boxShadow: '0 0 7px 3px rgba(0,0,0,0.05)',\n                                        color: textColor(option.color || \"#b7b7b7\", true)\n                                    }}\n                                    deleteIcon={<Icon\n                                        style={{\n                                            color: textColor(option.color || \"#b7b7b7\", true),\n                                            fontSize: \"20px\"\n                                        }}\n                                    >delete</Icon>}\n                                    onDelete={() => { deleteThis(option) }}\n                                />\n                            </ColorPicker>\n                            : option && option.label ?\n                                <Chip\n                                    label={option && option.label ? option.label : null}\n                                    style={{\n                                        backgroundColor: option.color || '#b7b7b7',\n                                        boxShadow: '0 0 7px 3px rgba(0,0,0,0.05)',\n                                        color: textColor(option.color || \"#b7b7b7\", true)\n                                    }}\n                                    deleteIcon={<Icon\n                                        style={{\n                                            color: textColor(option.color || \"#b7b7b7\", true),\n                                            fontSize: \"20px\"\n                                        }}\n                                    >delete</Icon>}\n                                    onDelete={() => { deleteThis(option) }}\n                                />\n                                : <React.Fragment></React.Fragment>\n                        }\n                    </div>\n                ))\n            }\n            }\n            onChange={\n                (d, v) => {\n                    if (props.onChange)\n                        props.onChange(v)\n                    let newValues = []\n                    if (props.multiple) {\n                        v.map(nv => {\n                            if (nv && nv.label) {\n                                newValues.push(nv)\n                            } else {\n                                newValues.push({\n                                    label: nv\n                                })\n                            }\n                        })\n                        setValues(newValues)\n                    } else {\n                        setValues(v)\n                    }\n                }\n            }\n            dbNode={props.dbNode ? props.dbNode : 'tag'}\n            add={props.add && props.add === true ? true : false}\n            inNode={props.inNode ? props.inNode : null}\n            secondaryParent={props.secondaryParent ? props.secondaryParent : null}\n            ws\n            api={props.api ? props.api : null}\n        />\n    )\n}\n\nexport default Component","const icons = {\r\n    instruction: {},\r\n    picture: {},\r\n};\r\n\r\nexport default icons;\r\n","//CORE\nimport React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\n//@MATERIAL\nimport Autocomplete from \"components/AutoComplete/multiple\";\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Tags-input.js\";\n\nfunction Component(props) {\n    const [values, setValues] = React.useState(props?.data?.values || [])\n\n    React.useEffect(() => {\n        if (props.data.values) {\n            let newValues = []\n            props.data.values.filter(d => d.value).map(d => {\n                newValues.push(d)\n            })\n            setValues(newValues)\n        }\n    }, [props.data])\n\n    const changeTags = async (v) => {\n        if (props.callBack)\n            props.callBack(v)\n        setValues(v)\n    }\n\n    return (\n        <div>\n            <Autocomplete\n                dbNode={props.dbNode ? props.dbNode : 'tag'}\n                secondaryParent={props.secondaryParent ? props.secondaryParent : null}\n                options={props.options ? props.options : []}\n                style={{ width: '100%' }}\n                name={props.name ? props.name : 'multInput'}\n                ws\n                add\n                colorPicker\n                multiple\n                freeSolo\n                disableClearable\n                disabled={props.disabled ? true : false}\n                value={values}\n                placeholder={props.placeholder || null}\n                onChange={\n                    (v) => {\n                        changeTags(v)\n                    }\n                }\n                colorPickerCallBack={(res) => {\n                    if (props.colorPickerCallBack)\n                        props.colorPickerCallBack(res)\n                }}\n            />\n        </div>\n    )\n}\n\n//REACT\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst headerStyle = theme => ({\r\n  btClose: {\r\n    position: 'relative',\r\n    zIndex: theme.zIndex.drawer + 1,\r\n    right: '0',\r\n    top: '-64px',\r\n    // backgroundColor: '#FFFFFF',\r\n    display: 'flex',\r\n  },\r\n  root: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    bottom: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    overflowX: 'auto'\r\n  },\r\n  image: {\r\n    width: '100%',\r\n    paddingTop: '48%',\r\n    backgroundPosition: 'center',\r\n    backgroundSize: 'cover',\r\n  },\r\n  data: {\r\n    marginTop: '10px',\r\n    padding: '10px',\r\n    overflowX: 'auto',\r\n    '& fieldset': {\r\n      border: 'solid 1px rgba(0,0,0,0.1)',\r\n      '& legend': {\r\n        marginBottom: '0px',\r\n        fontSize: '16px',\r\n        color: customApp('color')\r\n      }\r\n    }\r\n  },\r\n  switch: {\r\n    fontSize: '16px',\r\n    fontWeight: 'bold',\r\n    color: customApp('medium')\r\n  },\r\n  accessDescription: {\r\n    fontSize: '14px',\r\n    color: customApp('medium'),\r\n  },\r\n});\r\n\r\nexport default headerStyle;\r\n","// ID_CREATED*************************\n\n//CORE\nimport React, { useState, useEffect } from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport ImgCropper from \"components/Cropper\";\nimport TextField from \"components/TextField\";\nimport MultInput from \"components/MultInput/input\";\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\";\n\n//@MATERIAL\nimport Icon from \"components/Icon\";\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card.js\";\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n    validateEmail,\n    appAlert,\n    getAppAccess\n} from \"functions/\";\nimport { save, emailExist } from \"functions/users.js\";\n\nfunction Component(props) {\n    const { classes } = props;\n    const { sideModule, db, session } = reduxStore.getState()\n    const { users, dataType } = db\n    const { data } = sideModule\n    const [iniData, setIniData] = useState(data)\n    const [emailError, setEmailError] = React.useState(!validateEmail(data && data.email ? data.email : ''))\n    const AppAccess = getAppAccess()\n\n    const reqSave = JSON.stringify(iniData) !== JSON.stringify(data)\n\n    const changeData = (d) => {\n        let value = d.value\n        let newData = {\n            ...data,\n            [d.name]: value,\n        }\n        if (!value && newData[d.name])\n            delete newData[d.name]\n\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...sideModule,\n            data: newData\n        });\n\n    }\n\n    const close = (cl) => {\n        if (reqSave && !cl) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n        }\n    }\n    const saveUser = async (cl) => {\n        const exist = await emailExist(data.email)\n\n        if (\n            !data.name\n        ) {\n            appAlert({\n                message: translate('$__fillName', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n        } else if (\n            dataType.filter(a => a.name === data.type)[0].disabledFields.indexOf('email') === -1 &&\n            emailError\n        ) {\n            appAlert({\n                message: emailError,\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n        } else if (\n            dataType.filter(a => a.name === data.type)[0].disabledFields.indexOf('email') === -1 &&\n            (\n                !validateEmail(sideModule.data.email) ||\n                (\n                    users[data._id] &&\n                    data.email !== users[data._id].email &&\n                    exist\n                )\n            )\n        ) {\n            setEmailError(translate('$__invalidEmail', 1))\n        } else {\n            const reqSave = await save(props);\n            if (reqSave) {\n                appAlert({\n                    message: translate('$__userDataSaved', 1),\n                    variant: null,\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n                if (cl)\n                    close(true)\n            }\n        }\n    }\n\n    let permission = false\n    if (data._id === session._id ||\n        (AppAccess\n            &&\n            (\n                AppAccess.user\n                && (\n                    AppAccess.userAdmin\n                    || AppAccess.userEdit\n                )\n            )\n        ))\n        permission = true\n\n    // console.log(data)\n    // if (data.independentAccount)\n    //     permission = false\n\n\n\n    return (\n        <div>\n            <SideModuleCloseAndSave\n                save={permission && reqSave ? () => saveUser() : null}\n                saveClose={permission && reqSave ? () => saveUser(true) : null}\n                close={() => close(true)}\n            />\n            {(\n                permission\n                ||\n                (!permission && sideModule.data.image)\n            )}\n            <div\n                id={`sideModule_user_foto`}\n            >\n                <ImgCropper\n                    maxWidthOrHeight={600}\n                    img={\n                        sideModule.data &&\n                            sideModule.data.image ?\n                            sideModule.data.image :\n                            null\n                    }\n                    onChange={permission ? (a, file) => {\n                        changeData({ name: 'file', value: file })\n                    } : null}\n                    avatar\n                    avatarIcon={\n                        (\n                            !data.type ||\n                            data.type === 'user'\n                        ) ?\n                            'person' :\n                            (\n                                !data.type ||\n                                data.type === 'group'\n                            ) ?\n                                'groups' :\n                                'business'\n                    }\n                />\n            </div>\n            <form\n                className={classes.data}\n                autoComplete=\"off\"\n                id={`sideModule_user_data`}\n            >\n                <TextField\n                    id={`sideModule_user_fullName`}\n                    label={translate('$__fullName', 1)}\n                    variant={customApp('fieldVariant')}\n                    name={'fullName'}\n                    InputLabelProps={{\n                        shrink: true,\n                    }}\n                    InputProps={{\n                        autoComplete: 'new-password',\n                        endAdornment: (\n                            <InputAdornment position=\"end\">\n                                <Icon icon='person' />\n                            </InputAdornment>\n                        ),\n                        onChange: (d) => {\n                            changeData(d.target)\n                        },\n                        onBlur: (d) => {\n                            if (data && !data.name) {\n                                let name = d.target.value ? `${d.target.value.split(' ')[0]} ${d.target.value.split(' ')[1] ? d.target.value.split(' ')[1] : ''}` : \"\"\n                                changeData({\n                                    name: 'name',\n                                    value: name.trim()\n                                })\n                            }\n                        }\n                    }}\n                    value={data && data.fullName ? data.fullName : ''}\n                    placeholder={translate('$__fullName', 1)}\n                    autoFocus\n                    disabled={permission ? false : true}\n                />\n                <TextField\n                    id={`sideModule_user_displayName`}\n                    label={translate('$__displayName', 1)}\n                    variant={customApp('fieldVariant')}\n                    name=\"name\"\n                    InputProps={{\n                        autoComplete: 'new-password',\n                        multiline: true,\n                        endAdornment: (\n                            <InputAdornment position=\"end\">\n                                <Icon icon='view_comfy_ind' />\n                            </InputAdornment>\n                        ),\n                        onChange: (d) => {\n                            changeData(d.target)\n                        },\n                        onBlur: (d) => {\n                            changeData(d.target)\n                        }\n                    }}\n                    value={data && data.name ? data.name : ''}\n                    placeholder={translate('$__displayName', 1)}\n                    disabled={permission ? false : true}\n                />\n                {dataType.filter(a => a.name === data.type)[0].disabledFields.indexOf('email') === -1 &&\n                    <TextField\n                        id={`sideModule_user_email`}\n                        label={translate('$__email', 1)}\n                        variant={customApp('fieldVariant')}\n                        name=\"email\"\n                        type=\"email\"\n                        helperText={emailError}\n                        InputProps={{\n                            autoComplete: 'new-password',\n                            className: ((emailError || !data.email) || !validateEmail(data && data.email ? data.email : '')) ? \"invalid\" : \"\",\n                            endAdornment: (\n                                <InputAdornment position=\"end\">\n                                    <Icon icon='alternate_email' />\n                                </InputAdornment>\n                            ),\n                            onChange: (d) => {\n                                setEmailError(null)\n                                changeData(d.target)\n                            },\n                            onBlur: async (e) => {\n                                if ((data._id && data._id !== 'new' && users[data._id] && users[data._id].email !== e.target.value)\n                                    || (!data._id || data._id === 'new'))\n                                    if (validateEmail(e.target.value) && (!users[data._id] || e.target.value !== users[data._id].email)) {\n                                        const exist = await emailExist(e.target.value)\n                                        if (exist) {\n                                            setEmailError(translate('$__emailAlreadyExists', 1))\n                                        } else {\n                                            setEmailError(null)\n                                        }\n                                    } else {\n                                        setEmailError(translate('$__invalidEmail', 1))\n                                    }\n                            }\n                        }}\n                        value={data && data.email ? data.email : ''}\n                        placeholder={translate('$__email', 1)}\n                        disabled={!permission}\n                    />\n                }\n                {(\n                    permission &&\n                    (AppAccess\n                        &&\n                        (\n                            AppAccess.user\n                            && (\n                                AppAccess.userAdmin\n                                || AppAccess.userEdit\n                            )\n                        )\n                    )\n                )\n                    ?\n                    <React.Fragment>\n                        <fieldset\n                            style={{ marginBottom: '14px' }}\n                            id={`sideModule_user_tags`}\n                        >\n                            <MultInput\n                                data={{\n                                    values: data.tags || [],\n                                    _id: data._id,\n                                }}\n                                options={reduxStore.getState().db.tag ? reduxStore.getState().db.tag : []}\n                                placeholder={\"$__tagsPlaceholder\"}\n                                dbNode={\"tag\"}\n                                callBack={(v) => {\n                                    changeData({ name: 'tags', value: v })\n                                }}\n                                secondaryParent={data._parent}\n                                colorPickerCallBack={(res) => {\n                                    reduxStore.getState().functions.socket.emit('tag.UPD', res)\n                                }}\n                            />\n                        </fieldset>\n                        <fieldset\n                            style={{ marginBottom: '14px' }}\n                            id={`sideModule_user_group`}\n                        >\n                            <MultInput\n                                data={{\n                                    values: data.groups || [],\n                                    _id: data._id,\n                                }}\n                                options={reduxStore.getState().db.userGroup ? reduxStore.getState().db.userGroup : []}\n                                placeholder={\"$__userGroupPlaceholder\"}\n                                dbNode={\"userGroup\"}\n                                callBack={(v) => {\n                                    changeData({ name: 'groups', value: v })\n                                }}\n                                secondaryParent={data._parent}\n                                colorPickerCallBack={(res) => {\n                                    // reduxStore.getState().functions.socket.emit('userGroup.UPD', res)\n                                }}\n                            />\n                        </fieldset>\n                        {/* {dataType.filter(a => a.name === data.type)[0].hideFields.indexOf('independentAccount') === -1 ?\n                                <fieldset style={{ marginBottom: \"14px\" }}>\n                                    {reduxStore.getState().db.users[data._id].independentAccount ?\n                                        <div\n                                            style={{ color: \"gray\", fontSize: 11 }}\n                                        >\n                                            {translate(\"$__thisIsAIndependentAccountExplain\", 1)}\n                                        </div>\n                                        :\n                                        <React.Fragment>\n                                            <div className={classes.switch}>\n                                                <Switch\n                                                    checked={\n                                                        data.independentAccount\n                                                            ? true\n                                                            : false\n                                                    }\n                                                    onChange={(d) => {\n                                                        if (permission)\n                                                            changeData({\n                                                                name: \"independentAccount\",\n                                                                value: data.independentAccount ? false : true\n                                                            })\n                                                    }}\n                                                    name=\"independentAccount\"\n                                                    inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                                />\n                                                {translate(\"$__turnIntoIndependentAccount\", 1)}\n                                            </div>\n                                            <div\n                                                style={{ color: \"gray\", fontSize: 11 }}\n                                            >\n                                                {translate(\"$__turnIntoIndependentAccountExplain\", 1)}\n                                            </div>\n                                        </React.Fragment>\n                                    }\n                                </fieldset>\n                                : <React.Fragment></React.Fragment>} */}\n                    </React.Fragment>\n                    : <React.Fragment></React.Fragment>\n                }\n            </form>\n        </div>\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({\n    tag: store.db.tag,\n    userGroup: store.db.userGroup,\n    sideModule: store.sideModule\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","import React from \"react\";\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport TextField from \"components/TextField\";\n\n//FUNCTIONS\nimport { translate } from \"functions/\";\n\nexport default function LoginPage(props) {\n    const [user, setUser] = React.useState({ cPassword: '', password: '' });\n    const [confirmed, setConfirmed] = React.useState(false)\n    const [strength, setStrength] = React.useState(0)\n    const [clear, setClear] = React.useState(0)\n\n    React.useEffect(() => {\n        if (props.clear && props.clear !== clear) {\n            setClear(props.clear)\n            setUser({ cPassword: '', password: '' })\n            setConfirmed(false)\n        }\n    })\n\n    const calcPass = (password) => {\n        let matchedCase = [];\n        matchedCase.push(\"[$@$!%*#?&]\");\n        matchedCase.push(\"[A-Z]\");\n        matchedCase.push(\"[0-9]\");\n        matchedCase.push(\"[a-z]\");\n\n        let ctr = 0;\n        for (let i = 0; i < matchedCase.length; i++) {\n            if (new RegExp(matchedCase[i]).test(password)) {\n                ctr++;\n            }\n        }\n\n        switch (ctr) {\n            case 0:\n                setStrength(0)\n                break;\n            case 1:\n                setStrength(1)\n                break;\n            case 2:\n                setStrength(2)\n                break;\n            case 3:\n                setStrength(3)\n                break;\n            case 4:\n                setStrength(4)\n                break;\n            default:\n        }\n\n        if (password.length < 8) {\n            setStrength(0)\n        }\n    }\n\n    return (\n        <React.Fragment>\n            <div style={{ textAlign: 'left' }}>\n                <p>{translate('$__passwordTip_1')}</p>\n                <p>{translate('$__passwordTip_2')}</p>\n                <ul>\n                    <li>{translate('$__passwordTip_3')}</li>\n                    <li>{translate('$__passwordTip_4')}</li>\n                    <li>{translate('$__passwordTip_5')}</li>\n                    <li>{translate('$__passwordTip_6')}</li>\n                    <li>{translate('$__passwordTip_7')}</li>\n                </ul>\n            </div>\n            <TextField\n                label={translate('$__password', 1)}\n                variant={'standard'}\n                name={'password_primary'}\n                type={'password'}\n                InputLabelProps={{\n                    shrink: true,\n                }}\n                InputProps={{\n                    value: user.password,\n                    endAdornment: (\n                        <InputAdornment position=\"end\">\n                            <Icon>lock_outline</Icon>\n                        </InputAdornment>\n                    ),\n                    autoComplete: 'new-password',\n                    onChange: e => {\n                        setUser({\n                            ...user,\n                            password: e.target.value\n                        })\n                        calcPass(e.target.value)\n                        if (strength > 2 && user.password === e.target.value) {\n                            setConfirmed(true)\n                        } else {\n                            setConfirmed(false)\n                        }\n                    },\n                }}\n                value={user.password}\n            />\n            <TextField\n                label={translate('$__passwordConfirm', 1)}\n                variant={'standard'}\n                name={'password_secondary'}\n                type={'password'}\n                InputLabelProps={{\n                    shrink: true,\n                }}\n                InputProps={{\n                    value: user.cPassword,\n                    endAdornment: (\n                        <InputAdornment position=\"end\">\n                            <Icon color={confirmed ? \"green\" : \"lightgray\"}>\n                                {confirmed ? 'verified' : 'check'}\n                            </Icon>\n                        </InputAdornment>\n                    ),\n                    autoComplete: 'new-password',\n                    onChange: e => {\n                        setUser({\n                            ...user,\n                            cPassword: e.target.value\n                        })\n                        if (strength > 2 && user.password === e.target.value) {\n                            setConfirmed(true)\n                            props.onConfirmed(e.target.value)\n                        } else {\n                            setConfirmed(false)\n                            props.onConfirmed(null)\n                        }\n                    },\n                }}\n                value={user.cPassword}\n            />\n            {\n                user.password && strength > 0 &&\n                <div style={{\n                    position: 'relative',\n                    width: '100%',\n                    margin: 'auto',\n                    marginBottom: '7px',\n                    padding: '3px 0',\n                }}>\n                    {strength === 1 ?\n                        translate('$__passwordTooWeak', 1)\n                        : strength === 2 ?\n                            translate('weakPassword', 1)\n                            : strength === 3 ?\n                                translate('$__goodPassword', 1)\n                                : strength === 4 ?\n                                    translate('$__veryGoodPassword', 1)\n                                    : null\n                    }\n                </div>\n            }\n            {\n                user.password &&\n                <div style={{\n                    position: 'relative',\n                    width: '100%',\n                    margin: 'auto',\n                    height: '13px',\n                    padding: '3px 0',\n                    border: '1px solid rgba(0,0,0,0.1)'\n                }}>\n                    {strength >= 0 &&\n                        <div style={{\n                            position: 'relative',\n                            float: 'left',\n                            width: 'calc(20% - 6px)',\n                            height: '5px',\n                            backgroundColor: 'red',\n                            margin: '0 3px'\n                        }} />\n                    }\n                    {strength >= 1 &&\n                        <div style={{\n                            position: 'relative',\n                            float: 'left',\n                            width: 'calc(20% - 6px)',\n                            height: '5px',\n                            backgroundColor: 'rgb(129,153,179)',\n                            margin: '0 3px'\n                        }} />\n                    }\n                    {strength >= 2 &&\n                        <div style={{\n                            position: 'relative',\n                            float: 'left',\n                            width: 'calc(20% - 6px)',\n                            height: '5px',\n                            backgroundColor: 'rgb(95,151,254)',\n                            margin: '0 3px'\n                        }} />\n                    }\n                    {strength >= 3 &&\n                        <div style={{\n                            position: 'relative',\n                            float: 'left',\n                            width: 'calc(20% - 6px)',\n                            height: '5px',\n                            backgroundColor: 'rgb(42,66,255)',\n                            margin: '0 3px'\n                        }} />\n                    }\n                    {strength === 4 &&\n                        <div style={{\n                            position: 'relative',\n                            float: 'left',\n                            width: 'calc(20% - 6px)',\n                            height: '5px',\n                            backgroundColor: 'rgb(38,165,45)',\n                            margin: '0 3px'\n                        }} />\n                    }\n                </div>\n            }\n        </React.Fragment>\n    );\n}\n","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst headerStyle = theme => ({\r\n  btClose: {\r\n    position: 'relative',\r\n    zIndex: theme.zIndex.drawer + 1,\r\n    right: '0',\r\n    top: '-64px',\r\n    backgroundColor: '#FFFFFF',\r\n    display: 'flex',\r\n  },\r\n  image: {\r\n    width: '100%',\r\n    backgroundColor: 'rgb(0,88,0)',\r\n    paddingTop: '45%'\r\n  },\r\n  data: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    overflowY: 'auto',\r\n    marginTop: '10px',\r\n    padding: '10px'\r\n  },\r\n  switch: {\r\n    fontSize: '16px',\r\n    fontWeight: 'bold',\r\n    color: customApp('medium')\r\n  }\r\n});\r\n\r\nexport default headerStyle;\r\n","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport Password from \"components/Password\"\nimport Switch from \"components/Switch\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Users.js\"\n\n//FUNCTIONS\nimport api from \"api/\"\nimport {\n    customApp,\n    appAlert,\n    translate,\n    getAppAccess\n} from \"functions/\"\nimport { saveAccess } from \"functions/users.js\"\n\nfunction Component(props) {\n    const { classes } = props\n    const { sideModule, session, functions, db } = reduxStore.getState()\n    const { socket } = functions\n    const { data } = sideModule\n    const [iniData, setIniData] = React.useState(data)\n    const [reqSave, setReqSave] = React.useState(false)\n    const [newPass, setNewPass] = React.useState(null)\n    const [passClear, setPassClear] = React.useState(0)\n\n    const AppAccess = getAppAccess()\n\n    const changeData = (d) => {\n        setReqSave(true)\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...sideModule,\n            data: {\n                ...sideModule.data,\n                _access: {\n                    ...sideModule.data._access,\n                    [d.name]: d.value,\n                }\n            }\n        })\n        return true\n    }\n\n    const saveAdmin = (admin) => {\n        let newData = {\n            _id: data._id,\n            isAdmin: admin\n        }\n        try {\n            const { socket } = reduxStore.getState().functions\n            socket.emit(\"data\", {\n                module: \"user\",\n                method: \"post\",\n                action: \"save\"\n            }, newData, response => {\n                if (response.error) {\n                    console.log(\"companyDataError\", response.error)\n                } else {\n                    props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                        ...reduxStore.getState().session,\n                        GlobalData: {\n                            ...reduxStore.getState().session.GlobalData,\n                            ...newData\n                        }\n                    })\n                }\n            })\n        } catch (e) {\n            console.log(e)\n        }\n    }\n\n    const close = (force) => {\n        if (!force && reqSave) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n        }\n    }\n    const saveEdit = async (cl) => {\n        setReqSave(false)\n        const reqSave = await saveAccess(props)\n        if (reqSave) {\n            appAlert({\n                message: translate('$__userDataSaved', 1),\n                variant: null,\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n            saveAdmin(!data._access.admin ? true : null)\n            if (cl)\n                close(true)\n        }\n    }\n\n    const inviteUser = async () => {\n        socket.emit(\"data\", {\n            module: \"user\",\n            method: \"post\",\n            action: \"accessSendInvite\"\n        }, {\n            _id: reduxStore.getState().sideModule.data._id,\n            name: reduxStore.getState().sideModule.data.name,\n            email: reduxStore.getState().sideModule.data.email\n        }, () => {\n            appAlert({\n                message: translate('$__invitedEmailSended', 1),\n                variant: 'success',\n                persist: false,\n                horizontal: 'center',\n            })\n        })\n    }\n    const savePassword = async () => {\n        try {\n            const res = await api.post('/user/new-password', {\n                userId: data._id,\n                password: newPass,\n            })\n            if (res) {\n                setNewPass(null)\n                appAlert({\n                    message: translate('$__passwordChanged', 1),\n                    variant: null,\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n            }\n        } catch (err) {\n            appAlert({\n                message: `${translate('$__invalidRequest', 1)} | ${translate('$__contactSupport', 1)}`,\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n        }\n        setPassClear(passClear + 1)\n    }\n\n    let space = db.plans[0].settings.space\n    let subscriptionPlan = db.plans[0]\n    if (\n        session\n        && session.GlobalData\n        && String(session.GlobalData.plan)\n        && db.plans.filter(a => a.value === session.GlobalData.plan).length > 0\n        && db.plans.filter(a => a.value === session.GlobalData.plan)[0].settings\n    ) {\n        space = db.plans.filter(a => a.value === session.GlobalData.plan)[0].settings.space\n        subscriptionPlan = db.plans.filter(a => a.value === session.GlobalData.plan)[0]\n    }\n\n    let adminLimit = 1\n    if (subscriptionPlan && subscriptionPlan.settings && subscriptionPlan.settings.admins)\n        adminLimit = parseInt(subscriptionPlan.settings.admins)\n\n    if (session && session.GlobalData && session.GlobalData.customAdmins)\n        adminLimit = parseInt(session.GlobalData.customAdmins)\n\n    let adminUsers = Object.keys(db.users).filter(uid =>\n        db.users[uid]\n        && uid !== data._id\n        && db.users[uid]._access\n        && db.users[uid]._access.admin\n        && (\n            !db.users[uid]._parent\n            || (\n                db.users[uid]._parent\n                && db.users[db.users[uid]._parent]\n                && !db.users[db.users[uid]._parent].independentAccount\n            )\n        )\n    ).length || 0\n\n    if ((data._access && data._access.owner && session._id !== data._id) || session._id === data._id)\n        return (\n            <div>\n                <SideModuleCloseAndSave\n                    save={reqSave ? () => saveEdit() : null}\n                    saveClose={reqSave ? () => saveEdit(true) : null}\n                    close={() => close(true)}\n                />\n                <div style={{\n                    position: \"relative\",\n                    width: \"100%\",\n                    textAlign: \"center\",\n                    padding: '15px',\n                }}>\n                    <div\n                        style={{\n                            position: 'relative',\n                            width: '100%',\n                        }}\n                    >\n                        <Password onConfirmed={(v) => { setNewPass(v) }} clear={passClear} />\n                    </div>\n                    {newPass &&\n                        <div\n                            style={{\n                                display: 'flex',\n                                padding: '7px 15px',\n                                margin: 'auto',\n                                cursor: 'pointer',\n                                backgroundColor: 'green',\n                                marginTop: '15px',\n                                display: 'flex',\n                                alignItems: 'center',\n                                justifyContent: 'center',\n                                borderRadius: '7px'\n                            }}\n                            onClick={() => {\n                                savePassword()\n                            }}\n                        >\n                            <IconButton\n                                icon=\"save\"\n                                text={translate(\"$__save\", '*')}\n                                title={!translate(\"$__save\", '*')}\n                                iconColor={customApp('lightText')}\n                                textColor={customApp('lightText')}\n\n                            />\n                        </div>\n                    }\n                </div>\n            </div>\n        )\n\n    console.log(adminLimit, adminUsers)\n    return (\n        <div>\n            <SideModuleCloseAndSave\n                save={reqSave ? () => saveEdit() : null}\n                saveClose={reqSave ? () => saveEdit(true) : null}\n                close={() => close(true)}\n            />\n            <div className={classes.data}>\n                <fieldset>\n                    <div className={classes.switch}>\n                        <Switch\n                            checked={data._access && data._access.enabled ? true : false}\n                            onChange={(d) => {\n                                changeData({\n                                    name: 'enabled',\n                                    value: data._access && data._access.enabled ? false : true\n                                })\n                            }}\n                            name=\"checkedA\"\n                            inputProps={{ 'aria-label': 'secondary checkbox' }}\n                        />\n                        {translate('$__permitPlataformAccess', 1)}\n                    </div>\n                    <div className={classes.accessDescription}>\n                        <i>{translate('$__userAccess_PlataformAccessDescription', 1)}</i>\n                    </div>\n                </fieldset>\n                {data._access && data._access === 'owner' ?\n                    <fieldset>\n                        <div className={classes.accessDescription}>\n                            <i> {translate('$__youAreAccountOwner', 1)}</i>\n                        </div>\n                    </fieldset>\n                    : (adminUsers < adminLimit || (data && data._access && data._access.admin)) ?\n                        <React.Fragment>\n                            <fieldset\n                                style={{\n                                    // position: \"relative\",\n                                    // padding: 7,\n                                    // border: \"solid 1px rgba(0,0,0,0.5)\",\n                                    display: \"flex\"\n                                }}\n                            >\n                                <div style={{\n                                    // backgroundColor: \"rgba(0,0,0,0.1)\",\n                                    padding: 7,\n                                    width: \"calc(50% - 4px)\",\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                    justifyContent: \"center\",\n                                    cursor: \"pointer\",\n                                    backgroundColor: data && data._access && data._access.admin ? \"rgba(0,0,0,0.07)\" : customApp(\"color\"),\n                                    color: data && data._access && data._access.admin ? \"gray\" : \"#FFFFFF\"\n                                }}>\n                                    <div\n                                        style={{\n                                            display: \"flex\",\n                                            flexDirection: \"column\",\n                                            justifyContent: \"center\",\n                                            alignItems: \"center\"\n                                        }}\n                                        onClick={() => {\n                                            changeData({\n                                                name: 'admin',\n                                                value: false\n                                            })\n                                        }}\n                                    >\n                                        <Icon\n                                            icon={\"supervised_user_circle\"}\n                                            size={\"33px\"}\n                                            color={data && data._access && data._access.admin ? null : \"#FFFFFF\"}\n                                        />\n                                        {translate(\"$__guest\")}\n                                    </div>\n                                </div>\n                                <div\n                                    style={{\n                                        padding: 7,\n                                        marginLeft: 7,\n                                        width: \"calc(50% - 4px)\",\n                                        cursor: \"pointer\",\n                                        backgroundColor: data && data._access && data._access.admin ? customApp(\"color\") : \"rgba(0,0,0,0.07)\",\n                                        color: data && data._access && data._access.admin ? \"#FFFFFF\" : \"gray\"\n                                    }}\n                                >\n                                    <div\n                                        style={{\n                                            display: \"flex\",\n                                            flexDirection: \"column\",\n                                            justifyContent: \"center\",\n                                            alignItems: \"center\",\n\n                                        }}\n                                        onClick={() => {\n                                            changeData({\n                                                name: 'admin',\n                                                value: true\n                                            })\n                                        }}\n                                    >\n                                        <Icon\n                                            icon={\"supervisor_account\"}\n                                            size={\"33px\"}\n                                            color={data && data._access && data._access.admin ? \"#FFFFFF\" : null}\n\n                                        />\n                                        {translate(\"$__supervisorAccount\")}\n                                    </div>\n                                </div>\n                            </fieldset>\n                            <fieldset>\n                                <div className={classes.accessDescription}>\n                                    <i>{translate(data && data._access && data._access.admin ? '$__adminAccess_PlataformDescription' : '$__guestAccess_PlataformDescription', 1)}</i>\n                                </div>\n                            </fieldset>\n                        </React.Fragment>\n                        :\n                        <React.Fragment>\n                            <fieldset>\n                                <legend>{translate(\"$__adminLimitReached\")}</legend>\n                                <div className={classes.accessDescription}>\n                                    <i>{translate('$__adminLimitReachedDescription', 1)}</i>\n                                    <div\n                                        style={{\n                                            position: \"relative\",\n                                            marginTop: 7,\n                                            color: \"red\",\n                                            fontWeight: \"bolder\"\n                                        }}>{translate(\"$__usedUsers\", \"*\")} {adminUsers} {translate(\"$__of\", \"*\")} {adminLimit}<span style={{ marginLeft: 15, color: \"red\", fontSize: 11, cursor: \"pointer\" }} onClick={() => {\n                                            history.push(\"acc#tab/subscriptionUpgrade\")\n                                        }}>{translate(\"$__upgradeSubscription\")}</span>\n                                    </div>\n                                </div>\n                            </fieldset>\n                        </React.Fragment>\n                }\n                {data._access && data._access.enabled && data._access.admin &&\n                    <React.Fragment>\n                        <React.Fragment>\n                            {data._token &&\n                                < fieldset style={{ backgroundColor: 'rgba(255,0,0,0.1)' }}>\n                                    <i>{translate('$__unregisteredUserAlert', 1)}</i>\n                                    <IconButton text={translate(\"$__sendInviteEmail\", 1)} icon=\"contact_mail\"\n                                        onClick={() => {\n                                            inviteUser()\n                                        }}\n                                    />\n                                </fieldset>\n                            }\n                            {data._token && data._token._id &&\n                                <fieldset style={{ backgroundColor: 'rgba(255,0,0,0.1)' }}>\n                                    <i>{translate('$__urlToActivate', 1)}</i>\n                                    <input\n                                        type=\"text\"\n                                        value={`${String(process.env.REACT_APP_PROD) === 'true' ? 'https://software.machen.ai' : 'http://localhost:3000'}/activate?token=${data._token._id}`}\n                                        onClick={(e) => {\n                                            e.target.select()\n                                        }}\n                                        onChange={(e) => {\n                                            console.log('a')\n                                        }}\n                                    />\n                                </fieldset>\n                            }\n                        </React.Fragment>\n                        <fieldset>\n                            <legend>\n                                <Switch\n                                    checked={data._access && data._access.user ? true : false}\n                                    onChange={(d) => {\n                                        changeData({\n                                            name: 'user',\n                                            value: data._access && data._access.user ? false : true\n                                        })\n                                    }}\n                                    name=\"checkedA\"\n                                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                />\n                                {translate('$__users', 1)}\n                            </legend>\n                            {!data._access || (data._access && (!data._access.user || data._access.user === false)) ?\n                                <div className={classes.accessDescription}>\n                                    <i>{translate('$__userAccess_UserAccessDescription', 1)}</i>\n                                </div>\n                                :\n                                <React.Fragment>\n                                    {!data._access.userAdmin &&\n                                        <React.Fragment>\n                                            <div className={classes.switch}>\n                                                <Switch\n                                                    checked={data._access && (data._access.userRead) ? true : false}\n                                                    onChange={(d) => {\n                                                        changeData({\n                                                            name: 'userRead',\n                                                            value: data._access && data._access.userRead ? false : true\n                                                        })\n                                                    }}\n                                                    name=\"checkedA\"\n                                                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                                />\n                                                {translate('$__read', 1)}\n                                            </div>\n                                            <div className={classes.switch}>\n                                                <Switch\n                                                    checked={data._access && data._access.userInteract ? true : false}\n                                                    onChange={(d) => {\n                                                        changeData({\n                                                            name: 'userInteract',\n                                                            value: data._access && data._access.userInteract ? false : true\n                                                        })\n                                                    }}\n                                                    name=\"checkedA\"\n                                                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                                />\n                                                {translate('$__interact', 1)}\n                                            </div>\n                                            <div className={classes.switch}>\n                                                <Switch\n                                                    checked={data._access && data._access.userEdit ? true : false}\n                                                    onChange={(d) => {\n                                                        changeData({\n                                                            name: 'userEdit',\n                                                            value: data._access && data._access.userEdit ? false : true\n                                                        })\n                                                    }}\n                                                    name=\"checkedA\"\n                                                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                                />\n                                                {translate('$__edit', 1)}\n                                            </div>\n                                        </React.Fragment>\n                                    }\n                                    <div className={classes.switch}>\n                                        <Switch\n                                            checked={data._access && data._access.userAdmin ? true : false}\n                                            onChange={(d) => {\n                                                changeData({\n                                                    name: 'userAdmin',\n                                                    value: data._access && data._access.userAdmin ? false : true\n                                                })\n                                            }}\n                                            name=\"checkeduserAdmin\"\n                                            inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                        />\n                                        {translate('$__admin', 1)}\n                                    </div>\n                                </React.Fragment>\n                            }\n                        </fieldset>\n\n                        <fieldset>\n                            <legend>\n                                <Switch\n                                    checked={data._access && data._access.plan ? true : false}\n                                    onChange={(d) => {\n                                        changeData({\n                                            name: 'plan',\n                                            value: data._access && data._access.plan ? false : true\n                                        })\n                                    }}\n                                    name=\"checkedA\"\n                                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                />\n                                {translate('$__plan', 1)}\n                            </legend>\n                            {!data._access || (data._access && (!data._access.plan || data._access.plan === false)) ?\n                                <div className={classes.accessDescription}>\n                                    <i>{translate('$__userAccess_StrategyAndPlansAccessDescription')}</i>\n                                </div>\n                                :\n                                <React.Fragment>\n                                    {!data._access.planAdmin &&\n                                        <React.Fragment>\n\n                                            <div className={classes.switch}>\n                                                <Switch\n                                                    checked={data._access && data._access.planRead ? true : false}\n                                                    onChange={(d) => {\n                                                        changeData({\n                                                            name: 'planRead',\n                                                            value: data._access && data._access.planRead ? false : true\n                                                        })\n                                                    }}\n                                                    name=\"checkedA\"\n                                                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                                />\n                                                {translate('$__read', 1)}\n                                            </div>\n                                            <div className={classes.switch}>\n                                                <Switch\n                                                    checked={data._access && data._access.planEdit ? true : false}\n                                                    onChange={(d) => {\n                                                        changeData({\n                                                            name: 'planEdit',\n                                                            value: data._access && data._access.planEdit ? false : true\n                                                        })\n                                                    }}\n                                                    name=\"checkedA\"\n                                                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                                />\n                                                {translate('$__edit', 1)}\n                                            </div>\n                                            <div className={classes.switch}>\n                                                <Switch\n                                                    checked={data._access && data._access.createTemplate ? true : false}\n                                                    onChange={(d) => {\n                                                        changeData({\n                                                            name: 'createTemplate',\n                                                            value: data._access && data._access.createTemplate ? false : true\n                                                        })\n                                                    }}\n                                                    name=\"checkedA\"\n                                                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                                />\n                                                {translate('$__createTemplate', 1)}\n                                            </div>\n                                            <div className={classes.switch}>\n                                                <Switch\n                                                    checked={data._access && data._access.planModerate ? true : false}\n                                                    onChange={(d) => {\n                                                        changeData({\n                                                            name: 'planModerate',\n                                                            value: data._access && data._access.planModerate ? false : true\n                                                        })\n                                                    }}\n                                                    name=\"checkedA\"\n                                                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                                />\n                                                {translate('$__moderate', 1)}\n                                            </div>\n                                        </React.Fragment>\n                                    }\n                                    <div className={classes.switch}>\n                                        <Switch\n                                            checked={data._access && data._access.planAdmin ? true : false}\n                                            onChange={(d) => {\n                                                changeData({\n                                                    name: 'planAdmin',\n                                                    value: data._access && data._access.planAdmin ? false : true\n                                                })\n                                            }}\n                                            name=\"checkedA\"\n                                            inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                        />\n                                        {translate('$__admin', 1)}\n                                    </div>\n                                </React.Fragment>\n                            }\n                        </fieldset>\n\n                        {AppAccess && AppAccess.master && data._isAdmin ?\n                            <fieldset>\n                                <legend>\n                                    <Switch\n                                        checked={data._access && data._access.feed ? true : false}\n                                        onChange={(d) => {\n                                            changeData({\n                                                name: 'feed',\n                                                value: data._access && data._access.feed ? false : true\n                                            })\n                                        }}\n                                        name=\"checkedA\"\n                                        inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                    />\n                                    {translate('$__feed', 1)}\n                                </legend>\n                                {!data._access || (data._access && (!data._access.feed || data._access.feed === false)) ?\n                                    <div className={classes.accessDescription}>\n                                        <i>{translate('$__feedAccess_StrategyAndPlansAccessDescription')}</i>\n                                    </div>\n                                    :\n                                    <React.Fragment>\n                                        {!data._access.feedAdmin &&\n                                            <React.Fragment>\n                                                <div className={classes.switch}>\n                                                    <Switch\n                                                        checked={data._access && data._access.feedEdit ? true : false}\n                                                        onChange={(d) => {\n                                                            changeData({\n                                                                name: 'feedEdit',\n                                                                value: data._access && data._access.feedEdit ? false : true\n                                                            })\n                                                        }}\n                                                        name=\"checkedA\"\n                                                        inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                                    />\n                                                    {translate('$__edit', 1)}\n                                                </div>\n                                                <div className={classes.switch}>\n                                                    <Switch\n                                                        checked={data._access && data._access.feedModerate ? true : false}\n                                                        onChange={(d) => {\n                                                            changeData({\n                                                                name: 'feedModerate',\n                                                                value: data._access && data._access.feedModerate ? false : true\n                                                            })\n                                                        }}\n                                                        name=\"checkedA\"\n                                                        inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                                    />\n                                                    {translate('$__moderate', 1)}\n                                                </div>\n                                            </React.Fragment>\n                                        }\n                                        <div className={classes.switch}>\n                                            <Switch\n                                                checked={data._access && data._access.feedAdmin ? true : false}\n                                                onChange={(d) => {\n                                                    changeData({\n                                                        name: 'feedAdmin',\n                                                        value: data._access && data._access.feedAdmin ? false : true\n                                                    })\n                                                }}\n                                                name=\"checkedA\"\n                                                inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                            />\n                                            {translate('$__admin', 1)}\n                                        </div>\n                                    </React.Fragment>\n                                }\n                            </fieldset>\n                            :\n                            <React.Fragment></React.Fragment>\n                        }\n                        {AppAccess && AppAccess.masterAdmin ?\n                            <React.Fragment>\n                                <fieldset>\n                                    <legend style={{\n                                        color: \"red\"\n                                    }}>\n                                        <Switch\n                                            checked={data._access && data._access.masterAdmin ? true : false}\n                                            onChange={(d) => {\n                                                changeData({\n                                                    name: 'masterAdmin',\n                                                    value: data._access && data._access.masterAdmin ? false : true\n                                                })\n                                            }}\n                                            name=\"checkedA\"\n                                            inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                        />\n                                        {translate('$__accountAdministrator', 1)}\n                                    </legend>\n                                    <div className={classes.accessDescription}>\n                                        <i>{translate('$__accountAdministratorDescription')}</i>\n                                    </div>\n                                </fieldset>\n                            </React.Fragment>\n                            :\n                            <React.Fragment></React.Fragment>\n                        }\n                        {\n                            AppAccess\n                                && AppAccess.masterAdmin\n                                && session\n                                && (\n                                    session.email.indexOf(\"@sonne.global\") > -1\n                                    ||\n                                    session.email.indexOf(\"@machen.ai\") > -1\n                                )\n                                &&\n                                (\n                                    data.email.indexOf(\"@sonne.global\") > -1\n                                    ||\n                                    data.email.indexOf(\"@machen.ai\") > -1\n                                ) ?\n                                <React.Fragment>\n                                    <fieldset>\n                                        <legend style={{\n                                            color: \"red\"\n                                        }}>\n                                            <Switch\n                                                checked={data._access && data._access.machenAdmin ? true : false}\n                                                onChange={(d) => {\n                                                    changeData({\n                                                        name: 'machenAdmin',\n                                                        value: data._access && data._access.machenAdmin ? false : true\n                                                    })\n                                                }}\n                                                name=\"checkedA\"\n                                                inputProps={{ 'aria-label': 'secondary checkbox' }}\n                                            />\n                                            {translate('$__machenAdministrator', 1)}\n                                        </legend>\n                                        <div className={classes.accessDescription}>\n                                            <i>{translate('$__machenAdministratorDescription')}</i>\n                                        </div>\n                                    </fieldset>\n                                </React.Fragment>\n                                :\n                                <React.Fragment></React.Fragment>\n                        }\n\n                    </React.Fragment>\n                }\n                {iniData && iniData._access && iniData._access.admin && data && data._access && !data._access.admin ?\n                    <React.Fragment>\n                        <div style={{ color: \"red\", fontSize: 12 }}>\n                            Ao remover a permissão de administrador do usuário, o mesmo perderá acesso à todas as atividades que administra atualmente e passará a ter acesso restrito às atividades da plataforma.\n                        </div>\n                    </React.Fragment>\n                    : <React.Fragment></React.Fragment>\n                }\n            </div>\n        </div >\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React, { useEffect } from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Switch from \"components/Switch\";\nimport Icon from \"components/Icon\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport TextField from \"components/TextField\";\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Users.js\";\n\n//FUNCTIONS\nimport apims from \"apims/\";\n\nimport {\n    customApp,\n    appAlert,\n    translate,\n    getAppAccess\n} from \"functions/\";\nimport { saveAccess } from \"functions/users.js\";\n\nfunction Component(props) {\n    const { classes } = props;\n    const { sideModule, db, session, functions } = reduxStore.getState()\n    const { socket } = functions\n    const { data } = sideModule\n    const [reqSave, setReqSave] = React.useState(false)\n    const [tokenData, setTokenData] = React.useState({\n        image: null,\n        image: null,\n        status: false,\n    })\n    const [token, setToken] = React.useState(null)\n\n    useEffect(() => {\n        ini()\n    }, [])\n\n    const ini = async () => {\n        const res = await apims.post('/M_User_TwoFactor', {\n            action: 'has',\n        })\n        if (res && res.data && res.data.result) {\n            setTokenData({\n                ...tokenData,\n                ...res.data.result,\n                status: true,\n            })\n        } else {\n            const newToken = await apims.post('/M_User_TwoFactor', {\n                action: 'create',\n            })\n            if (newToken) {\n                setTokenData({\n                    ...tokenData,\n                    ...newToken.data.result,\n                    status: false,\n                })\n            }\n        }\n    }\n\n    const verify = async () => {\n        const res = await apims.post('/M_User_TwoFactor', {\n            action: 'verify',\n            code: token\n        })\n        if (res && res.data && res.data.result) {\n            setTokenData({\n                ...tokenData,\n                status: true\n            })\n        } else {\n            appAlert({\n                message: translate('$__invalidToken', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n            })\n            setTokenData({\n                ...tokenData,\n                status: false\n            })\n        }\n        setToken(null)\n    }\n\n    const disableToken = async () => {\n        const res = await apims.post('/M_User_TwoFactor', {\n            action: 'disable',\n            code: token\n        })\n        if (res && res.data && res.data.result) {\n            setTokenData({\n                image: null,\n                image: null,\n                status: false,\n            })\n            ini()\n        } else {\n            appAlert({\n                message: translate('$__invalidToken', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n            })\n        }\n        setToken(null)\n    }\n\n    const close = () => {\n        if (reqSave) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n        }\n    }\n\n    return (\n        <div>\n            <SideModuleCloseAndSave\n                close={() => close(true)}\n            />\n            {!tokenData.status ?\n                <div style={{\n                    position: \"relative\",\n                    width: \"100%\",\n                    textAlign: \"center\",\n                    padding: '15px',\n                }}>\n                    <div\n                        style={{\n                            position: 'relative',\n                            width: '100%',\n                        }}\n                    >\n                        {(tokenData.image) &&\n                            <img src={tokenData.image} />\n                        }\n\n                    </div>\n                    <div style={{ textAlign: 'left' }}>\n                        <p>{translate('$__tokenTip_1')}</p>\n                        <p>{translate('$__tokenTip_2')}</p>\n                        <ul>\n                            <li>{translate('$__tokenTip_3')}</li>\n                            <li>{translate('$__tokenTip_4')}</li>\n                            <li>{translate('$__tokenTip_5')}</li>\n                            <li>{translate('$__tokenTip_6')}</li>\n                            <li>{translate('$__tokenTip_7')}</li>\n                        </ul>\n                    </div>\n                    <fieldset>\n                        <legend>{translate('$__token', 1)}</legend>\n\n                        <TextField\n                            label={translate('$__token', 1)}\n                            variant={'standard'}\n                            name={'token'}\n                            type={'password'}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                value: token,\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon>lock_outline</Icon>\n                                    </InputAdornment>\n                                ),\n                                autoComplete: 'new-token',\n                                onChange: e => {\n                                    setToken(e.target.value)\n                                },\n                            }}\n                            placeholder={translate(\"$__token\", '*')}\n                            autoComplete={'new-token'}\n                            value={token}\n                            max={6}\n                        />\n                    </fieldset>\n                    {(!tokenData.status && token && token.length === 6) &&\n                        <div\n                            style={{\n                                display: 'flex',\n                                padding: '7px 15px',\n                                margin: 'auto',\n                                cursor: 'pointer',\n                                backgroundColor: 'green',\n                                marginTop: '15px',\n                                display: 'flex',\n                                alignItems: 'center',\n                                justifyContent: 'center',\n                                borderRadius: '7px'\n                            }}\n                            onClick={() => {\n                                verify()\n                            }}\n                        >\n                            <IconButton\n                                icon=\"check\"\n                                text={translate(\"$__activeToken\", '*')}\n                                title={!translate(\"$__activeToken\", '*')}\n                                iconColor={customApp('lightText')}\n                                textColor={customApp('lightText')}\n                            />\n                        </div>\n                    }\n                </div>\n                :\n                <div style={{\n                    position: \"relative\",\n                    width: \"100%\",\n                    textAlign: \"center\",\n                    padding: '15px',\n                }}>\n                    <div style={{ textAlign: 'left' }}>\n                        <p>{translate('$__disableTokenTip_1')}</p>\n                        <p>{translate('$__disableTokenTip_2')}</p>\n                        <ul>\n                            <li>{translate('$__disableTokenTip_3')}</li>\n                            <li>{translate('$__disableTokenTip_4')}</li>\n                            <li>{translate('$__disableTokenTip_5')}</li>\n                            <li>{translate('$__disableTokenTip_6')}</li>\n                            <li>{translate('$__disableTokenTip_7')}</li>\n                        </ul>\n                    </div>\n                    <TextField\n                        label={translate('$__token', 1)}\n                        variant={'standard'}\n                        name={'token'}\n                        type={'password'}\n                        InputLabelProps={{\n                            shrink: true,\n                        }}\n                        InputProps={{\n                            value: token,\n                            endAdornment: (\n                                <InputAdornment position=\"end\">\n                                    <Icon>lock_outline</Icon>\n                                </InputAdornment>\n                            ),\n                            autoComplete: 'new-password',\n                            onChange: e => {\n                                setToken(e.target.value)\n                            },\n                        }}\n                        autoComplete={'new-password'}\n                        value={token}\n                        max={6}\n                    />\n                    <div\n                        style={{\n                            display: 'flex',\n                            padding: '7px 15px',\n                            margin: 'auto',\n                            cursor: 'pointer',\n                            backgroundColor: 'red',\n                            marginTop: '15px',\n                            display: 'flex',\n                            alignItems: 'center',\n                            justifyContent: 'center',\n                            borderRadius: '7px'\n                        }}\n                        onClick={() => {\n                            disableToken()\n                        }}\n                    >\n                        <IconButton\n                            icon=\"toggle_on\"\n                            text={translate(\"$__disableToken\", '*')}\n                            title={translate(\"$__disableToken\", '*')}\n                            iconColor={customApp('lightText')}\n                            textColor={customApp('lightText')}\n                        />\n                    </div>\n                </div>\n            }\n        </div>\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React, { useEffect, useState } from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Autocomplete from \"components/AutoComplete\"\nimport Switch from \"components/Switch\"\nimport TextField from \"components/TextField\"\n\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Users.js\"\n\nimport {\n    customApp,\n    appAlert,\n    translate,\n    getAppAccess\n} from \"functions/\"\n\nimport { save } from \"../../functions/users.js\"\n\nfunction Component(props) {\n    const { classes } = props\n    const { sideModule, db } = reduxStore.getState()\n    const [data, setData] = React.useState(sideModule.data)\n    const [iniData, setIniData] = useState(sideModule.data)\n    const [language, setLanguage] = React.useState(sideModule.data && sideModule.data.language ? sideModule.data.language : 'pt-BR')\n\n    const reqSave = JSON.stringify(iniData) !== JSON.stringify(data)\n\n    const changeData = (d) => {\n        let newData = {\n            ...data,\n            [d.name]: d.value,\n        }\n\n        if (d.name === \"language\")\n            setLanguage(d.value)\n\n        if (!d.value && newData[d.name])\n            delete newData[d.name]\n\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...sideModule,\n            data: newData\n        })\n\n        setData(newData)\n    }\n\n    const close = (force = false) => {\n        if (reqSave && !force) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n        }\n    }\n\n    const saveUser = async (cl) => {\n        const reqSave = await save(props)\n        if (reqSave) {\n            appAlert({\n                message: translate('$__userDataSaved', 1),\n                variant: null,\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n\n            if (data.language !== language)\n                props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                    ...reduxStore.getState().session,\n                    language: language\n                })\n\n            if (cl) {\n                close(true)\n                if (data.language !== language)\n                    setTimeout(() => {\n                        window.location.reload()\n                    }, 1500)\n            }\n        }\n    }\n\n    console.log(iniData, data)\n\n    const AppAccess = getAppAccess()\n    let permission = false\n    if ((AppAccess\n        &&\n        (\n            AppAccess.user\n            && (\n                AppAccess.userAdmin\n                || AppAccess.userEdit\n            )\n        )\n    ))\n        permission = true\n\n    return (\n        <div>\n            <SideModuleCloseAndSave\n                save={reqSave ? () => saveUser() : null}\n                saveClose={reqSave ? () => saveUser(true) : null}\n                close={() => close(true)}\n            />\n            <div style={{\n                position: \"relative\",\n                width: \"100%\",\n                textAlign: \"center\",\n                padding: '15px',\n            }}>\n                <fieldset>\n                    <legend>{translate('$__language', 1)}</legend>\n                    <Autocomplete\n                        id=\"combo-box-demo\"\n                        options={db.languages}\n                        getOptionLabel={(option) => translate(option.label, 1)}\n                        style={{ width: \"100%\" }}\n                        name=\"status\"\n                        disableClearable\n                        value={\n                            data\n                                && data.language\n                                && db.languages\n                                ? db.languages.filter(a =>\n                                    String(a.value) === String(data.language)\n                                )[0]\n                                : db.languages[0]\n                        }\n                        renderInput={(params) =>\n                            <TextField\n                                {...params}\n                                label={translate(\"$__language\", 1)}\n                                variant={customApp(\"fieldVariant\")}\n                                value={\n                                    data\n                                        && data.language\n                                        && db.languages\n                                        ? db.languages.filter(a =>\n                                            String(a.value) === String(data.language)\n                                        )[0]\n                                        : db.languages[0]\n                                }\n                            />\n                        }\n                        onChange={\n                            (d, v) => {\n                                changeData({ name: \"language\", value: v[\"value\"] })\n                            }\n                        }\n                    />\n                </fieldset>\n                <fieldset>\n                    <legend>{translate('$__sessionDuration', 1)}</legend>\n                    <div>{translate('$__sessionDurationDescription', 1)}</div>\n                    <Autocomplete\n                        id=\"combo-box-demo\"\n                        options={db.expiresIn}\n                        getOptionLabel={(option) => translate(option.label, 1)}\n                        style={{ width: \"100%\" }}\n                        name=\"status\"\n                        disableClearable\n                        value={\n                            data\n                                && data.expiresIn\n                                && db.expiresIn\n                                ? db.expiresIn.filter(a =>\n                                    String(a.value) === String(data.expiresIn)\n                                )[0]\n                                : db.expiresIn.filter(a =>\n                                    !a.value\n                                )[0]\n                        }\n                        renderInput={(params) =>\n                            <TextField\n                                {...params}\n                                label={translate(\"$__expiresIn\", 1)}\n                                variant={customApp(\"fieldVariant\")}\n                                value={\n                                    data\n                                        && data.expiresIn\n                                        && db.expiresIn\n                                        ? db.expiresIn.filter(a =>\n                                            String(a.value) === String(data.expiresIn)\n                                        )[0]\n                                        : db.expiresIn.filter(a =>\n                                            !a.value\n                                        )[0]\n                                }\n                            />\n                        }\n                        onChange={\n                            (d, v) => {\n                                changeData({ name: \"expiresIn\", value: v[\"value\"] })\n                            }\n                        }\n                    />\n                </fieldset>\n                {reduxStore.getState().session.isResale && data.type !== \"user\" ?\n                    <fieldset style={{ marginBottom: \"14px\" }}>\n                        {reduxStore.getState().db.users[data._id].independentAccount ?\n                            <div\n                                style={{ color: \"gray\", fontSize: 11 }}\n                            >\n                                {translate(\"$__thisIsAIndependentAccountExplain\", 1)}\n                            </div>\n                            :\n                            <React.Fragment>\n                                <div className={classes.switch}>\n                                    <Switch\n                                        checked={\n                                            data.independentAccount\n                                                ? true\n                                                : false\n                                        }\n                                        onChange={(d) => {\n                                            if (permission)\n                                                changeData({\n                                                    name: \"independentAccount\",\n                                                    value: data.independentAccount ? false : true\n                                                })\n                                        }}\n                                        name=\"independentAccount\"\n                                        inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                    />\n                                    {translate(\"$__turnIntoIndependentAccount\", 1)}\n                                </div>\n                                <div\n                                    style={{ color: \"gray\", fontSize: 11 }}\n                                >\n                                    {translate(\"$__turnIntoIndependentAccountExplain\", 1)}\n                                </div>\n                            </React.Fragment>\n                        }\n                    </fieldset>\n                    : <React.Fragment></React.Fragment>}\n            </div>\n        </div>\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","import React from 'react'\r\nimport DatePicker, { registerLocale } from \"react-datepicker\"\r\nimport pt from \"date-fns/locale/pt\"// the locale you want\r\nimport moment from \"moment-timezone\"\r\n\r\n//COMPONENTS\r\nimport Icon from \"components/Icon\"\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport TextField from \"components/TextField\"\r\n\r\n//STYLES\r\nimport \"assets/css/components/react-datepicker.css\";\r\n//APIMS\r\nimport { translate, customApp } from 'functions';\r\n\r\n\r\nfunction DatePickerComponent(props) {\r\n    registerLocale(\"pt\", pt); // register it with the name you want\r\n    return (\r\n        <div style={{\r\n            width: '100%',\r\n            ...props.horizontal ?\r\n                {\r\n                    display: \"flex\",\r\n                    alignItems: \"center\"\r\n                }\r\n                : {},\r\n            ...props.style ? props.style : {},\r\n            justifyContent: \"center\"\r\n        }}>\r\n            <div style={{\r\n                ...props.horizontal ? { width: props.onClear ? \"calc(50% - 11px)\" : \"\" } : {}\r\n            }}>\r\n                <DatePicker\r\n                    locale=\"pt\"\r\n                    placeholderText={props.placeholder ? props.placeholder : translate(\"$__pleaseSelectStartDate\")}\r\n                    selected={props.startDate ? props.startDate : null}\r\n                    onChange={props.onChangeStartDate ? (x) => {\r\n                        props.onChangeStartDate(x)\r\n                    } : null}\r\n                    selectsStart\r\n                    startDate={props.startDate ? props.startDate : null}\r\n                    endDate={props.endDate ? props.endDate : null}\r\n                    maxDate={!props.range && props.maxDate ? props.maxDate : null}\r\n                    {...props.type && props.type === \"datetime\" ? {\r\n                        timeInputLabel: translate(\"$__time\"),\r\n                        dateFormat: \"dd/MM/yyyy HH:mm\",\r\n                        showTimeInput: true\r\n                    } : {\r\n                        dateFormat: \"dd/MM/yyyy\",\r\n                    }}\r\n                    customInput={(<CustomInput />)}\r\n                    showYearDropdown\r\n                />\r\n            </div>\r\n            {props.range ?\r\n                <div\r\n                    style={{\r\n                        ...props.horizontal ? { marginLeft: 7, width: props.onClear ? \"calc(50% - 18px)\" : \"calc(50% - 7px)\" } : { marginTop: 7 },\r\n                    }}\r\n                >\r\n                    <DatePicker\r\n                        locale=\"pt\"\r\n                        placeholderText={translate(\"$__pleaseSelectEndDate\")}\r\n                        selected={props.endDate ? props.endDate : null}\r\n                        onChange={props.onChangeEndDate ? (x) => {\r\n                            props.onChangeEndDate(x)\r\n                        } : null}\r\n                        selectsEnd\r\n                        startDate={props.startDate ? props.startDate : null}\r\n                        endDate={props.endDate ? props.endDate : null}\r\n                        minDate={props.minDate ? props.minDate : props.range && props.startDate ? props.startDate : null}\r\n                        {...props.type && props.type === \"datetime\" ? {\r\n                            timeInputLabel: translate(\"$__time\"),\r\n                            dateFormat: \"dd/MM/yyyy HH:mm\",\r\n                            showTimeInput: true\r\n                        } : {\r\n                            dateFormat: \"dd/MM/yyyy\",\r\n                        }}\r\n                        maxDate={props.maxDate ? props.maxDate : null}\r\n                        customInput={(<CustomInput />)}\r\n                        showYearDropdown\r\n                    // monthsShown={2}\r\n                    />\r\n                </div>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n            {props.onClear && (props.startDate || props.endDate) ?\r\n                <div\r\n                    style={{\r\n                        display: \"flex\",\r\n                        justifyContent: props.clearButtonPosition ? props.clearButtonPosition : \"center\",\r\n                        ...props.horizontal ? {\r\n\r\n                        } : {\r\n                            paddingTop: 3,\r\n                        }\r\n                    }}\r\n                >\r\n                    <CustomButton\r\n                        color={customApp('lightgray')}\r\n                        icon={'clear'}\r\n                        onClick={props.onClear}\r\n                        size={'15px'}\r\n                        {...props.horizontal ? {\r\n                        } : {\r\n\r\n                            title: translate(`$__clearDate`, '*'),\r\n                            text: translate(`$__clearDate`, '*')\r\n                        }}\r\n                    />\r\n                </div>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n        </div>\r\n    );\r\n}\r\n\r\nconst CustomInput = React.forwardRef((props, ref) => {\r\n    return (\r\n        <div style={{\r\n            display: \"flex\",\r\n            width: \"100%\",\r\n            padding: \"7px 7px\",\r\n            fontSize: \"12px\",\r\n            fontWeight: 400,\r\n            lineHeight: 1.5,\r\n            color: \"#212529\",\r\n            backgroundColor: \"#fff\",\r\n            border: \"1px solid #ced4da\",\r\n            borderRadius: 3,\r\n            transition: 'border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out',\r\n            appearance: 'none',\r\n            justifyContent: 'space-between'\r\n        }}\r\n            onClick={props.onClick}\r\n        >\r\n            <label\r\n                onClick={props.onClick}\r\n                ref={ref}\r\n                style={{ marginRight: 7, whiteSpace: \"nowrap\", overflow: \"hidden\", textOverflow: \"ellipsis\" }}\r\n            >\r\n                {props.value || props.placeholder}\r\n            </label>\r\n            <Icon\r\n                size={\"22px\"}\r\n                color={customApp('color')}\r\n                icon={'today'}\r\n                onClick={props.onClick}\r\n            />\r\n        </div>\r\n    );\r\n});\r\nexport default DatePickerComponent","//CORE\nimport React, { useEffect, useState } from \"react\"\nimport moment from \"moment\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\n\nimport Autocomplete from \"components/AutoComplete\"\nimport DataPicker from \"components/DataPicker\"\nimport Icon from \"components/Icon\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\nimport Switch from \"components/Switch\"\nimport TextField from \"components/TextField\"\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Users.js\"\n\n//FUNCTIONS\nimport apims from \"apims/\"\n\nimport {\n    customApp,\n    appAlert,\n    translate,\n    getAppAccess\n} from \"functions/\"\nimport { save } from \"../../functions/users.js\"\n\nfunction Component(props) {\n    const { classes } = props\n    const { sideModule, db } = reduxStore.getState()\n    const [data, setData] = useState(sideModule.data)\n    const [iniData, setIniData] = useState(sideModule.data)\n\n    const reqSave = JSON.stringify(data) !== JSON.stringify(iniData)\n\n    const changeData = (d) => {\n        let newData = {\n            ...data,\n            [d.name]: d.value,\n        }\n\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...sideModule,\n            data: {\n                ...sideModule.data,\n                [d.name]: d.value,\n            }\n        })\n\n        if (!d.value && newData[d.name])\n            delete newData[d.name]\n\n        setData(newData)\n    }\n\n    const close = (force = false) => {\n        if (reqSave && !force) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n        }\n    }\n\n    const saveUser = async (cl) => {\n\n        const reqSave = await save(props)\n\n        if (reqSave) {\n            appAlert({\n                message: translate('$__userDataSaved', 1),\n                variant: null,\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n            setIniData(data)\n\n            if (cl) {\n                close(true)\n            }\n        }\n    }\n\n    const AppAccess = getAppAccess()\n\n    let permission = false\n    if ((AppAccess\n        &&\n        (\n            AppAccess.user\n            && (\n                AppAccess.userAdmin\n                || AppAccess.userEdit\n            )\n        )\n    ))\n        permission = true\n\n    return (\n        <div>\n            <SideModuleCloseAndSave\n                save={reqSave ? () => saveUser() : null}\n                saveClose={reqSave ? () => saveUser(true) : null}\n                close={() => close(true)}\n            />\n            <div style={{\n                position: \"relative\",\n                width: \"100%\",\n                textAlign: \"center\",\n                padding: '15px',\n            }}>\n                <fieldset>\n                    <legend>{translate('$__limitNumberOfUsers', 1)}</legend>\n                    <div\n                    >\n                        {translate(\"$__limitAdminUsersExplain\", 1)}\n                        <TextField\n                            label={translate(\"$__numberOfUsers\")}\n                            variant={\"outlined\"}\n                            name=\"customAdmins\"\n                            type=\"number\"\n                            min={0}\n                            max={99999}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                type: \"number\",\n                                onChange: (d) => {\n                                    if (d.target.value === 0) {\n                                        changeData({ name: 'customAdmins', value: null })\n                                    } else {\n                                        changeData({ name: 'customAdmins', value: d.target.value > 0 ? d.target.value : 0 })\n                                    }\n                                },\n                            }}\n                            value={data.customAdmins || 0}\n                        />\n                    </div>\n                </fieldset>\n                {reduxStore.getState().session.isResale ?\n                    <fieldset style={{ marginBottom: \"14px\" }}>\n                        {reduxStore.getState().db.users[data._id].independentAccount ?\n                            <React.Fragment>\n                                <div\n                                    style={{ color: \"gray\", fontSize: 11, width: \"100%\" }}\n                                >\n                                    {translate(\"$__thisIsAIndependentAccountExplain\", 1)}\n                                </div>\n                                <ul\n                                    style={{\n                                        color: \"gray\",\n                                        fontSize: 12,\n                                        width: \"100%\",\n                                        textAlign: \"initial\"\n                                    }}\n                                >\n                                    {data.plan ?\n                                        <li>\n                                            {translate(\"$__signaturePlan\", 1)}: {translate(db.plans.filter(a =>\n                                                String(a.value) === String(data.plan)\n                                            )[0].label, 1)}\n                                        </li>\n                                        : <React.Fragment></React.Fragment>\n\n                                    }\n                                    {data.expireAccountDate ?\n                                        <li>\n                                            {translate(\"$__expireAccountDate\", 1)}: {moment(data.expireAccountDate * 1000).format(\"DD/MM/YYYY\")}\n                                        </li>\n                                        : <React.Fragment></React.Fragment>\n\n                                    }\n                                </ul>\n                            </React.Fragment>\n                            :\n                            <React.Fragment>\n                                <div className={classes.switch}>\n                                    <Switch\n                                        checked={\n                                            data.independentAccount\n                                                ? true\n                                                : false\n                                        }\n                                        onChange={(d) => {\n                                            if (permission)\n                                                changeData({\n                                                    name: \"independentAccount\",\n                                                    value: data.independentAccount ? false : true\n                                                })\n                                        }}\n                                        name=\"independentAccount\"\n                                        inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                    />\n                                    {translate(\"$__turnIntoIndependentAccount\", 1)}\n                                </div>\n                                <div\n                                    style={{ color: \"gray\", fontSize: 11 }}\n                                >\n                                    {translate(\"$__turnIntoIndependentAccountExplain\", 1)}\n                                </div>\n                            </React.Fragment>\n                        }\n                    </fieldset>\n                    : <React.Fragment></React.Fragment>}\n                {((!iniData.independentAccount && data.plan) || !data.plan) && data.independentAccount ?\n                    <React.Fragment>\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <Autocomplete\n                                id=\"combo-box-demo\"\n                                options={db.plans}\n                                getOptionLabel={(option) => translate(option.label, 1)}\n                                style={{ width: \"100%\" }}\n                                name=\"plans\"\n                                disableClearable\n                                value={\n                                    data\n                                        && data.plan\n                                        && db.plans\n                                        ? db.plans.filter(a =>\n                                            String(a.value) === String(data.plan)\n                                        )[0]\n                                        : db.plans[0]\n                                }\n                                renderInput={(params) =>\n                                    <TextField\n                                        {...params}\n                                        label={translate(\"$__demoPlanSignature\", 1)}\n                                        variant={customApp(\"fieldVariant\")}\n                                        value={\n                                            data\n                                                && data.plan\n                                                && db.plans\n                                                ? db.plans.filter(a =>\n                                                    String(a.value) === String(data.plan)\n                                                )[0]\n                                                : db.plans[0]\n                                        }\n                                    />\n                                }\n                                onChange={\n                                    (d, v) => {\n                                        if (permission)\n                                            changeData({ name: \"plan\", value: v[\"value\"] })\n                                    }\n                                }\n                            />\n                        </fieldset>\n                    </React.Fragment>\n                    : <React.Fragment>\n\n                    </React.Fragment>\n                }\n                {data.independentAccount && (data.plan && data.plan !== \"p0\" && !iniData.expireAccountDate) ?\n                    <DataPicker\n                        placeholder={translate(\"$__dueDate\")}\n                        clearButtonPosition={\"flex-end\"}\n                        onChangeStartDate={(d) => {\n                            changeData({ name: \"expireAccountDate\", value: String(moment(d).unix('X')) })\n                        }}\n                        maxDate={new Date(moment().add(\"days\", 30).unix('X') * 1000)}\n                        startDate={data && data.expireAccountDate ? new Date(data.expireAccountDate * 1000) : null}\n                    />\n                    : <React.Fragment></React.Fragment>\n                }\n            </div>\n        </div>\n    )\n}\nconst mapStateToProps = () => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React, { useEffect } from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Switch from \"components/Switch\";\nimport Icon from \"components/Icon\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport TextField from \"components/TextField\";\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Users.js\";\n\n//FUNCTIONS\nimport apims from \"apims/\";\n\nimport {\n    customApp,\n    appAlert,\n    translate,\n    getAppAccess\n} from \"functions/\";\nimport { saveAccess } from \"functions/users.js\";\n\nimport GooglePlayQR from \"assets/img/googlePlay-ptBR.png\"\nimport AppleStoreQR from \"assets/img/appleStore-ptBR.png\"\n\nfunction Component(props) {\n    const { classes } = props;\n    const { sideModule, db, session, functions } = reduxStore.getState()\n    const { socket } = functions\n    const { data } = sideModule\n    const [reqSave, setReqSave] = React.useState(false)\n    const [tokenData, setTokenData] = React.useState({\n        image: null,\n        image: null,\n        status: false,\n    })\n    const [token, setToken] = React.useState(null)\n\n    useEffect(() => {\n        ini()\n    }, [])\n\n    const ini = async () => {\n        // const res = await apims.post('/M_User_TwoFactor', {\n        //     action: 'has',\n        // })\n        // if (res && res.data && res.data.result) {\n        //     setTokenData({\n        //         ...tokenData,\n        //         ...res.data.result,\n        //         status: true,\n        //     })\n        // } else {\n        //     const newToken = await apims.post('/M_User_TwoFactor', {\n        //         action: 'create',\n        //     })\n        //     if (newToken) {\n        //         setTokenData({\n        //             ...tokenData,\n        //             ...newToken.data.result,\n        //             status: false,\n        //         })\n        //     }\n        // }\n    }\n\n    const verify = async () => {\n        // const res = await apims.post('/M_User_TwoFactor', {\n        //     action: 'verify',\n        //     code: token\n        // })\n        // if (res && res.data && res.data.result) {\n        //     setTokenData({\n        //         ...tokenData,\n        //         status: true\n        //     })\n        // } else {\n        //     appAlert({\n        //         message: translate('$__invalidToken', 1),\n        //         variant: 'warning',\n        //         persist: false,\n        //         horizontal: 'right',\n        //     })\n        //     setTokenData({\n        //         ...tokenData,\n        //         status: false\n        //     })\n        // }\n        // setToken(null)\n    }\n\n    const disableToken = async () => {\n        // const res = await apims.post('/M_User_TwoFactor', {\n        //     action: 'disable',\n        //     code: token\n        // })\n        // if (res && res.data && res.data.result) {\n        //     setTokenData({\n        //         image: null,\n        //         image: null,\n        //         status: false,\n        //     })\n        //     ini()\n        // } else {\n        //     appAlert({\n        //         message: translate('$__invalidToken', 1),\n        //         variant: 'warning',\n        //         persist: false,\n        //         horizontal: 'right',\n        //     })\n        // }\n        // setToken(null)\n    }\n\n    const close = () => {\n        if (reqSave) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n        }\n    }\n\n    return (\n        <div>\n            <SideModuleCloseAndSave\n                close={() => close(true)}\n            />\n            <div style={{\n                position: \"relative\",\n                width: \"100%\",\n                textAlign: \"center\",\n                padding: '15px',\n            }}>\n                <div style={{ textAlign: 'left' }}>\n                    <p>{translate('$__mobileTokenTip_1')}</p>\n                    <ul>\n                        <li>{translate('$__mobileTokenTip_2')}</li>\n                        <li>{translate('$__mobileTokenTip_3')}</li>\n                        <li>{translate('$__mobileTokenTip_4')}</li>\n                    </ul>\n                </div>\n                <img src={AppleStoreQR} style={{ width: \"52%\" }} />\n                <img src={GooglePlayQR} style={{ width: \"52%\", marginTop: \"33px\" }} />\n                {/* {(!tokenData.status && token && token.length === 6) &&\n                        <div\n                            style={{\n                                display: 'flex',\n                                padding: '7px 15px',\n                                margin: 'auto',\n                                cursor: 'pointer',\n                                backgroundColor: 'green',\n                                marginTop: '15px',\n                                display: 'flex',\n                                alignItems: 'center',\n                                justifyContent: 'center',\n                                borderRadius: '7px'\n                            }}\n                            onClick={() => {\n                                verify()\n                            }}\n                        >\n                            <IconButton\n                                icon=\"check\"\n                                text={translate(\"$__activeToken\", '*')}\n                                title={!translate(\"$__activeToken\", '*')}\n                                iconColor={customApp('lightText')}\n                                textColor={customApp('lightText')}\n                            />\n                        </div>\n                    } */}\n            </div>\n        </div>\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","import {\r\n  defaultFont,\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst headerStyle = () => ({\r\n  lock: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    height: '100vh',\r\n    zIndex: '3000 !important',\r\n  },\r\n  backdrop: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '440px',\r\n    bottom: '0px',\r\n    height: '100vh',\r\n    backgroundColor: 'rgba(0,0,0,0.7)',\r\n  },\r\n  module: {\r\n    ...defaultFont,\r\n    position: `absolute`,\r\n    right: `0px`,\r\n    top: `0px`,\r\n    bottom: `0px`,\r\n    // width: `440px`,\r\n    minWidth: \"500px\",\r\n    width: \"25%\",\r\n    zIndex: `1100`,\r\n    backgroundColor: `rgba(255,255,255,1)`\r\n  },\r\n  modulePopup: {\r\n    ...defaultFont,\r\n    width: '70vw',\r\n    position: 'absolute',\r\n    zIndex: '1100',\r\n    left: 'calc(50% - 35vw)',\r\n    backgroundColor: 'rgba(255,255,255,1)',\r\n    height: '80vh',\r\n    top: 'calc(50% - 40vh)',\r\n    boxShadow: '0px 0px 20px rgba(0,0,0,0.2)',\r\n    padding: '0px 5px',\r\n    border: 'solid 2px #ffffff',\r\n  },\r\n  moduleExpanded: {\r\n    ...defaultFont,\r\n    width: '90vw',\r\n    position: 'absolute',\r\n    zIndex: '1100',\r\n    left: 'calc(50% - 45vw)',\r\n    backgroundColor: 'rgba(255,255,255,1)',\r\n    height: '80vh',\r\n    bottom: '0px',\r\n    boxShadow: '0px 0px 20px rgba(0,0,0,0.2)',\r\n    padding: '0px 5px',\r\n    border: 'solid 2px #ffffff',\r\n  },\r\n  moduleFullScreen: {\r\n    ...defaultFont,\r\n    width: '100vw',\r\n    position: 'absolute',\r\n    zIndex: '1100',\r\n    left: '0px',\r\n    backgroundColor: 'rgba(255,255,255,1)',\r\n    height: '100vh',\r\n    bottom: '0px',\r\n    boxShadow: '0px 0px 20px rgba(0,0,0,0.2)',\r\n    padding: '0px 5px',\r\n    border: 'solid 2px #ffffff',\r\n  },\r\n  menu: {\r\n    position: `absolute`,\r\n    left: `0px`,\r\n    width: `45px`,\r\n    top: `0px`,\r\n    bottom: `0px`,\r\n    textAlign: `center`,\r\n  },\r\n  content: {\r\n    position: 'absolute',\r\n    top: '80px',\r\n    left: '45px',\r\n    bottom: '0px',\r\n    right: '0px',\r\n    padding: '0px',\r\n    overflowY: 'auto',\r\n    overflowX: 'hidden',\r\n    zIndex: 1\r\n  },\r\n  menuButtons_resume: {\r\n    margin: '0px auto 27px auto',\r\n    height: '40px'\r\n  },\r\n  MenuButton: {\r\n    margin: 'auto auto',\r\n    // padding: '7px',\r\n    cursor: 'pointer',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    justifyContent: 'center'\r\n  },\r\n  MenuButton_arrow: {\r\n    position: 'absolute',\r\n    right: '-8px',\r\n    fontSize: '16px',\r\n    transform: 'rotate(180deg)'\r\n  },\r\n  subTitle: {\r\n    position: `absolute`,\r\n    left: `45px`,\r\n    right: `0px`,\r\n    padding: `4px 10px`,\r\n    top: `47px`,\r\n    backgroundColor: customApp('color'),\r\n    color: customApp('light'),\r\n    // zIndex: 1\r\n  },\r\n});\r\n\r\nexport default headerStyle;\r\n","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule.js\"\n\n\n//IMPORT MODULES TO CARDS\nimport IconButton from '@material-ui/core/IconButton'\n\n\n//@MATERIAL\nimport Badge from '@material-ui/core/Badge'\n\n//FUNCTIONS\nimport { customApp } from \"functions/\"\nimport { countNotifications } from \"functions/cards\"\n\nconst Component = (props) => {\n    const { classes, sideModule } = props\n\n    let notifications = {}\n    if (props.count)\n        notifications = countNotifications(sideModule.id)\n\n    return (\n        <div\n            className={classes.MenuButton}\n            id={`sideModule_buttom_${props.module}`}\n        >\n            <IconButton\n                onClick={() => {\n                    props.openModule(props.module)\n                }\n                }\n            >\n                <Badge\n                    overlap=\"rectangular\"\n                    badgeContent={props.count && notifications && notifications[props.count] ? notifications[props.count] : null}\n                    color=\"secondary\"\n                >\n                    <Icon\n                        // disabled={sideModule.activeModule === props.module ? false : true}\n                        icon={props.icon}\n                        size={props.size}\n                        color={sideModule.activeModule === props.module ? customApp('active') : customApp('colorText')}\n                        title={props.title}\n                    />\n                </Badge>\n                {sideModule.activeModule === props.module &&\n                    <Icon\n                        className={classes.MenuButton_arrow}\n                        color={sideModule.activeModule === props.module ? customApp('active') : customApp('colorText')}\n                        icon={'play_arrow'}\n                    />\n                }\n            </IconButton>\n        </div >\n    )\n}\n\nconst mapStateToProps = (store) => (\n    {\n        timeline: store.timeline && store.sideModule.id && store.timeline[store.sideModule.id] ? store.timeline[store.sideModule.id] : {},\n        card: store.db.cards && store.db.cards[store.sideModule.id] ? store.db.cards[store.sideModule.id] : {},\n        sideModule: store.sideModule\n    }\n)\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","import React from 'react';\nimport { makeStyles } from '@material-ui/core/styles';\nimport Button from '@material-ui/core/Button';\n\nimport { customApp } from \"functions/\";\n\nexport default function CustomizedButtons(props) {\n    const useStyles = makeStyles({\n        root: {\n            boxShadow: `0 2px 2px 0px rgba(0,0,0,0.2)`,\n            textTransform: 'none',\n            padding: '6px 12px',\n            border: '1px solid',\n            lineHeight: 1.5,\n            backgroundColor: customApp(props.color ? props.color : 'color'),\n            borderColor: customApp(props.color ? props.color : 'color'),\n            color: customApp('lightText'),\n            '&:hover': {\n                backgroundColor: customApp(props.color ? props.color : 'color', 0.8),\n                borderColor: customApp(props.color ? props.color : 'color'),\n                boxShadow: `0 0 0 0.2rem ${customApp(props.color ? props.color : 'color', 0.2)}`,\n            },\n            '&:active': {\n                boxShadow: 'none',\n                backgroundColor: customApp(props.color ? props.color : 'color'),\n                borderColor: customApp(props.color ? props.color : 'color'),\n            },\n            '&:focus': {\n                boxShadow: `0 0 0 0.2rem ${customApp(props.color ? props.color : 'color', 0.2)}`,\n            },\n        },\n    });\n    const classes = useStyles();\n\n    const defaultColors = ['default', 'inherit', 'primary', 'secondary']\n    if (!props.color || (props.color && defaultColors.indexOf(props.color) === -1)) {\n        return (\n            <Button\n                className={classes.root}\n                variant=\"contained\"\n                color={props.color ? props.color : \"primary\"}\n                style={props.style ? props.style : {}}\n                onClick={props.onClick ? () => props.onClick() : null}\n            >\n                {props.children}\n            </Button>\n        );\n    } else {\n        return (\n            <Button\n                variant={props.variant ? props.variant : \"contained\"}\n                color={\"primary\"}\n                style={props.style ? props.style : {}}\n                onClick={props.onClick ? () => props.onClick() : null}\n            >\n                {props.children}\n            </Button>\n        );\n    }\n}","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport Buttom from \"components/CustomButtons/Custom\"\nimport CircularProgress from \"components/Progress/circular\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\nimport TextField from \"components/TextField/\"\nimport Icon from \"components/Icon\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport InputAdornment from '@material-ui/core/InputAdornment'\n\n//FUNCTIONS\nimport { translate, customApp, appAlert, deleteNode } from \"functions/\"\nimport { getChildrens, deleteCard } from \"functions/cards\"\n\nimport apims from \"apims\"\n\nfunction Component(props) {\n    const { sideModule, db, functions } = reduxStore.getState()\n    const { socket } = functions\n    const [migrateComplete, setMigrateComplete] = React.useState(false)\n    const [Load, setLoading] = React.useState(false)\n    const [SelectedUser, setSelectedUser] = React.useState(null)\n    const [childrensCards, setChildrensCards] = React.useState({})\n    const [countCards, setCountCards] = React.useState(0)\n    const [findNameUser, setFindNameUser] = React.useState(\"\")\n    const data = sideModule.data || {}\n    let countChildrens = 0\n\n    if (data && data.type === \"step\") {\n        countChildrens = Object.keys(reduxStore.getState().db.cards).filter(card =>\n            reduxStore.getState().db.cards[card]._parent === data._id\n            && !reduxStore.getState().db.cards[card].deleted\n        ).length\n    }\n\n    React.useEffect(() => {\n        if (data.type === 'user') {\n            loadUserCards()\n        } else {\n            setLoading(false)\n        }\n        return () => {\n\n        }\n    }, [])\n\n    React.useEffect(() => {\n        iniChildrens()\n    }, [data._id])\n\n    const iniChildrens = async () => {\n        let cards = await getChildrens(data._id)\n        if (cards)\n            setChildrensCards(cards)\n    }\n\n    const deleteThis = async () => {\n        if (countChildrens > 0) {\n            appAlert({\n                message: translate(\"$__beforeRemovingYouneedToMoveAllActivitiesInTheColumn\", 1),\n                variant: \"warning\",\n                persist: false,\n                horizontal: \"center\",\n            })\n            return\n        }\n        appAlert({\n            message: translate(\"$__confirmDeleteThis\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                deleteCard(props, { _id: data._id }, false)\n                deleteNode(props, { _id: data._id }, false)\n                props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n            }\n        })\n    }\n\n    const deleteAll = async () => {\n        appAlert({\n            message: translate(\"$__confirmDeleteThisAndAllLinkedsActivies\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                deleteCard(props, { _id: data._id }, false, true)\n                props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n            }\n        })\n    }\n\n    const loadUserCards = async () => {\n        setLoading(false)\n        const countChildrens = await apims.post(\"/Card_Count\", { id: data._id, all: true, rel: \"INN\" })\n        if (countChildrens) {\n            setLoading(true)\n            setCountCards(countChildrens.data)\n        }\n\n    }\n\n    const migrate = async () => {\n        setLoading(true)\n\n        socket.emit(\"data\", {\n            module: \"user\",\n            method: \"post\",\n            action: \"migrate\"\n        }, {\n            from: data._id,\n            fromData: data,\n            to: SelectedUser,\n            toData: db.users[SelectedUser]\n        }, async () => {\n            setMigrateComplete(true)\n            let cards = { ...db.cards }\n            Object.keys(cards).filter(a =>\n                cards[a]._users && cards[a]._users[data._id]\n            ).map(a => {\n                if (!cards[a]._users[SelectedUser])\n                    cards[a]._users = {\n                        ...cards[a]._users,\n                        [SelectedUser]: {\n                            access: cards[a]._users[data._id].access,\n                            _id: SelectedUser\n                        }\n                    }\n                delete cards[a]._users[data._id]\n            })\n            setLoading(true)\n        })\n    }\n\n    return (\n        <div style={{ width: '100%' }}>\n            <SideModuleCloseAndSave\n                close={() => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n                }}\n            />\n            {data._id && db.cards[data._id] &&\n                <React.Fragment>\n                    <fieldset style={{ textAlign: \"center\" }}>\n                        <legend style={{ color: customApp(\"color\") }}>{translate(\"$__deleteOptions\", 1)}</legend>\n                        <fieldset style={{ textAlign: \"center\" }}>\n                            <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                                {data.type === \"chatGroup\" ? translate(\"$__deleteThisChatGroup\", 1) : translate(\"$__deleteThisActivity\", 1)}\n                            </div>\n                            <Buttom onClick={() => { deleteThis() }} >{translate(\"$__delete\", 1)}</Buttom>\n                        </fieldset>\n                        {data.type !== \"step\" && Object.keys(childrensCards).length > 0 &&\n                            <fieldset style={{ textAlign: \"center\" }}>\n                                <legend style={{ color: customApp(\"color\") }}>{translate(\"$__thisActivityHasOtherLinkedsActivities\", 1)}</legend>\n                                <div style={{ textAlign: \"center\", width: \"100%\", color: 'red' }}>\n                                    {translate(\"$__deleteAllActiviesLinkedAlert\", 1)}\n                                </div>\n                                <Buttom onClick={() => { deleteAll() }} >{translate(\"$__deleteAll\", 1)}</Buttom>\n                            </fieldset>\n                        }\n                    </fieldset>\n\n                </React.Fragment>\n            }\n\n            {/* DELETE CLIENT */}\n            {data._id && db.users[data._id] &&\n                (\n                    db.users[data._id].type === 'client' ||\n                    db.users[data._id].type === 'group' ||\n                    db.users[data._id].type === 'sic' ||\n                    db.users[data._id].type === 'unity'\n                ) &&\n                <fieldset style={{ textAlign: \"center\" }}>\n                    <legend style={{ color: customApp(\"color\") }}>{translate(\"$__deleteOptions\", 1)}</legend>\n                    <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                        {Object.keys(db.users).filter(a => db.users[a]._parent === data._id).length > 0 ?\n                            translate(`$__delete${db.users[data._id].type}WithUsersDescription`, 1)\n                            :\n                            translate(`$__delete${db.users[data._id].type}NoUsersDescription`, 1)\n                        }\n                    </div>\n                    <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                        {translate(\"$__deleteThisDescription\", 1)}\n                    </div>\n                    <Buttom onClick={() => { deleteThis() }} >{translate(\"$__deleteThis\", 1)}</Buttom>\n                </fieldset>\n            }\n\n            {/* DELETE USER */}\n            {data._id && db.users[data._id] &&\n                db.users[data._id].type !== 'client' &&\n                db.users[data._id].type !== 'group' &&\n                db.users[data._id].type !== 'sic' &&\n                db.users[data._id].type === 'unity' &&\n                <React.Fragment>\n                    {Load ?\n                        <React.Fragment>\n                            {countCards > 0 && !migrateComplete ?\n                                <React.Fragment>\n\n                                    <fieldset>\n                                        <legend style={{ color: customApp(\"color\") }}>{translate(\"$__thisUserHas\", 1)}</legend>\n                                        <div style={{\n                                            position: \"relative\",\n                                            marginTop: \"22px\",\n                                            bottom: \"7px\",\n                                            width: \"100%\",\n                                            fontSize: \"12px\",\n                                            color: customApp('mediumText'),\n                                            display: \"flex\",\n                                            justifyContent: \"center\",\n                                            textAlign: \"center\"\n                                        }}>\n                                            {countCards} {translate(\"$__items\")}\n                                            <br></br>\n                                            {translate(\"$__deleteCountCardsExplain\")}\n                                        </div>\n                                    </fieldset>\n                                    {SelectedUser ?\n                                        <fieldset>\n                                            <legend>{translate('$__selectedUserToMigrationCards')}</legend>\n                                            <div\n                                                style={{\n                                                    cursor: 'pointer',\n                                                    marginBottom: '7px',\n                                                    display: 'flex',\n                                                    alignItems: 'center'\n                                                }}\n                                                onClick={() => {\n                                                    setSelectedUser(null)\n                                                }}\n                                            >\n                                                <Avatar alt={db.users[SelectedUser].name} src={db.users[SelectedUser].image || null}\n                                                    style={{ marginRight: '15px' }}\n                                                >\n                                                    {db.users[SelectedUser].name.substr(0, 1)}\n                                                </Avatar>\n                                                <span>{db.users[SelectedUser].name}</span>\n                                            </div>\n                                            <Buttom onClick={() => {\n                                                appAlert({\n                                                    message: translate('$__confirmUserTransferData', 1),\n                                                    autoClose: 50000,\n                                                    buttons: [\n                                                        {\n                                                            shadow: true,\n                                                            title: translate(\"$__confirm\"),\n                                                            text: translate(\"$__confirm\"),\n                                                            color: \"green\",\n                                                            icon: \"done_all\",\n                                                            size: \"25px\",\n                                                            style: { marginLeft: 15 },\n                                                            onClick: () => {\n                                                                migrate()\n                                                            },\n                                                        },\n                                                        {\n                                                            shadow: true,\n                                                            title: translate(\"$__cancel\"),\n                                                            text: translate(\"$__cancel\"),\n                                                            color: \"red\",\n                                                            icon: \"close\",\n                                                            size: \"25px\",\n                                                            style: { marginLeft: 15 },\n                                                            onClick: () => {\n\n                                                            },\n                                                        }],\n                                                    variant: 'warning',\n                                                    persist: false,\n                                                    horizontal: 'right',\n                                                })\n\n                                            }} >{translate(\"$__migrate\", 1)}</Buttom>\n                                        </fieldset>\n                                        :\n                                        <fieldset\n                                            style={{ marginTop: 7, marginBottom: 7 }}\n                                        >\n                                            <legend>{translate('$__chooseAUserToTransferCardsBeforeDeletingUser')}</legend>\n                                            <TextField\n                                                label={translate('$__search', '*')}\n                                                variant={'standard'}\n                                                autoFocus\n                                                value={findNameUser}\n                                                InputProps={{\n                                                    endAdornment: (\n                                                        <InputAdornment position=\"start\">\n                                                            <Icon color={customApp('color')}>search</Icon>\n                                                        </InputAdornment>\n                                                    ),\n                                                    onChange: e => {\n                                                        setFindNameUser(e.target.value)\n                                                    },\n                                                }}\n                                            />\n                                            {Object.keys(db.users)\n                                                .filter(a =>\n                                                    // a === a\n                                                    a !== data._id\n                                                    && db.users[a].type === 'user'\n                                                    && !db.users[a].deleted\n                                                    && (\n                                                        (!data._parent\n                                                            &&\n                                                            !db.users[a]._parent\n                                                        )\n                                                        || (\n                                                            data._parent\n                                                            && db.users[a]._parent === data._parent\n                                                        )\n                                                    )\n                                                    && (\n                                                        !findNameUser || (\n                                                            findNameUser && db.users[a].name.toLowerCase().indexOf(findNameUser.toLowerCase().trim()) > -1\n                                                        )\n                                                    )\n                                                )\n                                                .sort((a, b) => {\n                                                    var nameA = db.users[a].name.toLowerCase()\n                                                    var nameB = db.users[b].name.toLowerCase()\n                                                    if (nameA < nameB)\n                                                        return -1\n                                                    if (nameA > nameB)\n                                                        return 1\n                                                    return 0\n                                                })\n                                                .map(pr =>\n                                                    <div\n                                                        style={{\n                                                            cursor: 'pointer',\n                                                            marginBottom: '7px',\n                                                            display: 'flex',\n                                                            alignItems: 'center'\n                                                        }}\n                                                        onClick={() => {\n                                                            setSelectedUser(pr)\n                                                        }}\n                                                        key={pr}\n                                                    >\n                                                        <Avatar alt={db.users[pr].name} src={db.users[pr].image || null}\n                                                            style={{ marginRight: '15px' }}\n                                                        >\n                                                            {db.users[pr].name.substr(0, 1)}\n                                                        </Avatar>\n                                                        <span>{db.users[pr].name}</span>\n                                                    </div>\n                                                )}\n                                        </fieldset>\n                                    }\n                                    <fieldset style={{ textAlign: \"center\" }} >\n                                        <legend style={{ color: customApp(\"color\") }}>{translate(\"$__deactivateThis\", 1)}</legend>\n                                        <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                                            {translate(\"$__deactivateWhithoutMigration\", 1)}\n                                        </div>\n                                        <Buttom onClick={() => { deleteThis() }} >{translate(\"$__deactivateThis\", 1)}</Buttom>\n                                    </fieldset>\n                                </React.Fragment>\n                                :\n                                <fieldset style={{ textAlign: \"center\" }} >\n                                    <legend style={{ color: customApp(\"color\") }}>{translate(\"$__deactivateThis\", 1)}</legend>\n                                    <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                                        {translate(\"$__deactivateUserDescription\", 1)}\n                                    </div>\n                                    <Buttom onClick={() => { deleteThis() }} >{translate(\"$__deactivateThis\", 1)}</Buttom>\n                                </fieldset>\n                            }\n\n                        </React.Fragment>\n                        :\n                        <React.Fragment></React.Fragment>\n                    }\n                    {Load ?\n                        <div style={{\n                            position: 'relative',\n                            width: '100%',\n                            display: 'flex',\n                            justifyContent: 'center',\n                            alignItems: 'center',\n                            marginTop: '33px'\n                        }}>\n                            <CircularProgress />\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                </React.Fragment>\n            }\n        </div >\n    )\n}\nconst mapStateToProps = store => ({\n    store\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","//CORE\r\nimport React from \"react\"\r\nimport styled from \"styled-components\"\r\nimport { DragDropContext, Droppable, Draggable } from \"react-beautiful-dnd\"\r\nimport moment from \"moment-timezone\"\r\nimport { v4 as uuid } from \"uuid\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n//COMPONENTS\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport TextField from \"components/TextField\"\r\nimport Icon from \"components/Icon\"\r\n\r\n\r\n//@MATERIAL\r\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\r\n\r\n//FUNCTIONS\r\nimport api from \"api\"\r\nimport { translate, customApp, appAlert, } from \"functions/\"\r\nimport { automation, linkCard, action } from \"functions/kanban\"\r\n\r\n\r\n\r\nfunction Component(props) {\r\n    const { db, session } = reduxStore.getState()\r\n    const [reason, setReason] = React.useState(\"\")\r\n\r\n    return (\r\n        <div style={{ width: '100%' }} onClick={(e) => e.stopPropagation()}>\r\n            <div style={{ position: 'relative', float: 'right', width: '100%', padding: '7px' }}>\r\n                <div style={{ width: \"100%\", backgroundColor: \"#FFFFFF\", padding: 3, borderRadius: 7, }}>\r\n                    <TextField\r\n                        label={translate(\"$__ApprovalOrRejectReason\", 1)}\r\n                        variant={customApp(\"fieldVariant\")}\r\n                        name=\"reason\"\r\n                        InputProps={{\r\n                            autoComplete: \"new-password\",\r\n                            multiline: true,\r\n                            minRows: 3,\r\n                            endAdornment: (\r\n                                <InputAdornment position=\"end\">\r\n                                    <Icon icon=\"toc\" />\r\n                                </InputAdornment>\r\n                            ),\r\n                            onChange: (d) => {\r\n                                setReason(d.target.value)\r\n                            },\r\n                        }}\r\n                        value={reason}\r\n                        placeholder={translate(\"$__ApprovalOrRejectReason\", 1)}\r\n                    />\r\n                </div>\r\n                <div style={{\r\n                    display: 'flex', alignContent: 'flex-end', justifyContent: 'center'\r\n                }}>\r\n                    <CustomButton\r\n                        reverse\r\n                        title={translate(\"$__indorse\")}\r\n                        text={translate(\"$__indorse\")}\r\n                        color={\"green\"}\r\n                        textColor={\"green\"}\r\n                        icon={\"approval\"}\r\n                        onClick={() => {\r\n                            appAlert({\r\n                                message: translate('$__confirmApproveItem', 1),\r\n                                variant: 'warning',\r\n                                persist: false,\r\n                                horizontal: 'right',\r\n                                confirm: () => {\r\n                                    action({ ...props, reason, approval: true, approved: true },)\r\n                                }\r\n                            })\r\n                        }}\r\n                        size={\"25px\"}\r\n                        style={{ padding: 12 }}\r\n                    />\r\n                    <CustomButton\r\n                        reverse\r\n                        title={translate(\"$__reject\")}\r\n                        text={translate(\"$__reject\")}\r\n                        color={\"red\"}\r\n                        textColor={\"red\"}\r\n                        icon={\"backspace\"}\r\n                        onClick={() => {\r\n                            appAlert({\r\n                                message: translate('$__confirmRejectItem', 1),\r\n                                variant: 'warning',\r\n                                persist: false,\r\n                                horizontal: 'right',\r\n                                confirm: () => {\r\n                                    action({ ...props, reason, approval: true })\r\n                                }\r\n                            })\r\n                        }}\r\n                        size={\"25px\"}\r\n                        style={{ padding: 12 }}\r\n                    />\r\n                </div>\r\n            </div>\r\n        </div >\r\n    )\r\n}\r\n\r\nconst Container = styled.div`\r\n            background-color:none\r\n            ${props =>\r\n        props.isDragDisable\r\n            ? \"\"\r\n            : props.isDragging\r\n                ? `opacity:0.88`\r\n                : ``\r\n    }\r\n            `\r\n\r\nconst mapStateToProps = (store) => ({\r\n    cards: store.db.cards,\r\n}\r\n)\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","import React from 'react';\nimport Grid from '@material-ui/core/Grid';\nimport Button from '@material-ui/core/Button';\nimport ButtonGroup from '@material-ui/core/ButtonGroup';\nimport ArrowDropDownIcon from '@material-ui/icons/ArrowDropDown';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport Grow from '@material-ui/core/Grow';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport MenuList from '@material-ui/core/MenuList';\n\nimport { translate } from \"functions/\";\n\nconst marks = (props) => {\n    return [\n        {\n            value: 0,\n            label: 'Manual',\n        },\n        {\n            value: 7,\n            label: `7 ${translate('$__days', 1).toLowerCase()}`,\n        },\n        {\n            value: 15,\n            label: `15 ${translate('$__days', 1).toLowerCase()}`,\n        },\n        {\n            value: 30,\n            label: `30 ${translate('$__days', 1).toLowerCase()}`,\n        },\n        {\n            value: 60,\n            label: `60 ${translate('$__days', 1).toLowerCase()}`,\n        },\n        {\n            value: 90,\n            label: `90 ${translate('$__days', 1).toLowerCase()}`,\n        },\n        {\n            value: 180,\n            label: `180 ${translate('$__days', 1).toLowerCase()}`,\n        },\n        {\n            value: 365,\n            label: `365 ${translate('$__days', 1).toLowerCase()}`,\n        },\n        ...props.parentDate ?\n            [\n                {\n                    value: 'parent',\n                    label: `${translate('$__useParentDate')} ${props.parentDate.iniDate} - ${props.parentDate.iniDate}`,\n                }\n            ] : [],\n    ]\n}\n\nexport default function SplitButton(props) {\n    const [open, setOpen] = React.useState(false);\n    const anchorRef = React.useRef(null);\n    const [selectedIndex, setSelectedIndex] = React.useState(0);\n\n    React.useEffect(() => {\n        setSelectedIndex(props.value ? props.value : props.defaultValue ? props.defaultValue : 0)\n    }, [props.value])\n\n    const handleToggle = () => {\n        setOpen((prevOpen) => !prevOpen);\n    };\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n\n        setOpen(false);\n    };\n\n    return (\n        <React.Fragment>\n            <ButtonGroup variant=\"text\" ref={anchorRef} aria-label=\"split button\">\n                <Button\n                    onClick={() => {\n                        setSelectedIndex(selectedIndex)\n                        if (props.onChange)\n                            props.onChange(selectedIndex)\n                    }}\n                >{props.options.filter(a => a.value === selectedIndex).length > 0 && props.options.filter(a => a.value === selectedIndex)[0].label}</Button>\n                <Button\n                    size=\"small\"\n                    aria-controls={open ? 'split-button-menu' : undefined}\n                    aria-expanded={open ? 'true' : undefined}\n                    aria-label=\"select merge strategy\"\n                    aria-haspopup=\"menu\"\n                    onClick={handleToggle}\n                >\n                    <ArrowDropDownIcon />\n                </Button>\n            </ButtonGroup>\n            <Popper\n                open={open}\n                anchorEl={anchorRef.current}\n                role={undefined}\n                transition\n            // disablePortal\n            >\n                {({ TransitionProps, placement }) => (\n                    <Grow\n                        {...TransitionProps}\n                        style={{\n                            transformOrigin: placement === 'bottom' ? 'center top' : 'center bottom',\n                        }}\n                    >\n                        <Paper>\n                            <ClickAwayListener onClickAway={handleClose}>\n                                <MenuList id=\"split-button-menu\">\n                                    {props.options.map((option, index) => {\n                                        return (\n                                            <MenuItem\n                                                key={option.value}\n                                                selected={option.value === selectedIndex}\n                                                onClick={() => {\n                                                    setSelectedIndex(option.value)\n                                                    handleToggle()\n                                                    if (props.onChange)\n                                                        props.onChange(option.value)\n                                                }}\n                                            >\n                                                {option.label}\n                                            </MenuItem>\n                                        )\n                                    }\n                                    )}\n                                </MenuList>\n                            </ClickAwayListener>\n                        </Paper>\n                    </Grow>\n                )}\n            </Popper>\n        </React.Fragment>\n    );\n}","import React from \"react\";\nimport moment from 'moment-timezone';\n\n//COMPONENTS\nimport GroupedButton from \"components/Buttons/grouped\";\nimport Icon from \"components/Icon\";\nimport Switch from \"components/Switch\";\nimport TextField from \"components/TextField\";\n\n//@MATERIAL\nimport { makeStyles } from '@material-ui/core/styles';\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//FUNCTIONS\nimport { translate, customApp, getAppAccess } from \"functions/\";\n\nconst useStyles = makeStyles((theme) => ({\n    root: {\n        position: \"relative\",\n        width: \"100%\",\n    },\n    options: {\n        position: \"relative\",\n        width: \"100%\",\n        display: \"flex\",\n        justifyContent: \"space-between\",\n        alignItems: \"center\",\n        borderBottom: \"solid 1px rgba(0,0,0,0.05)\",\n        marginTop: \"7px\"\n    },\n    custom: {\n        position: \"relative\",\n        width: \"100%\",\n        padding: \"7px\",\n        backgroundColor: 'rgba(0,0,0,0.05)',\n        marginTop: '7px'\n    },\n\n    margin: {\n        height: theme.spacing(3),\n    },\n}));\n\nconst clearRecurrenceData = {\n    recurrence: \"0\",\n    recurrenceRepeatDays: null,\n    recurrenceEndDate: null,\n    recurrenceLimit: null,\n    recurrenceMyDay: null,\n    recurrenceOnlyCompleted: null,\n    recurrenceDuplicateCard: null,\n}\n\nfunction Comp(props) {\n    const [data, setCompData] = React.useState({\n        recurrence: \"0\"\n    })\n    const classes = useStyles();\n\n    React.useEffect(() => {\n        setCompData({\n            recurrence: props.data && props.data.recurrence ? props.data.recurrence : \"0\",\n            recurrenceRepeatDays: props.data && props.data.recurrenceRepeatDays ? props.data.recurrenceRepeatDays : null,\n            recurrenceEndDate: props.data && props.data.recurrenceEndDate ? props.data.recurrenceEndDate : null,\n            recurrenceLimit: props.data && props.data.recurrenceLimit ? props.data.recurrenceLimit : null,\n            recurrenceMyDay: props.data && props.data.recurrenceMyDay ? props.data.recurrenceMyDay : null,\n            recurrenceOnlyCompleted: props.data && props.data.recurrenceOnlyCompleted ? props.data.recurrenceOnlyCompleted : null,\n            recurrenceDuplicateCard: props.data && props.data.recurrenceDuplicateCard ? props.data.recurrenceDuplicateCard : null,\n        })\n    }, [])\n\n    React.useEffect(() => {\n\n    }, [props.data.startDate])\n\n    const calcNextRecurrence = (values) => {\n        let days = values.recurrence\n        if (values.recurrence === 'custom')\n            days = values.recurrenceRepeatDays\n        let result = values\n        let newDate = moment(props.data.startDate * 1000).tz('America/Sao_Paulo').add(days, 'd').format('YYYY-MM-DD')\n        if (moment(props.data.startDate * 1000).tz('America/Sao_Paulo').add(days, 'd').unix('X') < moment().tz('America/Sao_Paulo').unix('X'))\n            newDate = moment().tz('America/Sao_Paulo').add(days, 'd').format('YYYY-MM-DD')\n        result = {\n            ...values,\n            recurrenceNextDate: newDate,\n        }\n        return result\n    }\n\n    const setData = (values) => {\n        let result = values\n        if (!isNaN(values.recurrence) || values.recurrence === 'custom') {\n            result = calcNextRecurrence(values)\n        }\n        if (values.recurrence && parseInt(values.recurrence) > 0 && parseInt(values.recurrence) < 31)\n            result = {\n                ...result,\n                recurrenceNextDate: moment().tz('America/Sao_Paulo').add(parseInt(values.recurrence), 'days').format('YYYY-MM-DD')\n            }\n        if (values.recurrence === 'everyFriday')\n            result = {\n                ...result,\n                recurrenceNextDate: moment().tz('America/Sao_Paulo').add(1, 'weeks').isoWeekday(5).format('YYYY-MM-DD')\n            }\n\n        if (values.recurrence === 'everyMonday')\n            result = {\n                ...result,\n                recurrenceNextDate: moment().tz('America/Sao_Paulo').add(1, 'weeks').isoWeekday(1).format('YYYY-MM-DD')\n            }\n\n        if (values.recurrence === 'everyFirstMonthDay')\n            result = {\n                ...result,\n                recurrenceNextDate: moment().tz('America/Sao_Paulo').add(1, 'month').format('YYYY-MM-01')\n            }\n\n        setCompData(result)\n        if (props.onChange)\n            props.onChange(result)\n    }\n\n    return (\n        <div id=\"RecurrencySettings\" className={classes.root}>\n            <div className={classes.options}>\n                {translate('$__recurrence')}\n                <GroupedButton\n                    options={[\n                        {\n                            value: \"0\",\n                            label: translate('$__nonrecurrence'),\n                        },\n                        {\n                            value: '1',\n                            label: translate('$__everyDay'),\n                        },\n                        {\n                            value: '7',\n                            label: translate('$__weekly'),\n                        },\n                        {\n                            value: '15',\n                            label: translate('$__every15days'),\n                        },\n                        {\n                            value: '30',\n                            label: translate('$__every30days'),\n                        },\n                        {\n                            value: 'everyFirstMonthDay',\n                            label: translate('$__everyFirstMonthDay'),\n                        },\n                        {\n                            value: 'everyMonday',\n                            label: translate('$__everyMonday'),\n                        },\n                        {\n                            value: 'everyFriday',\n                            label: translate('$__everyFriday'),\n                        },\n                        {\n                            value: 'custom',\n                            label: translate('$__custom'),\n                        }\n                    ]}\n                    value={data && data.recurrence ? data.recurrence : \"0\"}\n                    onChange={(v) => {\n                        if (v === \"0\") {\n                            setData({\n                                ...clearRecurrenceData,\n                                recurrence: null,\n                                recurrenceRepeatDays: null\n                            })\n                        } else if (v !== 'custom') {\n                            setData({\n                                recurrence: `${v}`,\n                                recurrenceRepeatDays: null\n                            })\n                        } else {\n                            setData({\n                                ...data,\n                                recurrence: `${v}`,\n                                recurrenceNextDate: null,\n                                recurrenceRepeatDays: 1\n                            })\n                        }\n                    }}\n                />\n            </div>\n            {(data && data.recurrence && String(data.recurrence) !== \"0\") &&\n                <div className={classes.custom}>\n                    {translate(\"$__preffers\", 1)}\n                    {data && data.recurrence === 'custom' &&\n                        <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>\n                            {translate('$__repeatEvery', 1)}\n                            <TextField\n                                style={{ width: \"100px\" }}\n                                variant={customApp('standard')}\n                                name={'recurrenceRepeatDays'}\n                                type=\"number\"\n                                min=\"1\"\n                                InputLabelProps={{\n                                    shrink: true,\n                                }}\n                                InputProps={{\n                                    min: 1,\n                                    autoComplete: 'new-password',\n                                    endAdornment: (\n                                        <InputAdornment position=\"end\">\n                                            <Icon icon='replay_10' />\n                                            {translate('$__days').toLowerCase()}\n                                        </InputAdornment>\n                                    ),\n                                    onChange: (d) => {\n                                        if (parseInt(d.target.value) > 0)\n                                            setData({\n                                                ...data,\n                                                recurrenceRepeatDays: d.target.value\n                                            })\n                                    },\n                                }}\n                                defaultValue={data.recurrenceRepeatDays ? data.recurrenceRepeatDays : 1}\n                            />\n                        </div>\n                    }\n                    {/* <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>\n                        {translate('$__repeatLimit', 1)}\n                        <TextField\n                            style={{ width: \"152px\" }}\n                            variant={customApp('standard')}\n                            name={'repeatLimit'}\n                            type=\"number\"\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='replay_10' />\n                                        {translate('$__times').toLowerCase()}\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    setData({\n                                        ...data,\n                                        recurrenceLimit: d.target.value\n                                    })\n                                },\n                            }}\n                            defaultValue={data.recurrenceLimit}\n                            helperText={translate('$__0toUnlimited')}\n                        />\n                    </div> */}\n                    <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>\n                        {translate('$__limitDate', 1)}\n                        <TextField\n                            style={{ width: \"200px\" }}\n                            variant={customApp('standard')}\n                            name=\"endDate\"\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            type='date'\n                            InputProps={{\n                                endAdornment: data.recurrenceEndDate ? (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='clear'\n                                            onClick={() => {\n                                                setData({\n                                                    ...data,\n                                                    recurrenceEndDate: null\n                                                })\n                                            }}\n                                        />\n                                    </InputAdornment>\n                                ) : null,\n                                autoComplete: 'new-password',\n                                onBlur: (d) => {\n                                    setData({\n                                        ...data,\n                                        recurrenceEndDate: d.target.value ? moment(d.target.value).tz('America/Sao_Paulo').format('YYYY-MM-DD') : null\n                                    }\n                                    )\n                                },\n                                onChange: (d) => {\n                                    setData({\n                                        ...data,\n                                        recurrenceEndDate: d.target.value ? moment(d.target.value).tz('America/Sao_Paulo').format('YYYY-MM-DD') : null,\n                                    })\n                                },\n                            }}\n                            defaultValue={props.data.recurrenceEndDate ? props.data.recurrenceEndDate : null}\n                        />\n                    </div>\n\n                    {/* <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>\n                        {translate('$__addToMyDay', 1)}\n                        <Switch\n                            checked={data.recurrenceMyDay ? true : false}\n                            onChange={(d) => {\n                                setData({\n                                    ...data,\n                                    recurrenceMyDay: data.recurrenceMyDay ? false : true\n                                })\n                            }}\n                            name=\"recurrenceMyDay\"\n                            inputProps={{ 'aria-label': 'secondary checkbox' }}\n                        />\n                    </div> */}\n                    <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>\n                        {translate('$__recurrenceDuplicateCard', 1)}\n                        <Switch\n                            checked={data.recurrenceDuplicateCard ? true : false}\n                            onChange={(d) => {\n                                setData({\n                                    ...data,\n                                    recurrenceDuplicateCard: data.recurrenceDuplicateCard ? false : true,\n                                    ...data.recurrenceDuplicateCard ? { recurrenceCopyCatenation: false } : {}\n                                })\n                            }}\n                            name=\"duplicate\"\n                            inputProps={{ 'aria-label': 'secondary checkbox' }}\n                        />\n                    </div>\n                    {data.recurrenceDuplicateCard &&\n                        <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>\n                            {translate('$__copyCatenation', 1)}\n                            <Switch\n                                checked={data.recurrenceCopyCatenation ? true : false}\n                                onChange={(d) => {\n                                    setData({\n                                        ...data,\n                                        recurrenceCopyCatenation: data.recurrenceCopyCatenation ? false : true\n                                    })\n                                }}\n                                name=\"recurrenceCopyCatenation\"\n                                inputProps={{ 'aria-label': 'secondary checkbox' }}\n                            />\n                        </div>\n                    }\n                    {/* <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'space-between' }}>\n                        {translate('$__createNewOnlyWhenPreviousIsCompleted', 1)}\n                        <Switch\n                            checked={data.recurrenceOnlyCompleted ? true : false}\n                            onChange={(d) => {\n                                setData({\n                                    ...data,\n                                    recurrenceOnlyCompleted: data.recurrenceOnlyCompleted ? false : true\n                                })\n                            }}\n                            name=\"recurrenceOnlyCompleted\"\n                            inputProps={{ 'aria-label': 'secondary checkbox' }}\n                        />\n                    </div> */}\n                </div>\n            }\n        </div >\n    )\n}\n\nconst mapStateToProps = (store, ownProps) => ({ store, ownProps });\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(Comp);\n","//CORE\nimport React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\n//@MATERIAL\nimport Autocomplete from \"components/AutoComplete/multiple\";\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Tags-input.js\";\n\nimport {\n    translate,\n    customApp,\n    validateEmail,\n    appAlert,\n    getAppAccess\n} from \"functions/\";\n\nfunction Component(props) {\n    const [values, setValues] = React.useState([])\n\n    const AppAccess = getAppAccess()\n\n    React.useEffect(() => {\n        if (props.data.values) {\n            let newValues = []\n            props.data.values.map(tag => {\n                if (reduxStore.getState().db.tag.filter(a => a.value === tag.value).length > 0)\n                    newValues.push(tag)\n            })\n            setValues(newValues)\n        }\n    }, [props.data])\n\n    const changeTags = async (v) => {\n        if (props.callBack)\n            props.callBack(v)\n        setValues(v)\n    }\n\n    return (\n        <div>\n            <Autocomplete\n                dbNode={props.dbNode ? props.dbNode : 'tag'}\n                secondaryParent={props.secondaryParent ? props.secondaryParent : null}\n                options={reduxStore.getState().db.tag ? reduxStore.getState().db.tag : []}\n                style={{ width: '100%' }}\n                name=\"tag\"\n                ws\n                title={translate(\"$__tags\")}\n                api={\"tag/add\"}\n                add\n                colorPicker={AppAccess && AppAccess.plan && (AppAccess.planAdmin || AppAccess.planModerate) ? true : false}\n                multiple\n                freeSolo\n                disableClearable\n                disabled={props.disabled ? true : false}\n                value={values}\n                placeholder={props.placeholder || null}\n                onChange={\n                    (v) => {\n                        changeTags(v)\n                    }\n                }\n                colorPickerCallBack={(res) => {\n                    reduxStore.getState().functions.socket.emit('tag.UPD', res)\n                }}\n            />\n        </div>\n    )\n}\n\n//REACT\nconst mapStateToProps = (store) => ({\n    tags: store.db.tag,\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","//CORE\nimport React from \"react\"\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport Autocomplete from \"components/AutoComplete\"\nimport Approve from \"components/Card/approval\"\nimport Card from \"components/Card\"\nimport CardTags from \"components/Tags/Card\"\nimport ConnectedIn from \"components/ConnectedIn\"\nimport CustomButton from \"components/Buttons/custom\"\nimport CustomIconButton from \"components/CustomButtons/IconButton\"\nimport DataPicker from \"components/DataPicker\"\nimport GroupedButton from \"components/Buttons/grouped\"\nimport Icon from \"components/Icon\"\nimport ImgCropper from \"components/Cropper\"\nimport LinearProgress from \"components/Progress/linear\"\nimport QuickUsers from \"components/User/quick\"\nimport RecurrenceSettings from \"components/Recurrence/settings\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\nimport Switch from \"components/Switch\"\nimport TagsInput from \"components/Tags/input\"\nimport TextField from \"components/TextField\"\nimport Timer from \"components/Timer/timer\"\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card.js\"\n\n//FUNCTIONS\nimport api from \"api/\"\n\nimport {\n    cardStatus,\n    getUserAccess,\n    planMyAccountVerify,\n    saveCard,\n    setMyDay,\n    updateCardStatus,\n    verifyTemplate,\n} from \"functions/cards\"\n\nimport {\n    loadCardsV2\n} from \"functions/loadData\"\n\nimport {\n    appAlert,\n    customApp,\n    favoriteNode,\n    getAppAccess,\n    getDate,\n    translate,\n} from \"functions/\"\n\n//ICONS\nimport MatrixIcon from \"assets/icons/Matrix.js\"\n\n\nfunction Component(props) {\n    const { classes, sideModule } = props\n    const { db, session } = reduxStore.getState()\n    const { planType } = db\n\n    const [data, setData] = React.useState({})\n    const [newData, setNewData] = React.useState({})\n    const [reqSave, setReqSave] = React.useState(false)\n    const [saveLoader, setSaveLoader] = React.useState(false)\n    const [setDate, setSetDate] = React.useState(false)\n    const [mounted, setMounted] = React.useState(false)\n    const [startDate, setStartDate] = React.useState(null)\n    const [endDate, setEndDate] = React.useState(null)\n    const [miroOption, setMiroOption] = React.useState(false)\n    const [dateDays, setDateDays] = React.useState(0)\n    const [loadingData, setLoadingData] = React.useState(false)\n\n    let AppAccess = getAppAccess()\n    let CardAccess = getUserAccess(sideModule.id)\n\n    React.useEffect(() => {\n        if (data._id !== sideModule.data._id) {\n            setData(sideModule.data)\n            setReqSave(false)\n        }\n        if (!mounted) {\n            if (sideModule.data.startDate)\n                setStartDate(sideModule.data && sideModule.data.startDate ? sideModule.data.startDate : null)\n\n            if (sideModule.data.endDate)\n                setEndDate(sideModule.data && sideModule.data.endDate ? sideModule.data.endDate : null)\n            setData(sideModule.data)\n            setReqSave(false)\n\n            if (data.type === \"link\" && !data.name)\n                loadUrlContent()\n            setMounted(true)\n            reqFullData()\n        }\n        if (sideModule.data.name && sideModule.data.name.trim() !== \"\" && sideModule.data.type === \"link\" && sideModule.data._id === \"new\") {\n            setReqSave(true)\n            if (props.reqSave)\n                props.reqSave(true)\n        }\n        // return () => {\n        //     setMounted(false)\n        // }\n    }, [sideModule.data, data])\n\n    React.useEffect(() => {\n        if (!data.name || (data.name && data.name.trim === \"\")) {\n            setReqSave(false)\n        } else {\n            setReqSave(true)\n        }\n    }, [newData])\n\n    React.useEffect(() => {\n        if (props.cards[data._id]\n            && (\n                (\n                    props.cards[data._id]._requireApproval\n                    && !data._requireApproval\n                )\n                ||\n                (\n                    !props.cards[data._id]._requireApproval\n                    && data._requireApproval\n                )\n            )\n        )\n            setData({\n                ...data,\n                _requireApproval: !props.cards[data._id]._requireApproval\n            })\n    }, [props.cards])\n\n    const reqParents = async (parent) => {\n        if (!db.cards[parent]) {\n            await loadCardsV2({ ...props, ignoreLoader: true }, {\n                idRel: [parent],\n                cardLoad: \"parents\"\n            })\n        } else if (db.cards[parent] && db.cards[parent]._parent) {\n            setLoadingData(true)\n            let response = reqParents(db.cards[parent]._parent)\n            if (response)\n                setLoadingData(false)\n        } else {\n            setLoadingData(false)\n        }\n    }\n\n    const reqFullData = async () => {\n        const loadParents = await loadCardsV2({ ...props, ignoreLoader: true }, {\n            idRel: [sideModule.data._id],\n            cardLoad: \"parents\"\n        })\n        if (loadParents)\n            setLoadingData(false)\n    }\n\n    const changeData = (d, d2, clear = false) => {\n        if (\n            (\n                d.value\n                &&\n                (\n                    !sideModule.data[d.name]\n                    &&\n                    !data[d.name]\n                )\n            )\n            ||\n            (\n                sideModule.data[d.name]\n                && sideModule.data[d.name] !== d.value\n            )\n            ||\n            clear\n        ) {\n            // setReqSave(true)\n            if (props.reqSave)\n                props.reqSave(true)\n        }\n\n\n        let newDataCD = {\n            ...data,\n            [d.name]: d.value,\n        }\n        if (d2 && d2.name && d2.value) {\n            newDataCD = {\n                ...data,\n                ...newDataCD,\n                [d2.name]: d2.value\n            }\n        }\n        setData(newDataCD)\n        setNewData({\n            ...newData,\n            [d.name]: d.value,\n            ...d2 && d2.name && d2.value ? {\n                [d2.name]: d2.value\n            } : {}\n        })\n    }\n\n    const close = (cl) => {\n        if (reqSave && !cl) {\n            appAlert({\n                message: translate(\"$__confirmCloseWithUnsavedData\", 1),\n                variant: \"warning\",\n                persist: false,\n                horizontal: \"right\",\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n        }\n    }\n    const save = async (cl = false) => {\n        if (!saveLoader) {\n            setReqSave(false)\n            if (props.reqSave)\n                props.reqSave(false)\n            if (!data.status)\n                data.status = \"notStarted\"\n            if (sideModule.id === \"new\" && sideModule.data) {\n                setData({\n                    ...data,\n                    ...sideModule.data\n                })\n            }\n            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                ...sideModule,\n                data: data\n            })\n\n            if (!data.name || (data.name && data.name.trim() === \"\")) {\n                setSaveLoader(false)\n                appAlert({\n                    message: translate(\"$__fillName\", 1),\n                    variant: \"warning\",\n                    persist: false,\n                    horizontal: \"right\",\n                    confirm: null\n                })\n            } else {\n                const request = await saveCard({\n                    ...props,\n                    store: {\n                        ...props.store,\n                        db: {\n                            ...reduxStore.getState().db\n                        }\n                    }\n                }, cl, data)\n                if (request) {\n                    if (newData && newData.status) {\n                        updateCardStatus(\n                            {\n                                ...props,\n                                data: { _id: data._id }\n                            }, { status: newData.status })\n                        cardStatus(props, data._id, newData.status)\n                    }\n                    setSaveLoader(false)\n                    appAlert({\n                        message: translate(\"$__DataSaved\", 1),\n                        variant: null,\n                        persist: false,\n                        horizontal: \"right\",\n                        confirm: null\n                    })\n                }\n                setReqSave(false)\n                if (props.reqSave)\n                    props.reqSave(false)\n                if (cl)\n                    close(true)\n            }\n        }\n    }\n\n    const loadUrlContent = async () => {\n        const result = await api.post(`/link/content`, {\n            url: data.url\n        })\n        setData({\n            ...data,\n            content: result.data.article,\n        })\n        setReqSave(true)\n        if (props.reqSave)\n            props.reqSave(true)\n    }\n\n    const dataType = sideModule.data && sideModule.data.type ? db.dataType.filter(a => a.name === sideModule.data.type)[0] : {}\n\n    let parentData = null\n    if (data._parent)\n        parentData = reduxStore.getState().db.cards[data._parent]\n\n    if (!data)\n        return null\n\n    let myDay = reduxStore.getState().db.cards[data._id] && reduxStore.getState().db.cards[data._id]._users && reduxStore.getState().db.cards[data._id]._users[session._id] && reduxStore.getState().db.cards[data._id]._users[session._id].myDay ? reduxStore.getState().db.cards[data._id]._users[session._id].myDay : null\n    let myDayOption = !myDay || (myDay && myDay && moment(new Date(myDay * 1000)).format(\"YYYY/MM/DD\") !== moment().format(\"YYYY/MM/DD\")) ? true : false\n\n\n    const isTemplate = data.isTemplate ? data.isTemplate : verifyTemplate(data._id)\n\n    let permission = props.permission ? props.permission : false\n\n    if (data && data._planId && (!db.cards[data._planId] || !planMyAccountVerify(data._planId)))\n        permission = false\n\n    if (!permission && parseInt(CardAccess) >= 4)\n        permission = true\n\n    if (!permission && planMyAccountVerify(data._planId) && AppAccess && AppAccess.admin && AppAccess.plan && (AppAccess.planAdmin || AppAccess.planModerate))\n        permission = true\n\n\n    let hasYoutube = false\n    let youtube = (<React.Fragment></React.Fragment>)\n    if (data && data.url && data.url.indexOf(\".youtube.com/watch?\") > -1) {\n        let ybQuery = data.url.split(\"?\")[1].split(\"v=\")[1].split(\"&\")[0]\n        if (ybQuery) {\n            youtube = (\n                <iframe\n                    width=\"560\"\n                    height=\"315\"\n                    style={{\n                        top: 0,\n                        width: \"100%\",\n                        maxWidth: \"500px\",\n                        height: \"100%\",\n                        alignSelf: \"center\",\n                        position: \"absolute\",\n                        overflow: \"hidden\"\n                    }}\n                    src={`https://www.youtube.com/embed/${ybQuery}`}\n                    title=\"YouTube video player\"\n                    frameBorder=\"0\"\n                    allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                    allowFullScreen >\n\n                </iframe >\n            )\n            hasYoutube = true\n        }\n    }\n\n    if (data && data.url && data.url.indexOf(\"//youtu.be/\") > -1) {\n        let ybQuery = data.url.split(\".be/\")[1]\n        if (ybQuery) {\n            youtube = (\n                <iframe\n                    width=\"560\"\n                    height=\"315\"\n                    style={{\n                        top: 0,\n                        width: \"100%\",\n                        maxWidth: \"500px\",\n                        height: \"100%\",\n                        alignSelf: \"center\",\n                        position: \"absolute\",\n                        overflow: \"hidden\"\n                    }}\n                    src={`https://www.youtube.com/embed/${ybQuery}`}\n                    title=\"YouTube video player\"\n                    frameBorder=\"0\"\n                    allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                    allowFullScreen >\n\n                </iframe >\n            )\n            hasYoutube = true\n        }\n    }\n\n\n\n    return (\n        <React.Fragment>\n            <SideModuleCloseAndSave\n                save={reqSave ? () => {\n                    setSaveLoader(true)\n                    save()\n                } : null}\n                saveClose={reqSave ? () => {\n                    setSaveLoader(true)\n                    save(true)\n                } : null}\n                saveLoader={saveLoader}\n                close={() => {\n                    if (props.onClose)\n                        props.onClose()\n                }}\n            />\n            <div className={classes.root}>\n                {data._requireApproval ?\n                    <div style={{ position: \"relative\", width: \"100%\", background: customApp(\"ColumnTitleColor\"), padding: 7, display: \"grid\" }}>\n                        <div\n                            style={{\n                                color: \"red\",\n                                fontWeight: \"bold\",\n                                fontSize: 14\n                            }}\n                        >{translate(\"$__attention\", 1)}: <span style={{ color: \"#FFFFFF\" }}>{translate(\"$__thisActivityRequireApproval\", 1)}</span></div>\n                        <Approve nodeId={data._id} />\n                    </div>\n                    : <React.Fragment></React.Fragment>\n                }\n                {hasYoutube ?\n                    <div\n                        style={{\n                            backgroundRepeat: 'no-repeat',\n                            backgroundSize: 'cover',\n                            backgroundPosition: 'center',\n                            paddingTop: '48%',\n                            display: 'flex',\n                            justifyContent: 'center',\n                            alignItems: 'center',\n                            position: 'relative',\n                            float: 'left',\n                            width: '100%',\n                            clear: \"both\"\n                        }}\n                    >\n                        {youtube}\n                    </div>\n                    : <React.Fragment></React.Fragment>\n                }\n                {permission && (!dataType.hideFields || (dataType.hideFields && dataType.hideFields.indexOf(\"imageUpload\") === -1)) &&\n                    <ImgCropper img={data ? data.image : null}\n                        onChange={(a, file) => {\n                            changeData({ name: \"image\", value: a })\n                            changeData({ name: \"file\", value: file })\n                        }}\n                        files={data._files ? data._files : {}}\n                        maxWidthOrHeight={600}\n                        avatar={data.type === \"chatGroup\" ? true : false}\n                        aspectRatio={data.type === \"chatGroup\" ? null : 16 / 9}\n                        onDelete={() => {\n                            changeData({ name: \"image\", value: null }, { name: \"file\", value: null }, true)\n                        }}\n                    />\n                }\n                {!permission && data.image &&\n                    <div className={classes.image}\n                        style={{\n                            backgroundImage: `url(${data.image})`\n                        }}\n                    ></div>\n                }\n                {data.type === \"plan\" && !data._id ?\n                    <fieldset style={{ marginBottom: '14px', marginTop: 30 }}>\n                        <Autocomplete\n                            id=\"combo-box-demo\"\n                            options={planType}\n                            getOptionLabel={(option) => translate(option.label, 1)}\n                            style={{ width: '100%' }}\n                            name=\"planType\"\n                            disableClearable\n                            value={data && data.planType ? planType.filter(a => a.value === data.planType)[0] : planType[0]}\n                            renderInput={(params) =>\n                                <TextField\n                                    {...params}\n                                    label={translate('$__planType', 1)}\n                                    variant={customApp('fieldVariant')}\n                                    value={data && data.planType ? planType.filter(a => a.value === data.planType)[0] : planType[0]}\n                                />\n                            }\n                            onChange={\n                                (d, v) => {\n                                    changeData({ name: 'planType', value: v['value'] })\n                                }\n                            }\n                        />\n                        {\n                            planType.filter(a =>\n                                !data.planType\n                                || (data.planType\n                                    && a.value === data.planType\n                                    && a.swot === true\n                                )\n                            ).length > 0 ?\n                                <div style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                }}>\n                                    <div style={{\n                                        width: \"fit-content\",\n                                        display: \"flex\",\n                                        alignItems: \"center\",\n                                        justifyContent: \"center\",\n                                        fontWeight: \"bold\",\n                                        color: customApp(\"color\")\n                                    }}>\n                                        <Icon icon={MatrixIcon} color={customApp('color')} size={25} /><span style={{ marginLeft: 15 }}>MATRIX SWOT</span>\n                                    </div>\n\n                                </div>\n                                :\n                                <React.Fragment></React.Fragment>\n                        }\n                        <div>{translate(planType.filter(a =>\n                            !data.planType\n                            || (data.planType\n                                && a.value === data.planType\n                            )\n                        )[0].description, 1)}</div>\n                    </fieldset>\n                    : <React.Fragment></React.Fragment>}\n                <div className={classes.data}>\n                    {(data._parent || data._planId) && loadingData ?\n                        <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"center\", width: \"100%\", height: \"auto\" }}>\n                            <span style={{ color: customApp(\"menu\"), fontSize: \"12px\", paddingRight: \"15px\", whiteSpace: \"nowrap\" }}>{translate(\"$__loadingdata\")}</span>\n                            <LinearProgress />\n                        </div>\n                        : ((data._parent && db.cards[data._parent]) || (data._planId && db.cards[data._planId])) &&\n                        <ConnectedIn\n                            id={data._parent ? data._parent : data._planId ? data._planId : null}\n                            open={(id) => {\n                                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                    ...reduxStore.getState().sideModule,\n                                    db: \"cards\",\n                                    id: id,\n                                    ...reduxStore.getState().db.cards[id].type === \"step\" ? {\n                                        module: \"columnEdit\",\n                                        activeModule: \"columnEdit\"\n                                    } : {\n                                        module: \"cardEdit\",\n                                        activeModule: \"cardEdit\"\n                                    },\n\n                                    data: reduxStore.getState().db.cards[id],\n                                })\n                            }}\n                        />\n                    }\n\n                    <div style={{\n                        position: \"relative\",\n                        alignItems: \"center\",\n                        clear: 'both',\n                        justifyContent: \"space-between\",\n                        display: \"flex\",\n                    }}>\n                        {data._id && db.cards[data._id] && db.cards[data._id]._users &&\n                            <QuickUsers _id={data._id} noLimit avatarSize=\"33px\" permission={permission} />\n                        }\n                        <div\n                            style={{\n                                display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\"\n                            }}\n                        >\n                            {\n                                data.type === \"plan\" && data._id && permission ?\n                                    <CustomButton\n                                        title={translate(\"$__openPlan\", 1)}\n                                        icon={\"launch\"}\n                                        color={\"lightgray\"}\n                                        onClick={() => {\n                                            history.push(`sp#${data._id}/dashboard`)\n                                            close(true)\n                                        }\n                                        }\n                                        size={\"25px\"}\n                                    />\n                                    : <React.Fragment></React.Fragment>\n                            }\n                            {props.card && props.card._id && props.card.type === \"plan\" ?\n                                <CustomButton\n                                    title={translate(props.card && props.card._isFavorite ? \"$__removeFromFavorite\" : \"$__addToFavorite\", 1)}\n                                    icon={props.card && props.card._isFavorite ? \"favorite\" : \"favorite_border\"}\n                                    color={props.card && props.card._isFavorite ? \"red\" : \"lightgray\"}\n                                    onClick={() => {\n                                        favoriteNode(props, data._id, props.card && props.card._isFavorite ? true : false)\n                                        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                                            ...reduxStore.getState().db,\n                                            cards: {\n                                                ...reduxStore.getState().db.cards,\n                                                [data._id]: {\n                                                    ...reduxStore.getState().db.cards[data._id],\n                                                    _isFavorite: props.card && props.card._isFavorite ? false : true\n                                                },\n                                            }\n                                        })\n                                    }\n                                    }\n                                    size={\"25px\"}\n                                />\n                                : <React.Fragment></React.Fragment>\n                            }\n                            {(data._id\n                                && data._id.length === 36\n                                && data.type !== \"chatGroup\"\n                                && data.type !== \"plan\"\n                            ) &&\n                                <CustomButton\n                                    title={translate(myDay && moment(new Date(myDay * 1000)).format(\"YYYY/MM/DD\") === moment().format(\"YYYY/MM/DD\") ? \"$__removeOfMyDate\" : \"$__addOnMyDay\", 1)}\n                                    color={myDay && moment(new Date(myDay * 1000)).format(\"YYYY/MM/DD\") === moment().format(\"YYYY/MM/DD\") ? \"red\" : \"lightblue\"}\n                                    icon={myDay && moment(new Date(myDay * 1000)).format(\"YYYY/MM/DD\") === moment().format(\"YYYY/MM/DD\") ? \"auto_delete\" : \"alarm_add\"}\n                                    onClick={() => {\n                                        setMyDay(props, {\n                                            _id: data._id,\n                                            userId: session._id,\n                                            option: myDayOption\n                                        })\n                                        if (props.myDayClick)\n                                            props.myDayClick()\n                                    }\n                                    }\n                                    size={\"25px\"}\n                                />\n                            }\n                        </div>\n                    </div>\n                    <div>\n                        {props.card\n                            && data.type !== \"plan\"\n                            && data.type !== \"chatGroup\"\n                            && props.card._id\n                            && props.card._users[session._id]\n                            && data.status !== \"completed\"\n                            && CardAccess > 0\n                            ?\n                            <div\n                                style={{\n                                    position: 'relative',\n                                    width: '100%',\n                                    float: 'left'\n                                }}\n                                onClick={(e) => {\n                                    e.stopPropagation()\n                                }}\n                            >\n                                <Timer data={props.card} />\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                    </div>\n                    <fieldset style={{ marginBottom: \"14px\" }}>\n                        <legend>{data.type === 'plan' && data._id ? translate(`$__plan ${data.planType ? planType[1].label : planType[0].label}`, 1) : translate(\"$__data\", 1)}</legend>\n                        <div\n                            style={{\n                                display: \"flex\",\n                                justifyContent: \"space-between\",\n                                alignItems: \"center\",\n                                marginBottom: 7\n                            }}\n                        >\n                            <div\n                                style={{\n                                    color: \"gray\"\n                                }}\n                            >{data._cardCode ? `#${data._cardCode} ` : ``}</div>\n                            {data.created_at ?\n                                <div\n                                    style={{\n                                        position: \"relative\",\n                                        fontSize: 12,\n                                        color: \"#bfbfbf\",\n                                        padding: \"3px 0px\",\n                                        textAlign: \"right\",\n                                        marginLeft: 10\n                                    }}>\n                                    {translate(\"$__createdAt\")}: {getDate(data.created_at)}\n                                </div>\n                                : <React.Fragment></React.Fragment>\n                            }\n                        </div>\n                        <TextField\n                            label={translate(dataType && dataType.fieldsTitle && dataType.fieldsTitle.name ? dataType.fieldsTitle.name : \"$__titleOfCard\", 1)}\n                            variant={customApp(\"fieldVariant\")}\n                            name={\"name\"}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: \"new-password\",\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon=\"view_headline\" />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.name ? data.name : \"\"}\n                            placeholder={translate(dataType && dataType.fieldsTitle && dataType.fieldsTitle.placeholder && dataType.fieldsTitle.placeholder.name ? dataType.fieldsTitle.placeholder.name : \"$__titleOfCard_placeholder\", 1)}\n                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"name\") > -1) ? true : false}\n                        />\n                        {(CardAccess > 3 || data.description || permission)\n                            ?\n                            <React.Fragment>\n                                <TextField\n                                    label={translate(\"$__description\", 1)}\n                                    variant={customApp(\"fieldVariant\")}\n                                    name=\"description\"\n\n                                    InputProps={{\n                                        autoComplete: \"new-password\",\n                                        multiline: true,\n                                        minRows: 3,\n                                        endAdornment: (\n                                            <InputAdornment position=\"end\">\n                                                <Icon icon=\"toc\" />\n                                            </InputAdornment>\n                                        ),\n                                        onChange: (d) => {\n                                            changeData(d.target)\n                                        },\n                                    }}\n                                    value={data && data.description ? data.description : \"\"}\n                                    placeholder={translate(\"$__descriptionOfCard_placeholder\", 1)}\n                                    disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"description\") > -1) ? true : false}\n                                />\n                            </React.Fragment>\n                            :\n                            <React.Fragment></React.Fragment>\n                        }\n\n                        {/* {data.url ?\n                            <React.Fragment> */}\n                        {(CardAccess > 3 || data.url || permission) && data.type !== \"chatGroup\" ?\n                            <TextField\n                                label={translate(\"$__URL\", 1)}\n                                variant={customApp(\"fieldVariant\")}\n                                name={\"url\"}\n                                InputLabelProps={{\n                                    shrink: true,\n                                }}\n                                InputProps={{\n                                    autoComplete: \"new-password\",\n                                    endAdornment: (\n                                        <InputAdornment position=\"end\">\n                                            <Icon icon=\"http\" />\n                                        </InputAdornment>\n                                    ),\n                                    onChange: (d) => {\n                                        changeData(d.target)\n                                    },\n                                }}\n                                value={data && data.url ? data.url : \"\"}\n                                placeholder={\"https://domain.com\"}\n                                disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"name\") > -1) ? true : false}\n                            />\n                            : <React.Fragment></React.Fragment>}\n                        {data.url ?\n                            <div style={{\n                                width: \"100%\",\n                                textAlign: \"right\"\n                            }}>\n                                <a href={data.url} target=\"_blank\" style={{ color: customApp(\"menu\"), fontWeight: \"bold\" }}>{translate(\"$__openlink\", \"*\")}</a>\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                    </fieldset>\n                    {\n                        (CardAccess > 3 || data.client || permission) &&\n                        (\n                            !isTemplate\n                            && (\n                                permission &&\n                                (\n                                    !dataType.hideFields ||\n                                    (\n                                        dataType.hideFields &&\n                                        dataType.hideFields.indexOf(\"client\") === -1)\n                                )\n                            ) &&\n                            (\n                                !data.client ||\n                                (\n                                    data.client &&\n                                    db.users[data.client]\n                                )\n                            )\n                        ) &&\n                        <Autocomplete\n                            id=\"combo-box-demo\"\n                            options={Object.keys(db.users)\n                                .filter(a =>\n                                    db.users[a].type === \"client\" ||\n                                    db.users[a].type === \"group\" ||\n                                    db.users[a].type === \"sic\"\n                                )\n                                .sort((a, b) => {\n                                    if (db.users[a].name < db.users[b].name) {\n                                        return -1\n                                    } else if (db.users[a].name > db.users[b].name) {\n                                        return 1\n                                    } else {\n                                        return 0\n                                    }\n                                }).map(a => {\n                                    return { label: db.users[a].name, value: String(db.users[a]._id) }\n                                })\n                            }\n                            getOptionLabel={(option) => {\n                                return translate(option.label, 1)\n                            }\n                            }\n                            style={{ width: \"100%\" }}\n                            name=\"client\"\n                            value={\n                                (\n                                    data\n                                    &&\n                                    data.client\n                                )\n                                    ? Object.keys(db.users)\n                                        .filter(a =>\n                                            data.client\n                                            && db.users[a]._id === data.client\n                                        ).map(a => {\n                                            return {\n                                                label: db.users[a].name,\n                                                value: String(db.users[a]._id)\n                                            }\n                                        })[0]\n                                    : null\n                            }\n                            renderInput={(params) =>\n                                <TextField\n                                    {...params}\n                                    label={translate(\"$__account\", 1)}\n                                    variant={customApp(\"fieldVariant\")}\n                                    value={\n                                        (\n                                            data\n                                            &&\n                                            data.client\n                                        )\n                                            ? Object.keys(db.users)\n                                                .filter(a =>\n                                                    data.client\n                                                    && db.users[a]._id === data.client\n                                                ).map(a => {\n                                                    return {\n                                                        label: db.users[a].name,\n                                                        value: String(db.users[a]._id)\n                                                    }\n                                                })[0]\n                                            : null\n                                    }\n                                />\n                            }\n                            onChange={\n                                (d, v) => {\n                                    changeData({ name: \"client\", value: v && v[\"value\"] ? String(v[\"value\"]) : null })\n                                }\n                            }\n                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"client\") > -1) ? true : false}\n                        />\n                    }\n                    {\n                        (\n                            ((CardAccess > 2 || data.endDate || data.startDate || permission) && !isTemplate && data.type !== \"chatGroup\")\n                            ||\n                            (\n                                !(\n                                    !permission\n                                    &&\n                                    (\n                                        !data.startDate\n                                        && !data.endDate\n                                    )\n                                )\n                                &&\n                                (\n                                    !isTemplate\n                                    &&\n                                    (\n                                        !dataType.hideFields\n                                        || (\n                                            dataType.hideFields\n                                            && dataType.hideFields.indexOf(\"deadline\") === -1\n                                        )\n                                    )\n                                )\n                            )\n                        ) &&\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <legend>{translate(\"$__deadline\", 1)}</legend>\n                            {\n                                data.endDate\n                                    || data.startDate\n                                    || setDate ?\n                                    <React.Fragment>\n                                        <TextField\n                                            label={translate('$__initialDate', 1)}\n                                            variant={customApp('fieldVariant', 1)}\n                                            name=\"startDate\"\n                                            InputLabelProps={{\n                                                shrink: true,\n                                            }}\n                                            type='datetime-local'\n                                            inputProps={{\n                                                min: null,\n                                                autoComplete: 'start-date',\n                                                onChange: (d) => {\n                                                    if (moment(d.target.value).isValid()) {\n                                                        setStartDate(moment(d.target.value).unix('X'))\n                                                    }\n                                                    // if (!endDate || (\n                                                    //     endDate\n                                                    //     &&\n                                                    //     (\n                                                    //         moment(d.target.value).format(\"YYYY-MM-DD\") === moment(endDate * 1000).format(\"YYYY-MM-DD\")\n                                                    //         || moment(d.target.value).unix(\"X\") > moment(endDate * 1000).unix(\"X\")\n                                                    //     )\n                                                    // )\n                                                    // ) setEndDate(moment(moment(d.target.value).format(\"YYYY-MM-DDT23:59:59\")).unix('X'))\n\n                                                    let newData = {\n                                                        startDate: moment(d.target.value).unix('X')\n                                                    }\n                                                    setStartDate(moment(d.target.value).unix('X'))\n                                                    if (!endDate || endDate < moment(d.target.value).unix('X')) {\n                                                        newData = {\n                                                            ...newData,\n                                                            endDate: moment(`${moment(d.target.value).format(\"YYYY-MM-DD\")} 23:59:59`).unix('X')\n                                                        }\n                                                        setEndDate(moment(`${moment(d.target.value).format(\"YYYY-MM-DD\")} 23:59:59`).unix('X'))\n                                                    }\n                                                    setData({\n                                                        ...data,\n                                                        ...newData\n                                                    })\n                                                    setReqSave(true)\n                                                },\n                                            }}\n                                            value={startDate ? moment(startDate * 1000).format(\"YYYY-MM-DDTHH:mm\") : null}\n                                        />\n                                        <TextField\n                                            label={translate('$__endDate', 1)}\n                                            variant={customApp('fieldVariant', 1)}\n                                            name=\"endDate\"\n                                            InputLabelProps={{\n                                                shrink: true,\n                                            }}\n                                            type='datetime-local'\n                                            inputProps={{\n                                                min: !endDate || startDate ? moment(startDate * 1000).format(\"YYYY-MM-DDTHH:mm\") : null,\n                                                autoComplete: 'end-date',\n                                                onChange: (d) => {\n                                                    let newData = {\n                                                        endDate: moment(d.target.value).unix('X')\n                                                    }\n                                                    setEndDate(moment(d.target.value).unix('X'))\n                                                    if (!startDate) {\n                                                        newData = {\n                                                            ...newData,\n                                                            startDate: moment(`${moment(d.target.value).format(\"YYYY-MM-DD\")} 00:00:00`).unix('X')\n                                                        }\n                                                        setStartDate(moment(`${moment(d.target.value).format(\"YYYY-MM-DD\")} 00:00:00`).unix('X'))\n                                                    }\n                                                    setData({\n                                                        ...data,\n                                                        ...newData\n                                                    })\n                                                    setReqSave(true)\n                                                },\n                                            }}\n                                            value={endDate ? moment(endDate * 1000).format(\"YYYY-MM-DDTHH:mm\") : null}\n                                        />\n                                        <div style={{\n                                            display: \"flex\",\n                                            width: \"100%\",\n                                            justifyContent: \"flex-end\"\n                                        }}>\n                                            <CustomButton\n                                                color={customApp('lightgray')}\n                                                icon={'clear'}\n                                                onClick={() => {\n                                                    setStartDate(null)\n                                                    setEndDate(null)\n                                                    setData({\n                                                        ...data,\n                                                        startDate: null,\n                                                        endDate: null,\n                                                        recurrence: null\n                                                    })\n                                                    setSetDate(false)\n                                                    setReqSave(true)\n                                                }}\n                                                size={'15px'}\n                                                {...{\n\n                                                    title: translate(`$__clearDate`, '*'),\n                                                    text: translate(`$__clearDate`, '*')\n                                                }}\n                                            />\n                                        </div>\n                                        {/* <DataPicker\n                                            type=\"datetime\"\n                                            clearButtonPosition={\"flex-end\"}\n                                            onChangeStartDate={(d) => {\n                                                let newData = {\n                                                    startDate: moment(d).unix('X')\n                                                }\n                                                setStartDate(moment(d).unix('X'))\n                                                if (!endDate || endDate < moment(d).unix('X')) {\n                                                    newData = {\n                                                        ...newData,\n                                                        endDate: moment(`${moment(d).format(\"YYYY-MM-DD\")} 23:59:59`).unix('X')\n                                                    }\n                                                    setEndDate(moment(`${moment(d).format(\"YYYY-MM-DD\")} 23:59:59`).unix('X'))\n                                                }\n                                                setData({\n                                                    ...data,\n                                                    ...newData\n                                                })\n                                                setReqSave(true)\n                                            }}\n                                            onChangeEndDate={(d) => {\n                                                let newData = {\n                                                    endDate: moment(d).unix('X')\n                                                }\n                                                setEndDate(moment(d).unix('X'))\n                                                if (!startDate) {\n                                                    newData = {\n                                                        ...newData,\n                                                        startDate: moment(`${moment(d).format(\"YYYY-MM-DD\")} 00:00:00`).unix('X')\n                                                    }\n                                                    setStartDate(moment(`${moment(d).format(\"YYYY-MM-DD\")} 00:00:00`).unix('X'))\n                                                }\n                                                setData({\n                                                    ...data,\n                                                    ...newData\n                                                })\n                                                setReqSave(true)\n                                            }}\n                                            range\n                                            // horizontal\n                                            startDate={startDate ? new Date(startDate * 1000) : null}\n                                            endDate={endDate ? new Date(endDate * 1000) : null}\n                                            onClear={() => {\n                                                setStartDate(null)\n                                                setEndDate(null)\n                                                setData({\n                                                    ...data,\n                                                    startDate: null,\n                                                    endDate: null,\n                                                    recurrence: null\n                                                })\n                                                setSetDate(false)\n                                                setReqSave(true)\n                                            }\n\n                                            }\n                                        /> */}\n                                        <div\n                                            style={{ position: \"relative\", width: \"fit-content\", float: \"right\", display: \"flex\", justifyContent: \"right\" }}\n                                        >\n                                            <GroupedButton\n                                                options={[\n                                                    {\n                                                        value: 0,\n                                                        label: \"Manual\",\n                                                    },\n                                                    {\n                                                        value: 7,\n                                                        label: `7 ${translate(\"$__days\").toLowerCase()}`,\n                                                    },\n                                                    {\n                                                        value: 15,\n                                                        label: `15 ${translate(\"$__days\").toLowerCase()}`,\n                                                    },\n                                                    {\n                                                        value: 30,\n                                                        label: `30 ${translate(\"$__days\").toLowerCase()}`,\n                                                    },\n                                                    {\n                                                        value: 60,\n                                                        label: `60 ${translate(\"$__days\").toLowerCase()}`,\n                                                    },\n                                                    {\n                                                        value: 90,\n                                                        label: `90 ${translate(\"$__days\").toLowerCase()}`,\n                                                    },\n                                                    {\n                                                        value: 180,\n                                                        label: `180 ${translate(\"$__days\").toLowerCase()}`,\n                                                    },\n                                                    {\n                                                        value: 365,\n                                                        label: `365 ${translate(\"$__days\").toLowerCase()}`,\n                                                    },\n                                                    ...parentData && parentData.startDate && parentData.endDate ? [\n                                                        {\n                                                            value: \"parent\",\n                                                            label: `${translate(\"$__useParentDate\")} ${moment(parentData.startDate * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")} - ${moment(parentData.endDate * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\")}`,\n                                                        }\n                                                    ] : [],\n                                                ]}\n                                                value={dateDays ? dateDays : \"\"}\n                                                onChange={(v) => {\n                                                    if (v !== \"parent\" && v !== 0) {\n                                                        setEndDate(moment(new Date(startDate * 1000)).tz(\"America/Sao_Paulo\").add(v, \"days\").unix(\"X\"))\n                                                        changeData({ name: \"endDate\", value: moment(new Date(startDate * 1000)).tz(\"America/Sao_Paulo\").add(v, \"days\").unix(\"X\") }, null, true)\n                                                    } else if (v === \"parent\") {\n                                                        if (parentData.startDate) {\n                                                            setStartDate(parentData.startDate)\n                                                            changeData(\n                                                                { name: \"startDate\", value: parentData.startDate },\n                                                                parentData.endDate ?\n                                                                    { name: \"endDate\", value: parentData.endDate }\n                                                                    : null, true\n                                                            )\n                                                            if (parentData.endDate) {\n                                                                setEndDate(parentData.endDate)\n                                                            }\n                                                        }\n                                                        if (!parentData.startDate && parentData.endDate) {\n                                                            setEndDate(parentData.endDate)\n                                                            changeData(\n                                                                { name: \"endDate\", value: parentData.endDate }\n                                                                , null\n                                                                , true\n                                                            )\n                                                        }\n                                                    }\n                                                    setDateDays(v)\n                                                }}\n                                            />\n                                        </div>\n                                        <div className={classes.switch}\n                                            style={{\n                                                position: \"relative\",\n                                                width: \"100%\",\n                                                float: \"left\",\n                                                display: \"flex\",\n                                                alignItems: \"center\",\n                                                justifyContent: \"space-between\"\n                                            }}>\n                                            {translate(\"$__freeChildrenDate\", 1)}\n                                            <Switch\n                                                checked={data.freeChildrenDate ? true : false}\n                                                onChange={(d) => {\n                                                    changeData({\n                                                        name: \"freeChildrenDate\",\n                                                        value: data.freeChildrenDate ? false : true\n                                                    })\n                                                }}\n                                                name=\"freeChildrenDate\"\n                                                inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                                disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"freeChildrenDate\") > -1) ? true : false}\n                                            />\n                                        </div>\n                                        {data.startDate && moment(data.startDate).isValid() &&\n                                            (!dataType.hideFields || (dataType.hideFields && dataType.hideFields.indexOf(\"recurrence\") === -1)) &&\n                                            <div style={{ width: \"311px\", position: \"relative\", float: \"left\" }}>\n                                                {data._recurrenceId ?\n                                                    <div\n                                                        style={{\n                                                            marginTop: \"15px\",\n\n                                                        }}\n                                                    >\n                                                        {translate(\"$__recurrentActivityFrom\")}:\n                                                        <Card db=\"cards\" data={db.cards[data._recurrenceId]} db=\"cards\" Avatar ignoreList onlyOption />\n                                                    </div>\n                                                    :\n                                                    <div>\n                                                        <RecurrenceSettings\n                                                            data={data}\n                                                            onChange={(res) => {\n                                                                setData({\n                                                                    ...data,\n                                                                    ...res,\n                                                                    recurrenceNextDate: moment(`${res.recurrenceNextDate} 06:00:00`).tz(\"America/Sao_Paulo\").format('YYYY-MM-DD')\n                                                                })\n                                                                setReqSave(true)\n                                                            }}\n                                                        />\n                                                        {data.recurrence && data.recurrence !== \"0\" && data.recurrenceNextDate &&\n                                                            <fieldset\n                                                                style={{ marginTop: \"7px\" }}>\n                                                                <legend>{translate(\"$__NextRecurrenceDate\")}</legend>\n                                                                <DataPicker\n                                                                    // type=\"date\"\n                                                                    placeholder={translate(\"$__NextRecurrenceDate\")}\n                                                                    clearButtonPosition={\"flex-end\"}\n                                                                    onChangeStartDate={(d) => {\n                                                                        let newData = {\n                                                                            recurrenceNextDate: moment(d).tz(\"America/Sao_Paulo\").format('YYYY-MM-DD')\n                                                                        }\n                                                                        setData({\n                                                                            ...data,\n                                                                            ...newData\n                                                                        })\n                                                                        setReqSave(true)\n                                                                    }}\n\n                                                                    startDate={data.recurrenceNextDate && moment(data.recurrenceNextDate).isValid() ? new Date(moment(`${data.recurrenceNextDate} 06:00:00`).tz(\"America/Sao_Paulo\").unix('X') * 1000) : null}\n\n                                                                    onClear={() => {\n                                                                        setData({\n                                                                            ...data,\n                                                                            recurrenceNextDate: null,\n                                                                        })\n                                                                        setReqSave(true)\n                                                                    }\n\n                                                                    }\n                                                                />\n                                                            </fieldset>\n                                                        }\n                                                    </div>\n                                                }\n                                            </div>\n                                        }\n                                    </React.Fragment>\n                                    : (permission || ((CardAccess > 2 || data.endDate || data.startDate || permission) && !isTemplate)) ?\n                                        <CustomIconButton\n                                            text={translate(\"$__addDeadline\", 1)}\n                                            icon=\"timer\"\n                                            onClick={() => {\n                                                setSetDate(true)\n                                                setStartDate(moment(`${moment().format(\"YYYY-MM-DD\")} 00:00:00`).unix(\"X\"))\n                                                changeData(\n                                                    { name: \"startDate\", value: moment(`${moment().format(\"YYYY-MM-DD\")} 00:00:00`).unix(\"X\") },\n                                                    dateDays !== \"parent\" ?\n                                                        { name: \"endDate\", value: moment(`${moment().format(\"YYYY-MM-DD\")} 23:59:59`).add(dateDays, \"days\").unix(\"X\") }\n                                                        : null\n                                                )\n                                                if (dateDays !== \"parent\") {\n                                                    setEndDate(moment(`${moment().format(\"YYYY-MM-DD\")} 23:59:59`).add(dateDays, \"days\").unix(\"X\"))\n                                                }\n                                            }}\n                                        />\n                                        : <></>\n                            }\n                        </fieldset>\n                    }\n                    {((data.status === \"completed\" || !permission) && CardAccess < 3) ?\n                        <React.Fragment>\n                            {data._tags && data._tags.length > 0 ?\n                                <CardTags options={data._tags}\n                                    expanded={true}\n                                />\n                                :\n                                <React.Fragment></React.Fragment>\n                            }\n                        </React.Fragment>\n                        :\n                        <React.Fragment>\n                            {(!dataType.hideFields || (dataType.hideFields && dataType.hideFields.indexOf(\"tags\") === -1)) &&\n                                <fieldset style={{ marginBottom: \"14px\" }}>\n                                    <legend>{translate(\"$__tags\", 1)}</legend>\n                                    <TagsInput\n                                        data={{\n                                            values: data._tags ? data._tags : [],\n                                        }}\n                                        callBack={(v) => {\n                                            if (permission)\n                                                changeData({ name: \"_tags\", value: v })\n                                        }}\n                                        disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"_tags\") > -1) ? true : false}\n                                        placeholder={translate(\"$__selectTheOptions\", 1)}\n                                    />\n                                    <div className={classes.switch}>\n                                        <Switch\n                                            checked={\n                                                data.childrenAutoTag\n                                                    ? true\n                                                    : false\n                                            }\n                                            onChange={(d) => {\n                                                if (permission)\n                                                    changeData({\n                                                        name: \"childrenAutoTag\",\n                                                        value: data.childrenAutoTag ? false : true\n                                                    })\n                                            }}\n                                            name=\"childrenAutoTag\"\n                                            inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"childrenAutoTag\") > -1) ? true : false}\n                                        />\n                                        {translate(\"$__makeLinksAssumeTheSameLabelsOnAdd\", 1)}\n                                    </div>\n                                </fieldset>\n                            }\n                        </React.Fragment>\n                    }\n                    {(!dataType.hideFields\n                        || (dataType.hideFields\n                            && (dataType.hideFields.indexOf(\"priority\") === -1\n                                || dataType.hideFields.indexOf(\"status\") === -1))) &&\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            {!isTemplate && (!dataType.hideFields || (dataType.hideFields && dataType.hideFields.indexOf(\"priority\") === -1)) &&\n                                <div style={{\n                                    position: \"relative\",\n                                    float: \"left\",\n                                    width: \"100%\"\n                                }}>\n                                    <div style={{\n                                        position: \"relative\",\n                                        float: \"left\",\n                                        width: \"calc(50% - 15px)\",\n                                        margin: 3,\n                                        paddingLeft: 7,\n                                    }}>\n                                        <Autocomplete\n                                            id=\"combo-box-demo\"\n                                            options={db.priority}\n                                            getOptionLabel={(option) => translate(option.label, 1)}\n                                            style={{ width: \"100%\" }}\n                                            name=\"priority\"\n                                            disableClearable\n                                            value={\n                                                data\n                                                    && data.priority\n\n                                                    && db.priority\n\n                                                    ? db.priority.filter(a =>\n                                                        String(a.value) === String(data.priority)\n                                                    )[0]\n                                                    : db.priority[0]\n                                            }\n                                            renderInput={(params) =>\n                                                <TextField\n                                                    {...params}\n                                                    label={translate(\"$__priority\", 1)}\n                                                    variant={customApp(\"fieldVariant\")}\n                                                    disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"priority\") > -1) ? true : false}\n                                                    inputProps={{\n                                                        ...params && params.inputProps ? params.inputProps : {},\n                                                        style: {\n                                                            ...params && params.inputProps && params.inputProps.style ? params.inputProps.style : {},\n                                                            paddingLeft: 7,\n                                                            marginTop: 3,\n                                                            marginLeft: -5,\n                                                            width: \"calc(100% - 7px)\",\n                                                            color: data && data.priority ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.priority)\n                                                            )[0].color : db.priority[0].color,\n                                                            borderLeft: `solid 3.33px ${data && data.priority ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.priority)\n                                                            )[0].color : db.priority[0].color}`,\n                                                        }\n                                                    }}\n                                                    value={\n                                                        data\n                                                            && data.priority\n\n                                                            && db.priority\n\n                                                            ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.priority)\n                                                            )[0]\n                                                            : db.priority[0]\n                                                    }\n                                                />\n                                            }\n                                            onChange={\n                                                (d, v) => {\n                                                    if (permission)\n                                                        changeData({ name: \"priority\", value: v[\"value\"] })\n                                                }\n                                            }\n                                            renderOption={(option, { inputValue }) => {\n                                                return (\n                                                    <span style={{ color: option.color }}>\n                                                        {translate(option.label, 1)}\n                                                    </span>\n                                                )\n                                            }}\n                                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"priority\") > -1) ? true : false}\n                                        />\n                                    </div>\n                                    <div style={{\n                                        position: \"relative\",\n                                        float: \"left\",\n                                        width: \"calc(50% - 15px)\",\n                                        margin: 3,\n                                        paddingLeft: 7,\n                                    }}>\n                                        <Autocomplete\n                                            id=\"combo-box-demo\"\n                                            options={db.priority}\n                                            getOptionLabel={(option) => translate(option.label, 1)}\n                                            style={{ width: \"100%\" }}\n                                            name=\"risk\"\n                                            disableClearable\n                                            value={\n                                                data\n                                                    && data.risk\n\n                                                    && db.priority\n\n                                                    ? db.priority.filter(a =>\n                                                        String(a.value) === String(data.risk)\n                                                    )[0]\n                                                    : db.priority[0]\n                                            }\n                                            renderInput={(params) =>\n                                                <TextField\n                                                    {...params}\n                                                    label={translate(\"$__risk\", 1)}\n                                                    variant={customApp(\"fieldVariant\")}\n                                                    disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"priority\") > -1) ? true : false}\n                                                    inputProps={{\n                                                        ...params && params.inputProps ? params.inputProps : {},\n                                                        style: {\n                                                            ...params && params.inputProps && params.inputProps.style ? params.inputProps.style : {},\n                                                            paddingLeft: 7,\n                                                            marginTop: 3,\n                                                            marginLeft: -5,\n                                                            width: \"calc(100% - 7px)\",\n                                                            color: data && data.risk ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.risk)\n                                                            )[0].color : db.priority[0].color,\n                                                            borderLeft: `solid 3.33px ${data && data.risk ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.risk)\n                                                            )[0].color : db.priority[0].color}`,\n                                                        }\n                                                    }}\n                                                    value={\n                                                        data\n                                                            && data.risk\n\n                                                            && db.priority\n\n                                                            ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.risk)\n                                                            )[0]\n                                                            : db.priority[0]\n                                                    }\n\n                                                />\n                                            }\n                                            onChange={\n                                                (d, v) => {\n                                                    if (permission)\n                                                        changeData({ name: \"risk\", value: v[\"value\"] })\n                                                }\n                                            }\n                                            renderOption={(option, { inputValue }) => {\n                                                return (\n                                                    <span style={{ color: option.color }}>\n                                                        {translate(option.label, 1)}\n                                                    </span>\n                                                )\n                                            }}\n                                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"priority\") > -1) ? true : false}\n                                        />\n                                    </div>\n                                    <div style={{\n                                        position: \"relative\",\n                                        float: \"left\",\n                                        width: \"calc(50% - 15px)\",\n                                        margin: 3,\n                                        paddingLeft: 7,\n                                    }}>\n                                        <Autocomplete\n                                            id=\"combo-box-demo\"\n                                            options={db.priority}\n                                            getOptionLabel={(option) => translate(option.label, 1)}\n                                            style={{ width: \"100%\" }}\n                                            name=\"complexity\"\n                                            disableClearable\n                                            value={\n                                                data\n                                                    && data.complexity\n\n                                                    && db.priority\n\n                                                    ? db.priority.filter(a =>\n                                                        String(a.value) === String(data.complexity)\n                                                    )[0]\n                                                    : db.priority[0]\n                                            }\n                                            renderInput={(params) =>\n                                                <TextField\n                                                    {...params}\n                                                    label={translate(\"$__complexity\", 1)}\n                                                    variant={customApp(\"fieldVariant\")}\n                                                    disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"priority\") > -1) ? true : false}\n                                                    inputProps={{\n                                                        ...params && params.inputProps ? params.inputProps : {},\n                                                        style: {\n                                                            ...params && params.inputProps && params.inputProps.style ? params.inputProps.style : {},\n                                                            paddingLeft: 7,\n                                                            marginTop: 3,\n                                                            marginLeft: -5,\n                                                            width: \"calc(100% - 7px)\",\n                                                            color: data && data.complexity ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.complexity)\n                                                            )[0].color : db.priority[0].color,\n                                                            borderLeft: `solid 3.33px ${data && data.complexity ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.complexity)\n                                                            )[0].color : db.priority[0].color}`,\n                                                        }\n                                                    }}\n                                                    value={\n                                                        data\n                                                            && data.complexity\n\n                                                            && db.priority\n\n                                                            ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.complexity)\n                                                            )[0]\n                                                            : db.priority[0]\n                                                    }\n                                                />\n                                            }\n                                            onChange={\n                                                (d, v) => {\n                                                    if (permission)\n                                                        changeData({ name: \"complexity\", value: v[\"value\"] })\n                                                }\n                                            }\n                                            renderOption={(option, { inputValue }) => {\n                                                return (\n                                                    <span style={{ color: option.color }}>\n                                                        {translate(option.label, 1)}\n                                                    </span>\n                                                )\n                                            }}\n                                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"priority\") > -1) ? true : false}\n                                        />\n                                    </div>\n                                    <div style={{\n                                        position: \"relative\",\n                                        float: \"left\",\n                                        width: \"calc(50% - 15px)\",\n                                        margin: 3,\n                                        paddingLeft: 7,\n                                    }}>\n                                        <Autocomplete\n                                            id=\"combo-box-demo\"\n                                            options={db.priority}\n                                            getOptionLabel={(option) => translate(option.label, 1)}\n                                            style={{ width: \"100%\" }}\n                                            name=\"impact\"\n                                            disableClearable\n                                            value={\n                                                data\n                                                    && data.impact\n\n                                                    && db.priority\n\n                                                    ? db.priority.filter(a =>\n                                                        String(a.value) === String(data.impact)\n                                                    )[0]\n                                                    : db.priority[0]\n                                            }\n                                            renderInput={(params) =>\n                                                <TextField\n                                                    {...params}\n                                                    label={translate(\"$__impact\", 1)}\n                                                    variant={customApp(\"fieldVariant\")}\n                                                    disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"priority\") > -1) ? true : false}\n                                                    inputProps={{\n                                                        ...params && params.inputProps ? params.inputProps : {},\n                                                        style: {\n                                                            ...params && params.inputProps && params.inputProps.style ? params.inputProps.style : {},\n                                                            paddingLeft: 7,\n                                                            marginTop: 3,\n                                                            marginLeft: -5,\n                                                            width: \"calc(100% - 7px)\",\n                                                            color: data && data.impact ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.impact)\n                                                            )[0].color : db.priority[0].color,\n                                                            borderLeft: `solid 3.33px ${data && data.impact ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.impact)\n                                                            )[0].color : db.priority[0].color}`,\n                                                        }\n                                                    }}\n                                                    value={\n                                                        data\n                                                            && data.impact\n\n                                                            && db.priority\n\n                                                            ? db.priority.filter(a =>\n                                                                String(a.value) === String(data.impact)\n                                                            )[0]\n                                                            : db.priority[0]\n                                                    }\n                                                />\n                                            }\n                                            onChange={\n                                                (d, v) => {\n                                                    if (permission)\n                                                        changeData({ name: \"impact\", value: v[\"value\"] })\n                                                }\n                                            }\n                                            renderOption={(option, { inputValue }) => {\n                                                return (\n                                                    <span style={{ color: option.color }}>\n                                                        {translate(option.label, 1)}\n                                                    </span>\n                                                )\n                                            }}\n                                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"priority\") > -1) ? true : false}\n                                        />\n                                    </div>\n                                </div>\n                            }\n                            {!isTemplate && (!dataType.hideFields || (dataType.hideFields && dataType.hideFields.indexOf(\"status\") === -1)) &&\n                                <Autocomplete\n                                    id=\"combo-box-demo\"\n                                    options={db.status}\n                                    getOptionLabel={(option) => translate(option.label, 1)}\n                                    style={{ width: \"100%\" }}\n                                    name=\"status\"\n                                    disableClearable\n                                    value={\n                                        data\n                                            && data.status\n                                            && db.status\n                                            ? db.status.filter(a =>\n                                                String(a.value) === String(data.status)\n                                            )[0]\n                                            : db.status[0]\n                                    }\n                                    renderInput={(params) =>\n                                        <TextField\n                                            {...params}\n                                            label={translate(\"$__status\", 1)}\n                                            variant={customApp(\"fieldVariant\")}\n                                            value={\n                                                data\n                                                    && data.status\n                                                    && db.status\n                                                    ? db.status.filter(a =>\n                                                        String(a.value) === String(data.status)\n                                                    )[0]\n                                                    : db.status[0]\n                                            }\n                                        />\n                                    }\n                                    onChange={\n                                        (d, v) => {\n                                            if (permission || String(CardAccess) !== \"0\")\n                                                changeData({ name: \"status\", value: v[\"value\"] })\n                                        }\n                                    }\n                                    disabled={!permission || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"status\") > -1) ? String(CardAccess) === \"0\" ? true : false : false}\n                                />\n                            }\n\n                        </fieldset>\n                    }\n                    {((CardAccess > 4 || (AppAccess && AppAccess.plan && AppAccess.planAdmin)) && data.type === 'plan' && data.status !== \"completed\") &&\n                        <React.Fragment>\n                            {!miroOption && !data.miroBoard ?\n                                <fieldset style={{ marginBottom: \"14px\" }}>\n                                    <legend>{translate(\"$__MiroBoard\", 1)}</legend>\n                                    <CustomIconButton\n                                        text={translate(\"$__addBoard\", 1)}\n                                        icon={\"developer_board\"}\n                                        onClick={() => {\n                                            setMiroOption(true)\n                                        }}\n                                    />\n                                </fieldset>\n                                : miroOption ?\n                                    <fieldset style={{ marginBottom: \"14px\" }}>\n                                        <legend>{translate(\"$__MiroBoard\", 1)}</legend>\n                                        <TextField\n                                            label={translate(\"$__MiroBoardCode\")}\n                                            variant={customApp(\"fieldVariant\")}\n                                            name={\"boardCode\"}\n                                            InputLabelProps={{\n                                                shrink: true,\n                                            }}\n                                            InputProps={{\n                                                autoComplete: \"new-password\",\n                                                endAdornment: (\n                                                    <InputAdornment position=\"end\">\n                                                        <Icon icon={\"save\"} color=\"green\" onClick={() => setMiroOption(false)} />\n                                                    </InputAdornment>\n                                                ),\n                                                onChange: (d, v) => {\n                                                    changeData({ name: \"miroBoard\", value: d.target.value })\n                                                },\n                                            }}\n                                            value={data && data.miroBoard ? data.miroBoard : \"\"}\n                                            placeholder={translate(\"$__MiroBoardCodePlaceholder\", 1)}\n                                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"miroBoard\") > -1) ? true : false}\n                                        />\n                                    </fieldset>\n                                    : data.miroBoard &&\n                                    <fieldset style={{ marginBottom: \"14px\" }}>\n                                        <legend>{translate(\"$__MiroBoard\", 1)}</legend>\n                                        <CustomIconButton\n                                            text={translate(\"$__openMiroBoard\", 1)}\n                                            icon={\"developer_board\"}\n                                            onClick={() => {\n                                                props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n                                                    miro: true,\n                                                    miroBoard: data.miroBoard\n                                                })\n                                            }}\n                                        />\n                                        <CustomIconButton\n                                            text={translate(\"$__editBoard\", 1)}\n                                            icon={\"insert_link\"}\n                                            onClick={() => {\n                                                setMiroOption(true)\n                                            }}\n                                        />\n                                    </fieldset>\n                            }\n                        </React.Fragment>\n                    }\n                    {\n                        (!data._id\n                            ||\n                            (\n                                (\n                                    data\n                                    && data._users\n                                    && session\n                                    && session._id\n                                    && data._users[session._id]\n                                    && data._users[session._id].access\n                                    && parseInt(data._users[session._id].access) >= 3\n                                )\n                                && (\n                                    !dataType.hideFields\n                                    ||\n                                    (\n                                        dataType.hideFields\n                                        && dataType.hideFields.indexOf(\"private\") === -1\n                                    )\n                                )\n                            )\n                        ) &&\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <div className={classes.switch}>\n                                <Switch\n                                    checked={\n                                        data.private\n                                            ? true\n                                            : false\n                                    }\n                                    onChange={(d) => {\n                                        if (permission)\n                                            changeData({\n                                                name: \"private\",\n                                                value: data.private ? false : true\n                                            })\n                                    }}\n                                    name=\"private\"\n                                    inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                    disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"private\") > -1) ? true : false}\n                                />\n                                {translate(\"$__private\", 1)}\n                            </div>\n                        </fieldset>\n                    }\n                    {(!dataType.hideFields || (dataType.hideFields && dataType.hideFields.indexOf(\"private\") === -1)) && data.private &&\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <div className={classes.switch}>\n                                <Switch\n                                    checked={\n                                        data.privateChildrens\n                                            ? true\n                                            : false\n                                    }\n                                    onChange={(d) => {\n                                        if (permission)\n                                            changeData({\n                                                name: \"privateChildrens\",\n                                                value: data.privateChildrens ? false : true\n                                            })\n                                    }}\n                                    name=\"privateChildrens\"\n                                    inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                    disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"private\") > -1) ? true : false}\n                                />\n                                {translate(\"$__privateChildrens\", 1)}\n                            </div>\n                        </fieldset>\n                    }\n                    {permission && data.type === \"chatGroup\" &&\n                        <React.Fragment>\n                            <fieldset style={{ marginBottom: \"14px\" }}>\n                                <div className={classes.switch}>\n                                    <Switch\n                                        checked={\n                                            data.onlyAdminsSendMessages\n                                                ? true\n                                                : false\n                                        }\n                                        onChange={(d) => {\n                                            if (permission)\n                                                changeData({\n                                                    name: \"onlyAdminsSendMessages\",\n                                                    value: data.onlyAdminsSendMessages ? false : true\n                                                })\n                                        }}\n                                        name=\"onlyAdmins\"\n                                        inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                    />\n                                    {translate(\"$__onlyAdminsCanSendMessage\", 1)}\n                                </div>\n                            </fieldset>\n                            {(\n                                data.broadcast\n                                ||\n                                (\n                                    reduxStore.getState().timeline\n                                    &&\n                                    (\n                                        !reduxStore.getState().timeline[data._id]\n                                        ||\n                                        (\n                                            reduxStore.getState().timeline[data._id]\n                                            && Object.keys(reduxStore.getState().timeline[data._id]).length === 0\n                                        )\n                                    )\n                                )\n                            ) ?\n                                <fieldset style={{ marginBottom: \"14px\" }}>\n                                    <div className={classes.switch}>\n                                        <Switch\n                                            checked={\n                                                data.broadcast\n                                                    ? true\n                                                    : false\n                                            }\n                                            onChange={(d) => {\n                                                if (permission)\n                                                    changeData({\n                                                        name: \"broadcast\",\n                                                        value: data.broadcast ? false : true\n                                                    })\n                                            }}\n                                            name=\"broadcast\"\n                                            inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                        // disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"private\") > -1) ? true : false}\n                                        />\n                                        {translate(\"$__workAsABroadcastList\", 1)}\n                                    </div>\n                                </fieldset>\n                                : <React.Fragment></React.Fragment>}\n                        </React.Fragment>\n                    }\n                    {AppAccess\n                        && AppAccess.plan\n                        && AppAccess.planAdmin\n                        && isTemplate\n                        && data.type === \"plan\"\n                        && session._access\n                        && session._access.userAdmin\n                        && session._access.machenAdmin\n                        ?\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <Autocomplete\n                                id=\"combo-box-demo\"\n                                options={db.plans}\n                                getOptionLabel={(option) => translate(option.label, 1)}\n                                style={{ width: \"100%\" }}\n                                name=\"plans\"\n                                disableClearable\n                                value={\n                                    data\n                                        && data.plans\n                                        && db.plans\n                                        ? db.plans.filter(a =>\n                                            String(a.value) === String(data.plans)\n                                        )[0]\n                                        : {\n                                            label: \"$__notAvaiable\",\n                                            value: null,\n                                            settings: {}\n                                        }\n                                }\n                                renderInput={(params) =>\n                                    <TextField\n                                        {...params}\n                                        label={translate(\"$__avaiablefromplan\", 1)}\n                                        variant={customApp(\"fieldVariant\")}\n                                        value={\n                                            data\n                                                && data.plans\n                                                && db.plans\n                                                ? db.plans.filter(a =>\n                                                    String(a.value) === String(data.plans)\n                                                )[0]\n                                                : {\n                                                    label: \"$__notAvaiable\",\n                                                    value: null,\n                                                    settings: {}\n                                                }\n                                        }\n                                    />\n                                }\n                                onChange={\n                                    (d, v) => {\n                                        if (permission)\n                                            changeData({ name: \"plans\", value: v[\"value\"] })\n                                    }\n                                }\n                            />\n                        </fieldset>\n                        : <React.Fragment></React.Fragment>\n                    }\n                </div>\n            </div>\n        </React.Fragment>\n    )\n}\nconst mapStateToProps = (store) => ({\n    sideModule: store.sideModule,\n    card: store.db.cards[store.sideModule.id],\n    cards: store.db.cards,\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst headerStyle = theme => ({\r\n  btClose: {\r\n    position: 'relative',\r\n    zIndex: theme.zIndex.drawer + 1,\r\n    right: '0',\r\n    top: '-64px',\r\n    backgroundColor: '#FFFFFF',\r\n    display: 'flex',\r\n  },\r\n  data: {\r\n    marginTop: '0px',\r\n    padding: '0 10px',\r\n    '& fieldset': {\r\n      border: 'solid 1px rgba(0,0,0,0.1)',\r\n      '& legend': {\r\n        marginBottom: '0px',\r\n        fontSize: '16px',\r\n        color: customApp('color')\r\n      }\r\n    }\r\n  },\r\n  timeline: {\r\n    position: 'absolute',\r\n    width: '100%',\r\n    top: '300px',\r\n    bottom: '0px',\r\n  },\r\n  timelineKpiParent: {\r\n    position: 'absolute',\r\n    width: '100%',\r\n    top: '350px',\r\n    bottom: '0px',\r\n  },\r\n  avatar: {\r\n    width: '22px',\r\n    height: '22px'\r\n  },\r\n  switch: {\r\n    fontSize: '16px',\r\n    fontWeight: 'bold',\r\n    color: customApp('medium')\r\n  }\r\n});\r\n\r\nexport default headerStyle;\r\n","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport { ResponsiveBullet } from '@nivo/bullet'\n\n//COMPONENTS\nimport Autocomplete from \"components/AutoComplete\"\nimport Card from \"components/Card\"\nimport CustomButton from \"components/Buttons/custom\"\nimport KPIChange from \"components/KPI/change\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\nimport Switch from \"components/Switch\"\nimport TextField from \"components/TextField\"\nimport Timeline from \"components/Timeline\"\n\n//@MATERIAL\nimport Icon from \"components/Icon\"\nimport ToggleButton from \"@material-ui/lab/ToggleButton\"\nimport ToggleButtonGroup from \"@material-ui/lab/ToggleButtonGroup\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\nimport {\n    withStyles\n} from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card-KPI.js\"\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n    appAlert,\n    formatNumber,\n    getAppAccess,\n    decimal,\n} from \"functions/\"\n\nimport {\n    saveCard\n} from \"functions/cards\"\n\nimport {\n    getUserAccess\n} from \"functions/cards\"\n\n\nfunction Component(props) {\n\n    const {\n        classes\n    } = props\n\n    const {\n        timeline,\n        db,\n        session,\n        sideModule,\n    } = reduxStore.getState()\n\n    const data = sideModule.data || {}\n\n    const [kpiChangeMod, setKpiChangeMod] = React.useState(data.kpi_type ? false : true)\n    const [view, setView] = React.useState(data.kpi_type ? \"timeline\" : \"settings\")\n    const [reqSave, setReqSave] = React.useState(data._id && data._id === \"new\" && data.name ? true : false)\n    const [fieldError, setFieldError] = React.useState({})\n\n    React.useEffect(() => {\n        if (reqSave && props.reqSave)\n            props.reqSave()\n    }, [reqSave])\n\n\n    let AppAccess = getAppAccess()\n    let CardAccess = getUserAccess(sideModule.id)\n\n    let permission = false\n\n    if (parseInt(CardAccess) >= 4 || (AppAccess.plan && AppAccess.planAdmin))\n        permission = true\n\n    if (session._id\n        && db.cards[data._id]\n        && db.cards[data._id]._users\n        && db.cards[data._id]._users[Object.keys(db.cards[data._id]._users).find(a => a.indexOf(session._id) > -1)])\n        CardAccess = db.cards[data._id]._users[Object.keys(db.cards[data._id]._users).find(a => a.indexOf(session._id) > -1)]\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    let kpi_flow = timeline[data._id] || {}\n    kpi_flow = Object.keys(kpi_flow).filter(a => kpi_flow[a].type === \"kpi\").map(a => kpi_flow[a])\n\n    let parentData = null\n    let notAllocated = 0\n    let Allocated = 0\n    if (data._parent\n        && reduxStore.getState().db.cards[data._parent]\n        && reduxStore.getState().db.cards[data._parent].kpi_type\n        && reduxStore.getState().db.cards[data._parent].kpi_type !== 'task'\n    ) {\n        parentData = reduxStore.getState().db.cards[data._parent]\n        if (parseInt(parentData.kpi_ini) > parseInt(parentData.kpi_fin)) {\n            notAllocated = parseInt(parentData.kpi_ini) - parseInt(parentData.kpi_fin)\n        } else {\n            notAllocated = parseInt(parentData.kpi_fin) - parseInt(parentData.kpi_ini)\n        }\n        Object.keys(reduxStore.getState().db.cards)\n            .filter(pp =>\n                reduxStore.getState().db.cards[pp]._parent\n                && reduxStore.getState().db.cards[pp]._parent === parentData._id\n                && reduxStore.getState().db.cards[pp].kpi_type === parentData.kpi_type\n                && reduxStore.getState().db.cards[pp].kpi_useParent\n            )\n            .map(pp => {\n                if (parseInt(parentData.kpi_ini) > parseInt(parentData.kpi_fin && parseInt(reduxStore.getState().db.cards[pp].kpi_ini))) {\n                    notAllocated = notAllocated - parseInt(reduxStore.getState().db.cards[pp].kpi_ini)\n                } else if (parseInt(reduxStore.getState().db.cards[pp].kpi_fin)) {\n                    notAllocated = notAllocated - parseInt(reduxStore.getState().db.cards[pp].kpi_fin)\n                }\n            })\n    }\n\n\n\n    const changeData = (d) => {\n        if ((d.value && !sideModule.data[d.name]) || (sideModule.data[d.name] && sideModule.data[d.name] !== d.value))\n            setReqSave(true)\n\n        let newData = {\n            ...sideModule.data,\n            [d.name]: d.value,\n        }\n        if (!newData.kpi_ini)\n            newData = {\n                ...newData,\n                kpi_ini: 0,\n            }\n        if (!newData.kpi_fin)\n            newData = {\n                ...newData,\n                kpi_fin: 0,\n            }\n        if (!newData.kpi_useParent && (!String(newData.kpi_useParent) !== 'false') && (parentData && parentData.kpi_type === d.value))\n            newData = {\n                ...newData,\n                kpi_useParent: true,\n            }\n\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...sideModule,\n            data: newData\n        })\n    }\n\n    const save = async (close = false) => {\n        setReqSave(false)\n        if (\n            sideModule.data.kpi_type === \"time\"\n            && (\n                (\n                    parseInt(sideModule.data.kpi_fin) === 0\n                    && parseInt(sideModule.data.kpi_ini) === 0\n                )\n                || (\n                    parseInt(sideModule.data.kpi_fin) > 0\n                    && parseInt(sideModule.data.kpi_fin) < parseInt(sideModule.data.kpi_ini)\n                )\n\n            )\n        ) {\n            appAlert({\n                message: translate(\"$__invalidMaximumMinutes\", 1),\n                variant: \"warning\",\n                persist: false,\n                horizontal: \"right\",\n                confirm: null\n            })\n        } else {\n            const rSave = await saveCard(props, true, sideModule.data)\n            if (rSave) {\n                appAlert({\n                    message: translate(\"$__kpiDataSaved\", 1),\n                    variant: null,\n                    persist: false,\n                    horizontal: \"right\",\n                    confirm: null\n                })\n            }\n            if (close)\n                props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n        }\n    }\n\n    const setParentKpi = async (d) => {\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...sideModule,\n            data: {\n                ...sideModule.data,\n                kpi_ini: null,\n                kpi_fin: null,\n                kpi_useParent: d.value ? true : null\n            }\n        })\n    }\n\n    let totalAllocated = 0\n\n    Object.keys(db.cards).filter(ch => db.cards[ch] && db.cards[ch]._parent && db.cards[ch]._parent === data._id && db.cards[ch].kpi_useParent).map((ch, chi) => {\n        if (parseInt(data.kpi_ini) > parseInt(data.kpi_fin)) {\n            totalAllocated = totalAllocated + parseInt(db.cards[ch].kpi_ini) - parseInt(db.cards[ch].kpi_fin)\n        } else {\n            totalAllocated = totalAllocated + parseInt(db.cards[ch].kpi_fin) - parseInt(db.cards[ch].kpi_ini)\n        }\n    })\n\n    return (\n        <div>\n            <SideModuleCloseAndSave\n                save={reqSave && permission ? () => {\n                    save()\n                } : null}\n                saveClose={reqSave && permission ? () => {\n                    save(true)\n                } : null}\n                close={() => {\n                    if (props.onClose)\n                        props.onClose(reqSave)\n                }}\n            />\n            <div style={{\n                posision: \"absolute\",\n                top: 5,\n                left: 0,\n                right: 0\n            }}>\n                {permission ?\n                    <div style={{\n                        width: '100%',\n                        position: 'relative',\n                        display: 'flex',\n                        flexDirection: 'row-reverse'\n                    }}>\n                        <CustomButton\n                            title={translate(`$__changeKpiType`, 1)}\n                            color={customApp(view === 'settings' ? \"menu\" : \"color\")}\n                            icon={'tune'}\n                            onClick={() => setView('settings')}\n                            size={'25px'}\n                            transparent\n                        />\n\n                        <CustomButton\n                            title={translate(`$__chart`, 1)}\n                            color={customApp(view === 'chart' ? \"menu\" : \"color\")}\n                            icon={'analytics'}\n                            onClick={() => setView('chart')}\n                            size={'25px'}\n                            transparent\n                        />\n                        <CustomButton\n                            title={translate(`$__statement`, 1)}\n                            color={customApp(view === 'timeline' ? \"menu\" : \"color\")}\n                            icon={'receipt'}\n                            onClick={() => setView('timeline')}\n                            size={'25px'}\n                            transparent\n                        />\n                    </div>\n                    : <div>\n\n                    </div>\n                }\n                {view === 'chart' ?\n                    <KPIChange data={data} chartShow={true} />\n                    : view === 'settings' ?\n                        <fieldset style={{ textAlign: \"center\" }}>\n                            <legend>{translate(\"$__measurementeType\", 1)}</legend>\n                            {Object.keys(db.cards).filter(c => db.cards[c]._parent === data._id && db.cards[c].kpi_useParent).length === 0 ?\n                                <ToggleButtonGroup\n                                    value={data && data.kpi_type ? data.kpi_type : \"task\"}\n                                    exclusive\n                                    onChange={(e, a) => {\n                                        changeData({\n                                            name: \"kpi_type\",\n                                            value: a\n                                        })\n                                    }}\n                                >\n                                    <ToggleButton value=\"decimal\">\n                                        <Icon title={translate(\"$__decimal\", 1)} color=\"color\">filter_9_plus</Icon>\n                                    </ToggleButton>\n                                    <ToggleButton value=\"currency\">\n                                        <Icon title={translate(\"$__currency\", 1)} color=\"color\">attach_money</Icon>\n                                    </ToggleButton>\n                                    <ToggleButton value=\"percent\">\n                                        <Tooltip title={translate(\"$__percentage\", 1)}>\n                                            <span style={{ color: `${customApp(\"color\")}`, fontSize: \"22px\" }}>%</span>\n                                        </Tooltip>\n                                    </ToggleButton>\n                                    <ToggleButton value=\"time\">\n                                        <Icon title={translate(\"$__time\", 1)} color=\"color\">hourglass_top</Icon>\n                                    </ToggleButton>\n                                    <ToggleButton value=\"task\">\n                                        <Icon title={translate(\"$__task\", 1)} color=\"color\">task</Icon>\n                                    </ToggleButton>\n                                </ToggleButtonGroup>\n                                : data.kpi_type === 'decimal' ?\n                                    <Icon title={translate(\"$__decimal\", 1)} color=\"color\">filter_9_plus</Icon>\n                                    : data.kpi_type === 'currency' ?\n                                        <Icon title={translate(\"$__currency\", 1)} color=\"color\">attach_money</Icon>\n                                        : data.kpi_type === 'percent' ?\n                                            <Icon title={translate(\"$__percentage\", 1)} color=\"color\">percent</Icon>\n                                            :\n                                            <Icon title={translate(\"$__task\", 1)} color=\"color\">task</Icon>\n                            }\n                            {Object.keys(db.cards).filter(c => db.cards[c]._parent === data._id && db.cards[c].kpi_useParent).length === 0 ?\n                                <React.Fragment>\n\n                                </React.Fragment>\n                                :\n                                <React.Fragment>\n\n                                </React.Fragment>\n                            }\n                            {parentData && parentData.kpi_type && parentData.kpi_type === data.kpi_type ?\n                                <React.Fragment>\n                                    <fieldset style={{ marginTop: 7 }}>\n                                        <legend style={{ color: \"gray\", fontSize: 12 }}>{translate(\"$__parentKpi\", 1)}</legend>\n                                        {data.kpi_useParent ?\n                                            <React.Fragment>\n                                                {/* <fieldset style={{ marginTop: 3 }}>\n                                                    <legend style={{ color: \"gray\", fontSize: 12 }}>{translate(\"$__initialValue\", 1)}</legend>\n                                                    {formatNumber(parentData && parentData.kpi_ini ? parentData.kpi_ini : 0, parentData.kpi_type === \"time\" ? \"number\" : parentData.kpi_type, parentData.kpi_currency ? parentData.kpi_currency : null)}\n                                                </fieldset>\n                                                <fieldset style={{ marginTop: 3 }}>\n                                                    <legend style={{ color: \"gray\", fontSize: 12 }}>{translate(\"$__finalValue\", 1)}</legend>\n                                                    {formatNumber(parentData && parentData.kpi_fin ? parentData.kpi_fin : 0, parentData.kpi_type === \"time\" ? \"number\" : parentData.kpi_type, parentData.kpi_currency ? parentData.kpi_currency : null)}\n                                                </fieldset> */}\n                                                <fieldset style={{ marginTop: 3 }}>\n                                                    <legend style={{ color: \"blue\", fontSize: 12 }}>{parentData && parseInt(parentData.kpi_ini) > parseInt(parentData.kpi_fin) ? translate(\"$__notAllocatedBudget\", 1) : translate(\"$__notAllocatedGoal\", 1)}</legend>\n                                                    {formatNumber(notAllocated, parentData.kpi_type === \"time\" ? \"number\" : parentData.kpi_type, parentData.kpi_currency ? parentData.kpi_currency : null)}\n                                                </fieldset>\n                                            </React.Fragment>\n                                            : <React.Fragment></React.Fragment>}\n                                        <div className={classes.switch}>\n                                            <Switch\n                                                checked={data.kpi_useParent ? true : false}\n                                                onChange={(d) => {\n                                                    setParentKpi({\n                                                        name: \"kpi_useParent\",\n                                                        value: data.kpi_useParent ? false : true\n                                                    })\n                                                }}\n                                                name=\"kpi_useParent\"\n                                                inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                            />\n                                            {translate(\"$__useParentKpi\", 1)}\n                                        </div>\n                                        {!data.kpi_useParent ?\n                                            <div style={{ color: 'red' }}>\n                                                {translate(\"$__independentKPIDescription\")}\n                                            </div>\n                                            : <React.Fragment></React.Fragment>\n                                        }\n                                        <div>\n                                        </div>\n                                    </fieldset>\n                                </React.Fragment>\n                                : <React.Fragment></React.Fragment>\n                            }\n                            {data && data.kpi_type\n                                && (data.kpi_type !== \"task\") &&\n                                <React.Fragment>\n                                    {data.kpi_type === \"currency\" && !data.kpi_useParent && Object.keys(db.cards).filter(c => db.cards[c]._parent === data._id && db.cards[c].kpi_useParent).length === 0 ?\n                                        <Autocomplete\n                                            id=\"combo-box-demo\"\n                                            options={db.currency}\n                                            getOptionLabel={(option) => translate(option.label, 1)}\n                                            style={{ width: \"100%\" }}\n                                            name=\"currency\"\n                                            disableClearable\n                                            value={\n                                                data\n                                                    && data.kpi_currency\n                                                    && db.currency\n                                                    ? db.currency.filter(a =>\n                                                        String(a.value) === String(data.kpi_currency)\n                                                    )[0]\n                                                    : db.currency[0]\n                                            }\n                                            renderInput={(params) =>\n                                                <TextField\n                                                    {...params}\n                                                    label={translate(\"$__currency\", 1)}\n                                                    variant={customApp(\"fieldVariant\")}\n                                                    value={\n                                                        data\n                                                            && data.kpi_currency\n                                                            && db.currency\n                                                            ? db.currency.filter(a =>\n                                                                String(a.value) === String(data.kpi_currency)\n                                                            )[0]\n                                                            : db.currency[0]\n                                                    }\n                                                />\n                                            }\n                                            onChange={\n                                                (d, v) => {\n                                                    changeData({ name: \"kpi_currency\", value: v[\"value\"] })\n                                                }\n                                            }\n                                        />\n                                        : Object.keys(db.cards).filter(ch => db.cards[ch]._parent === data._id && db.cards[ch].kpi_useParent).length > 0 ?\n                                            <fieldset style={{ marginTop: 7 }}>\n                                                <legend style={{ color: \"gray\", fontSize: 12 }}>{translate(\"$__allocatedKpiActivities\", 1)}</legend>\n                                                <ul style={{ listStyle: \"none\", padding: 0 }}>\n                                                    {Object.keys(db.cards).filter(ch => db.cards[ch]._parent === data._id && db.cards[ch].kpi_useParent).map((ch, chi) => {\n                                                        let cardAllocated = 0\n                                                        if (parseInt(data.kpi_ini) > parseInt(data.kpi_fin)) {\n                                                            cardAllocated = parseInt(db.cards[ch].kpi_ini) - parseInt(db.cards[ch].kpi_fin)\n                                                        } else {\n                                                            cardAllocated = parseInt(db.cards[ch].kpi_fin) - parseInt(db.cards[ch].kpi_ini)\n                                                        }\n                                                        let kpiAccomplished = 0\n                                                        if (timeline && timeline[ch] && Object.keys(timeline[ch]).filter(k => timeline[ch][k] && timeline[ch][k].value).length > 0)\n                                                            Object.keys(timeline[ch]).filter(k => timeline[ch][k] && timeline[ch][k].value).map(k => {\n                                                                kpiAccomplished = kpiAccomplished + parseFloat(timeline[ch][k].value)\n                                                            })\n                                                        return (\n                                                            <li key={`ca-${ch}`}>\n                                                                <Card db=\"cards\" data={reduxStore.getState().db.cards[ch]} notGlobalExpanded ignoreList />\n                                                                <div style={{\n                                                                    width: \"100%\",\n                                                                    height: 22,\n                                                                }}>\n                                                                    <ResponsiveBullet\n                                                                        data={\n                                                                            [\n                                                                                {\n                                                                                    // \"id\": \"temp.\",\n                                                                                    \"ranges\": [\n                                                                                        0,\n                                                                                        parseInt(data.kpi_ini) > parseInt(data.kpi_fin) ? parseInt(data.kpi_ini) - parseInt(data.kpi_fin) : parseInt(data.kpi_fin) - parseInt(data.kpi_ini)\n                                                                                    ],\n                                                                                    \"measures\": [\n                                                                                        cardAllocated\n                                                                                    ],\n                                                                                    \"markers\": [\n                                                                                        kpiAccomplished\n                                                                                    ]\n                                                                                }\n                                                                            ]\n                                                                        }\n                                                                        minValue={parseInt(data.kpi_ini) > parseInt(data.kpi_fin) ? parseInt(data.kpi_fin) : parseInt(data.kpi_ini)}\n                                                                        maxValue={parseInt(data.kpi_ini) < parseInt(data.kpi_fin) ? parseInt(data.kpi_fin) : parseInt(data.kpi_ini)}\n                                                                        margin={{ top: 0, right: 0, bottom: 0, left: 0 }}\n                                                                        spacing={50}\n                                                                        titlePosition=\"after\"\n                                                                        titleAlign=\"end\"\n                                                                        titleOffsetX={-70}\n                                                                        rangeBorderColor={{ from: 'color', modifiers: [] }}\n                                                                        measureBorderColor={{ from: 'color', modifiers: [] }}\n                                                                        measureSize={100000}\n                                                                        markerSize={1.2}\n                                                                        rangeColors=\"purple_orange\"\n                                                                        measureColors=\"seq:blue_purple\"\n                                                                        markerColors=\"seq:yellow_orange_red\"\n                                                                        motionConfig=\"stiff\"\n                                                                    />\n                                                                </div>\n                                                                <div style={{ marginTop: 0, fontSize: 12, color: 'black', width: \"100%\", textAlign: \"left\" }}>\n                                                                    {formatNumber(cardAllocated, data.kpi_type === \"time\" ? \"number\" : data.kpi_type, data.kpi_currency ? data.kpi_currency : null)}\n                                                                </div>\n                                                            </li>)\n                                                    })\n                                                    }\n                                                </ul>\n                                            </fieldset>\n                                            :\n                                            <React.Fragment></React.Fragment>\n                                    }\n                                    <div style={{ display: \"flex\", marginTop: \"14px\", justifyContent: !data.kpi_useParent ? \"space-between\" : \"center\" }}>\n                                        {\n                                            (\n                                                !data.kpi_useParent\n                                                ||\n                                                (\n                                                    data.kpi_useParent\n                                                    && parentData\n                                                    && parseInt(parentData.kpi_ini) > parseInt(parentData.kpi_fin)\n                                                )\n                                            ) ?\n                                                <div style={{ width: \"calc(50% - 7px)\" }}>\n                                                    <TextField\n                                                        label={data.kpi_useParent ? translate(\"$__budget\") : data.kpi_type === \"time\" ? translate(\"$__minimumMinutes\", 1) : translate(\"$__initialValue\", 1)}\n                                                        variant={\"outlined\"}\n                                                        name=\"kpi_ini\"\n                                                        error={fieldError && fieldError.kpi_ini ? true : false}\n                                                        helperText={fieldError && fieldError.kpi_ini ? translate(\"$__valueExceedAllocatedValue\", 1) : null}\n                                                        InputLabelProps={{\n                                                            shrink: true,\n                                                            step: 0.01,\n                                                        }}\n                                                        InputProps={{\n                                                            autoComplete: \"new-password\",\n                                                            startAdornment: <span style={{ color: \"lightgray\", fontSize: 8 }}>{data.kpi_type === 'currency' && db.currency.filter(a =>\n                                                                (data.kpi_currency && String(a.value) === String(data.kpi_currency))\n                                                                || (!data.kpi_currency & String(a.value) === 'BRL')\n                                                            )[0] ? db.currency.filter(a =>\n                                                                (data.kpi_currency && String(a.value) === String(data.kpi_currency))\n                                                                || (!data.kpi_currency & String(a.value) === 'BRL')\n                                                            )[0].symbol : \"\"}</span>,\n                                                        }}\n                                                        onChange={(e) => {\n                                                            changeData({\n                                                                name: `kpi_ini`,\n                                                                value: data.kip_type === 'time' ? decimal(e.target.value, 0) : decimal(e.target.value, 2)\n                                                            })\n                                                        }}\n                                                        value={data.kpi_ini}\n                                                    />\n                                                </div>\n                                                : <React.Fragment></React.Fragment>\n                                        }\n                                        {\n                                            (\n                                                !data.kpi_useParent\n                                                ||\n                                                (\n                                                    data.kpi_useParent\n                                                    && parentData\n                                                    && parseInt(parentData.kpi_ini) < parseInt(parentData.kpi_fin)\n                                                )\n                                            ) ?\n                                                <div style={{ width: \"calc(50% - 7px)\" }}>\n                                                    <TextField\n                                                        label={data.kpi_useParent ? translate(\"$__goal\") : data.kpi_type === \"time\" ? translate(\"$__maximumMinutes\", 1) : translate(\"$__finalValue\", 1)}\n                                                        variant={\"outlined\"}\n                                                        name=\"kpi_fin\"\n                                                        type=\"number\"\n                                                        error={fieldError && fieldError.kpi_fin ? true : false}\n                                                        helperText={fieldError && fieldError.kpi_fin ? translate(\"$__valueExceedAllocatedValue\", 1) : null}\n                                                        InputLabelProps={{\n                                                            shrink: true,\n                                                        }}\n                                                        InputProps={{\n                                                            autoComplete: \"new-password\",\n                                                            startAdornment: <span style={{ color: \"lightgray\", fontSize: 8 }}>{data.kpi_type === 'currency' && db.currency.filter(a =>\n                                                                (data.kpi_currency && String(a.value) === String(data.kpi_currency))\n                                                                || (!data.kpi_currency & String(a.value) === 'BRL')\n                                                            )[0] ? db.currency.filter(a =>\n                                                                (data.kpi_currency && String(a.value) === String(data.kpi_currency))\n                                                                || (!data.kpi_currency & String(a.value) === 'BRL')\n                                                            )[0].symbol : \"\"}</span>,\n                                                        }}\n                                                        onChange={(e) => {\n                                                            changeData({\n                                                                name: `kpi_fin`,\n                                                                value: data.kip_type === 'time' ? decimal(e.target.value, 0) : decimal(e.target.value, 2)\n                                                            })\n                                                        }}\n                                                        value={data.kpi_fin}\n                                                    />\n                                                </div>\n                                                : <React.Fragment></React.Fragment>\n                                        }\n                                    </div>\n                                    <div className={classes.switch}>\n                                        <Switch\n                                            checked={data.kpi_reqMessage ? true : false}\n                                            onChange={(d) => {\n                                                changeData({\n                                                    name: \"kpi_reqMessage\",\n                                                    value: data.kpi_reqMessage ? false : true\n                                                })\n                                            }}\n                                            name=\"kpi_reqMessage\"\n                                            inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                        />\n                                        {translate(\"$__reqDescription\", 1)}\n                                    </div>\n\n                                    {/* {data.kpi_type === \"time\" &&\n                                    <div className={classes.switch}>\n                                        <Switch\n                                            checked={data.kpi_canExceed ? true : false}\n                                            onChange={(d) => {\n                                                changeData({\n                                                    name: \"kpi_canExceed\",\n                                                    value: data.kpi_canExceed ? false : true\n                                                })\n                                            }}\n                                            name=\"kpi_canExceed\"\n                                            inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                        />\n                                        {translate(\"$__canExceedLimit\", 1)}\n                                    </div>\n                                        }\n                                } */}\n                                </React.Fragment>\n                            }\n                        </fieldset>\n                        :\n                        <div\n                            style={{\n                                position: \"absolute\",\n                                top: 30,\n                                bottom: 0,\n                                left: 0,\n                                right: 0,\n                            }}\n                        >\n                            <KPIChange\n                                data={data}\n                                chartShow={false}\n                            />\n                            <div\n                                style={{\n                                    position: \"absolute\",\n                                    top: 103,\n                                    bottom: 0,\n                                    left: 0,\n                                    right: 0,\n                                }}\n                            >\n                                <Timeline\n                                    noSearch={true}\n                                    nodeId={data._id}\n                                    type={\"kpi\"}\n                                    db={'cards'}\n                                    disabledSend\n                                    loadTimeline\n                                    kpi_type={data.kpi_type}\n                                />\n                            </div>\n                        </div>\n                }\n            </div>\n        </div >\n    )\n}\nconst mapStateToProps = (store) => ({\n    store: {\n        sideModule: store.sideModule,\n    }\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst style = theme => ({\r\n  root: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: 'calc(100% - 20px)',\r\n    margin: '10px',\r\n  },\r\n  progress: {\r\n    marginLeft: '7px',\r\n    width: 'calc(100% - 14px)'\r\n  },\r\n  image: {\r\n    width: '100%',\r\n    paddingTop: '48%',\r\n    backgroundPosition: 'center',\r\n    backgroundSize: 'cover',\r\n  },\r\n})\r\n\r\nexport default style;\r\n","//CORE\nimport React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport KPIChange from \"components/KPI/change\";\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card-Resume.js\";\n\nfunction Component(props) {\n    const { classes } = props;\n    const { sideModule } = reduxStore.getState()\n    const data = sideModule.data || {}\n\n    return (\n        <div className={classes.root}>\n            {sideModule.data.image &&\n                <div className={classes.image}\n                    style={{\n                        backgroundImage: `url(${sideModule.data.image})`\n                    }}\n                />\n            }\n            {data.kpi_type &&\n                <KPIChange data={data} chartShow />\n            }\n        </div>\n    )\n}\nconst mapStateToProps = store => ({\n    store\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","//CORE\nimport React from 'react'\nimport moment from 'moment-timezone'\n\n//REDUX\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\nimport { bindActionCreators } from 'redux'\nimport { connect } from 'react-redux'\n\n//COMPONENTS\nimport TextField from \"components/TextField\"\nimport Buttom from \"components/CustomButtons/Custom\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\n\n//@MATERIAL\nimport Autocomplete from \"components/AutoComplete\"\nimport Icon from \"components/Icon\"\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card.js\"\n\n//FUNCTIONS\nimport { saveCard, unlinkChildrens } from \"functions/cards\"\nimport { translate, customApp, appAlert } from \"functions/\"\n\nimport MatrixIcon from \"assets/icons/Matrix.js\"\n\nfunction Component(props) {\n    const { classes } = props\n    const { db, sideModule, session } = reduxStore.getState()\n    const { planType } = db\n    const data = sideModule.data || {}\n    const [reqSave, setReqSave] = React.useState(false)\n    const [mounted, setMounted] = React.useState(false)\n\n\n    React.useEffect(() => {\n        if (!mounted) {\n            if (data.type === 'link' && data._id === 'new')\n                setReqSave(true)\n            setMounted(true)\n        }\n    })\n\n    const changeData = (d, d2) => {\n        if ((d.value && !sideModule.data[d.name]) || (sideModule.data[d.name] && sideModule.data[d.name] !== d.value))\n            setReqSave(true)\n        let newData = {\n            ...sideModule.data,\n            [d.name]: d.value,\n        }\n        if (d2 && d2.name && d2.value) {\n            newData = {\n                ...newData,\n                [d2.name]: d2.value\n            }\n        }\n\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...sideModule,\n            data: {\n                ...sideModule.data,\n                ...newData\n            }\n        })\n    }\n\n    const close = (cl) => {\n        if (reqSave && !cl) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n        }\n    }\n    const save = async (cl = false) => {\n        setReqSave(false)\n        if (!sideModule.data.name) {\n            appAlert({\n                message: translate('$__fillName', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n        } else {\n            const request = await saveCard(props, true, sideModule.data)\n            if (request) {\n                appAlert({\n                    message: translate('$__userDataSaved', 1),\n                    variant: null,\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n            }\n            if (cl)\n                close(true)\n        }\n    }\n\n    const unlinkCards = async () => {\n        appAlert({\n            message: translate('$__unlinkCardsConfirm', 1),\n            variant: 'warning',\n            persist: false,\n            horizontal: 'right',\n            confirm: async () => {\n                await unlinkChildrens(props, { cardId: data._id, _planId: data._planId })\n            }\n        })\n    }\n\n    const dataType = db.dataType.filter(a => a.name === sideModule.data.type)[0]\n\n    return (\n        <React.Fragment>\n            <SideModuleCloseAndSave\n                save={reqSave ? () => {\n                    // setSaveLoader(true)\n                    save()\n                } : null}\n                saveClose={reqSave ? () => {\n                    // setSaveLoader(true)\n                    save(true)\n                } : null}\n                // saveLoader={saveLoader}\n                close={() => {\n                    close(true)\n                }}\n            />\n            <div className={classes.root}>\n                {data.type !== 'plan' ?\n                    <React.Fragment>\n                        {Object.keys(db.cards).filter(card => db.cards[card]._parent === data._id && !db.cards[card].checklist).length > 0 ?\n                            <fieldset style={{ textAlign: \"center\" }}>\n                                <legend style={{ color: customApp(\"color\") }}>{translate(\"$__unLinkCards\", 1)}</legend>\n                                <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                                    {translate(\"$__unLinkCardsDescription\", 1)}\n                                </div>\n                                <Buttom onClick={() => { unlinkCards() }} >{translate(\"$__unLinkCards\", 1)}</Buttom>\n                            </fieldset>\n                            :\n                            <fieldset style={{ marginBottom: '14px' }}>\n                                {(!dataType.hideFields || (dataType.hideFields && dataType.hideFields.indexOf('type') === -1)) &&\n                                    <Autocomplete\n                                        id=\"combo-box-demo\"\n                                        options={db.type}\n                                        getOptionLabel={(option) => translate(option.label, 1)}\n                                        style={{ width: '100%' }}\n                                        name=\"type\"\n                                        disableClearable\n                                        value={data && data.type && db && db.type ? db.type.filter(a => String(a.value) === String(data.type))[0] : db.type[0]}\n                                        renderInput={(params) =>\n                                            <TextField\n                                                {...params}\n                                                label={translate('$__type', 1)}\n                                                variant={customApp('fieldVariant')}\n                                                value={data && data.type && db && db.type ? db.type.filter(a => String(a.value) === String(data.type))[0] : db.type[0]}\n                                            />\n                                        }\n                                        onChange={\n                                            (d, v) => {\n                                                changeData({ name: 'type', value: v['value'] })\n                                            }\n                                        }\n                                    />\n                                }\n                            </fieldset>\n                        }\n                    </React.Fragment>\n                    : <React.Fragment></React.Fragment>\n                }\n                {data.type === 'plan' ?\n                    <fieldset style={{ marginBottom: '14px', marginTop: 30 }}>\n                        <Autocomplete\n                            id=\"combo-box-demo\"\n                            options={planType}\n                            getOptionLabel={(option) => translate(option.label, 1)}\n                            style={{ width: '100%' }}\n                            name=\"type\"\n                            disableClearable\n                            value={data && data.planType ? planType.filter(a => a.value === data.planType)[0] : planType[0]}\n                            renderInput={(params) =>\n                                <TextField\n                                    {...params}\n                                    label={translate('$__planType', 1)}\n                                    variant={customApp('fieldVariant')}\n                                    value={data && data.planType ? planType.filter(a => a.value === data.planType)[0] : planType[0]}\n                                />\n                            }\n                            onChange={\n                                (d, v) => {\n                                    changeData({ name: 'planType', value: v['value'] })\n                                }\n                            }\n                        />\n                        {\n                            planType.filter(a =>\n                                !data.planType\n                                || (data.planType\n                                    && a.value === data.planType\n                                    && a.swot === true\n                                )\n                            ).length > 0 ?\n                                <div style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                }}>\n                                    <div style={{\n                                        width: \"fit-content\",\n                                        display: \"flex\",\n                                        alignItems: \"center\",\n                                        justifyContent: \"center\",\n                                        fontWeight: \"bold\",\n                                        color: customApp(\"color\")\n                                    }}>\n                                        <Icon icon={MatrixIcon} color={customApp('color')} size={25} /><span style={{ marginLeft: 15 }}>MATRIX SWOT</span>\n                                    </div>\n\n                                </div>\n                                :\n                                <React.Fragment></React.Fragment>\n                        }\n                        <div>{translate(planType.filter(a =>\n                            !data.planType\n                            || (data.planType\n                                && a.value === data.planType\n                            )\n                        )[0].description, 1)}</div>\n                    </fieldset>\n                    :\n                    <React.Fragment></React.Fragment>\n                }\n            </div>\n        </React.Fragment>\n    )\n}\nconst mapStateToProps = () => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\r\nimport React from \"react\"\r\nimport styled from \"styled-components\"\r\nimport { DragDropContext, Droppable, Draggable } from \"react-beautiful-dnd\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n//COMPONENTS\r\nimport Card from \"components/Card/\"\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport IconButton from \"components/CustomButtons/IconButton\"\r\nimport TextField from \"components/TextField\"\r\nimport LinearProgress from \"components/Progress/linear\"\r\n\r\n//FUNCTIONS\r\nimport { translate, customApp } from \"functions/\"\r\nimport {\r\n    loadCards\r\n} from \"functions/loadData\"\r\n\r\nfunction Component(props) {\r\n    const { db, session } = reduxStore.getState()\r\n    const { socket } = reduxStore.getState().functions\r\n    const [name, setName] = React.useState(props.name ? props.name : '')\r\n    const [add, setAdd] = React.useState(false)\r\n    const [loadingData, setLoadingData] = React.useState(false)\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace('#', '')\r\n    if (hashs[0].length !== 36) {\r\n        hashs[0] = null\r\n    }\r\n\r\n    React.useEffect(() => {\r\n        reqFullData()\r\n        return () => {\r\n            // return false\r\n        }\r\n    }, [])\r\n\r\n    const reqFullData = async () => {\r\n        const loadParents = await loadCards({ ...props, ignoreLoader: true }, [props.nodeId], false, null, \"childrens\")\r\n        if (loadParents)\r\n            setLoadingData(false)\r\n    }\r\n\r\n\r\n    let parent = {}\r\n    if (reduxStore.getState().db[props.db] && reduxStore.getState().db[props.db][props.nodeId])\r\n        parent = reduxStore.getState().db[props.db][props.nodeId]\r\n\r\n    let tasksCards = Object.keys(reduxStore.getState().db.cards)\r\n        .filter(fil => {\r\n            if (\r\n                !reduxStore.getState().db.cards[fil].deleted\r\n                && !reduxStore.getState().db.cards[fil].checklist\r\n                && !reduxStore.getState().db.cards[fil]._recurrenceId\r\n                && reduxStore.getState().db.cards[fil]._parent === props.nodeId &&\r\n                (\r\n                    !reduxStore.getState().db.cards[fil].private\r\n                    || (\r\n                        reduxStore.getState().db.cards[fil].private\r\n                        && reduxStore.getState().db.cards[fil]._users[session._id]\r\n                    )\r\n                )\r\n            )\r\n                return true\r\n        }\r\n        )\r\n        .map(card => card)\r\n\r\n    const addCard = async () => {\r\n        const { socket } = reduxStore.getState().functions\r\n        let type = 'task'\r\n        if (parent && parent.type) {\r\n            if (parent.type.indexOf('guideline') > -1)\r\n                type = 'objective'\r\n            if (parent.type === 'objective')\r\n                type = 'goal'\r\n            if (parent.type === 'goal')\r\n                type = 'task'\r\n        }\r\n        if (parent.childrenAutoTag && parent._tags && parent._tags.length > 0)\r\n            console.log(parent)\r\n\r\n\r\n        socket.emit(\"data\", {\r\n            module: \"cards\",\r\n            method: \"post\",\r\n            action: \"add\"\r\n        }, {\r\n            _parent: parent._id,\r\n            planId: parent._planId ? parent._planId : null,\r\n            name,\r\n            type,\r\n            status: 'notStarted',\r\n            ...(parent.childrenAutoTag && parent._tags && parent._tags.length > 0) ? {\r\n                _tags: parent._tags\r\n            } : {}\r\n        }, async (response) => {\r\n            socket.emit('card.UPD', {\r\n                cardId: response.id,\r\n                cardData: {\r\n                    ...response.data,\r\n                    // _loaded: true,\r\n                    _planId: parent._planId ? parent._planId : null,\r\n                    _parent: parent._id,\r\n                    _timeline: {\r\n                        [response.log._id]: {\r\n                            ...response.log,\r\n                            _parent: [response.id],\r\n                        }\r\n                    },\r\n                    _users: {\r\n                        [session._id]: {\r\n                            name: reduxStore.getState().db.users[session._id].name ? reduxStore.getState().db.users[session._id].name : null,\r\n                            displayName: reduxStore.getState().db.users[session._id].displayName ? reduxStore.getState().db.users[session._id].displayName : null,\r\n                            image: reduxStore.getState().db.users[session._id].image ? reduxStore.getState().db.users[session._id].image : null,\r\n                            access: 5,\r\n                            _id: session._id\r\n                        }\r\n                    }\r\n                },\r\n            })\r\n            setName('')\r\n        })\r\n    }\r\n\r\n    const onDragEnd = async result => {\r\n        let cardsOn = Object.keys(reduxStore.getState().db.cards)\r\n            .filter(fil => {\r\n                if (reduxStore.getState().db.cards[fil] && reduxStore.getState().db.cards[fil].checklist && reduxStore.getState().db.cards[fil]._parent === props.nodeId)\r\n                    return true\r\n            }\r\n            )\r\n            .sort((a, b) => {\r\n                if (db.cards[a].order && db.cards[b].order && String(db.cards[a].order.low) && String(db.cards[b].order.low) && parseInt(db.cards[a].order.low) < parseInt(db.cards[b].order.low)) {\r\n                    return -1\r\n                } else if (db.cards[a].order && db.cards[b].order && String(db.cards[a].order.low) && String(db.cards[b].order.low) && parseInt(db.cards[a].order.low) > parseInt(db.cards[b].order.low)) {\r\n                    return 1\r\n                } else {\r\n                    return 0\r\n                }\r\n            })\r\n            .map(card => card)\r\n\r\n        const { destination, source, draggableId } = result\r\n\r\n        if (!destination) return false\r\n\r\n        if (destination.droppableId === source.droppableId && destination.id === source.index) return false\r\n\r\n        const itemOrderIds = cardsOn\r\n        itemOrderIds.splice(source.index, 1)\r\n        itemOrderIds.splice(destination.index, 0, draggableId)\r\n\r\n        // socket.emit(\"data\", {\r\n        //     module: \"cards\",\r\n        //     method: \"put\",\r\n        //     action: \"reorder\"\r\n        // }, {\r\n        //     cards: itemOrderIds\r\n        // })\r\n        // let cards = {}\r\n\r\n        // itemOrderIds.map((a, i) => {\r\n        //     cards = {\r\n        //         ...cards,\r\n        //         [a]: db.cards[a]\r\n        //     }\r\n        //     cards = {\r\n        //         ...cards,\r\n        //         [a]: {\r\n        //             ...cards[a],\r\n        //             order: {\r\n        //                 low: i\r\n        //             }\r\n        //         }\r\n        //     }\r\n        //     return true\r\n        // })\r\n        // props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n        //     ...reduxStore.getState().db,\r\n        //     cards: {\r\n        //         ...reduxStore.getState().db.cards,\r\n        //         ...cards\r\n        //     }\r\n        // })\r\n        return\r\n\r\n    }\r\n    const onDragStart = async result => {\r\n    }\r\n    const onDragUpdate = async result => {\r\n    }\r\n\r\n    if (loadingData)\r\n        return <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"center\", width: \"100%\" }}>\r\n            <span style={{ color: customApp('menu'), fontSize: \"12px\", paddingRight: \"15px\", whiteSpace: \"nowrap\" }}>{translate('$__loadingCatenation')}</span>\r\n            <LinearProgress />\r\n        </div>\r\n\r\n    let openCards = tasksCards\r\n        .filter(a => db.cards[a].status !== 'completed')\r\n        .sort((a, b) => {\r\n            if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase()) {\r\n                return -1\r\n            } else if (db.cards[a].name.toLowerCase() > db.cards[b].name.toLowerCase()) {\r\n                return 1\r\n            } else {\r\n                return 0\r\n            }\r\n        }\r\n        )\r\n\r\n    let completedCards = tasksCards\r\n        .filter(a => db.cards[a].status === 'completed')\r\n        .sort((a, b) => {\r\n            if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase()) {\r\n                return -1\r\n            } else if (db.cards[a].name.toLowerCase() > db.cards[b].name.toLowerCase()) {\r\n                return 1\r\n            } else {\r\n                return 0\r\n            }\r\n        }\r\n        )\r\n\r\n    return (\r\n        <div style={{ width: '100%' }}>\r\n            <DragDropContext\r\n                onDragEnd={onDragEnd}\r\n                onDragStart={onDragStart}\r\n                onDragUpdate={onDragUpdate}\r\n            >\r\n                <Droppable\r\n                    droppableId={`Drop_tasks`} //ID OF BOARD\r\n                    type=\"column\"\r\n                    direction={\"vertical\"}\r\n                >\r\n                    {(provided, snapshot) => (\r\n                        <Container\r\n                            ref={provided.innerRef}\r\n                            {...provided.droppableProps}\r\n                            isDraggingOver={snapshot.isDraggingOver}\r\n                        >\r\n                            {openCards.length > 0 ?\r\n                                openCards.map((card, index) => (\r\n                                    <Draggable\r\n                                        draggableId={card}\r\n                                        index={index}\r\n                                        key={card}\r\n                                    >\r\n                                        {(provided, snapshot) => (\r\n                                            <div\r\n                                                {...provided.draggableProps}\r\n                                                {...provided.dragHandleProps}\r\n                                                ref={provided.innerRef}\r\n                                            >\r\n                                                <Card\r\n                                                    provided={provided}\r\n                                                    snapshot={snapshot}\r\n                                                    data={db.cards[card]}\r\n                                                    db={'cards'}\r\n                                                    onlyOption\r\n                                                    showCompleteOption\r\n                                                    directDeletion\r\n                                                    editable\r\n                                                />\r\n                                            </div>\r\n                                        )}\r\n                                    </Draggable>\r\n                                )) : <React.Fragment></React.Fragment>}\r\n                            {completedCards.length > 0 ?\r\n                                completedCards.map((card, index) => (\r\n                                    <div key={card} >\r\n                                        <Card\r\n                                            provided={provided}\r\n                                            snapshot={snapshot}\r\n                                            data={db.cards[card]}\r\n                                            db={'cards'}\r\n                                            onlyOption\r\n                                            showCompleteOption\r\n                                            directDeletion\r\n                                            editable\r\n                                        />\r\n                                    </div>\r\n                                )) : <React.Fragment></React.Fragment>}\r\n                            {provided.placeholder}\r\n                        </Container>\r\n                    )}\r\n                </Droppable>\r\n            </DragDropContext>\r\n            {\r\n                !add &&\r\n                <div style={{ position: 'relative', float: 'right', width: '100%', padding: '7px', display: 'flex', alignContent: 'flex-end', justifyContent: 'center' }}>\r\n                    <div>\r\n                        <IconButton\r\n                            reverse\r\n                            text={translate(\"$__add\", '*')}\r\n                            icon=\"add_box\"\r\n                            iconColor={customApp('medium')}\r\n                            onClick={() => {\r\n                                setAdd(!add)\r\n                            }}\r\n                        />\r\n                    </div>\r\n                </div>\r\n            }\r\n            {\r\n                add &&\r\n                <React.Fragment>\r\n                    <div\r\n                        style={{ position: 'relative', float: 'left', width: '100%', padding: '7px', display: 'flex', alignItems: 'center' }}>\r\n                        <div style={{ width: 'calc(100% - 50px)', display: 'flex' }}>\r\n                            <TextField\r\n                                label={translate('$__taskTitle')}\r\n                                variant={customApp('fieldVariant')}\r\n                                name={'name'}\r\n                                InputLabelProps={{\r\n                                    shrink: true,\r\n                                }}\r\n                                InputProps={{\r\n                                    autoComplete: 'new-password',\r\n                                    onChange: (d) => {\r\n                                        setName(d.target.value)\r\n                                    },\r\n                                    onBlur: (d) => {\r\n                                        if (d.target.value === '')\r\n                                            setAdd(!add)\r\n                                    },\r\n                                    onKeyDown: (e) => {\r\n                                        if (e.keyCode === 13 && name)\r\n                                            addCard()\r\n                                        if (e.keyCode === 27) {\r\n                                            setAdd(!add)\r\n                                            setName('')\r\n                                        }\r\n                                    }\r\n                                }}\r\n                                autoFocus\r\n                                value={name}\r\n                                placeholder={translate('$__taskTitlePlaceholder')}\r\n                            />\r\n                        </div>\r\n                        <div style={{ display: 'flex' }}>\r\n                            <CustomButton\r\n                                title={translate(`$__save`, 1)}\r\n                                color='green'\r\n                                icon={'save'}\r\n                                onClick={(e) => {\r\n                                    addCard()\r\n                                }}\r\n                                transparent\r\n                            />\r\n                            <CustomButton\r\n                                title={translate(`$__cancel`, 1)}\r\n                                color='lightgrey'\r\n                                icon={'cancel'}\r\n                                onClick={(e) => {\r\n                                    setAdd(!add)\r\n                                    setName('')\r\n                                }}\r\n                                transparent\r\n                            />\r\n                        </div>\r\n                    </div>\r\n                </React.Fragment>\r\n            }\r\n        </div >\r\n    )\r\n}\r\n\r\nconst Container = styled.div`\r\n            background-color:none\r\n            `\r\n\r\nconst ContainerDeleted = styled.div\r\n    `background-color:red\r\n            padding:7px`\r\n\r\nconst mapStateToProps = (store, props) => {\r\n    return ({\r\n        cards: Object.keys(store.db.cards).filter(fil => store.db.cards[fil]._parent === props.nodeId)\r\n    })\r\n}\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","//CORE\nimport React from \"react\"\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport Autocomplete from \"components/AutoComplete\"\nimport Card from \"components/Card\"\nimport ConnectedIn from \"components/ConnectedIn\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Icon from \"components/Icon\"\nimport QuickUsers from \"components/User/quick\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\nimport Switch from \"components/Switch\"\nimport TagsInput from \"components/Tags/input\"\nimport TextField from \"components/TextField\"\nimport Navigation from \"components/Navigation\"\nimport MultInput from \"components/MultInput/input\";\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card.js\"\n\n//FUNCTIONS\nimport api from \"api/\"\n\nimport {\n    cardStatus,\n    getUserAccess,\n    planMyAccountVerify,\n    saveCard,\n    setMyDay,\n    updateCardStatus,\n    verifyTemplate,\n} from \"functions/cards\"\n\nimport {\n    loadCardsV2\n} from \"functions/loadData\"\n\nimport {\n    appAlert,\n    customApp,\n    favoriteNode,\n    getAppAccess,\n    getDate,\n    translate,\n} from \"functions/\"\n\n//ICONS\nimport MatrixIcon from \"assets/icons/Matrix.js\"\n\nconst planType = [{\n    label: \"$__strategic\",\n    value: null,\n    swot: true,\n    description: \"$__strategicPlanDescription\"\n},\n{\n    label: \"$__tacticAndOrOperational\",\n    value: \"operational\",\n    swot: false,\n    description: \"$__operationalPlanDescription\"\n}]\n\nfunction Component(props) {\n    const { classes, sideModule } = props\n    const { db, session } = reduxStore.getState()\n\n    const [data, setData] = React.useState({})\n    const [newData, setNewData] = React.useState({})\n    const [reqSave, setReqSave] = React.useState(false)\n    const [saveLoader, setSaveLoader] = React.useState(false)\n    const [mounted, setMounted] = React.useState(false)\n    const [startDate, setStartDate] = React.useState(null)\n    const [endDate, setEndDate] = React.useState(null)\n    const [loadingData, setLoadingData] = React.useState(false)\n    const [onConcludedStepMoveTo, setOnConcludedStepMoveTo] = React.useState(sideModule.data?.onConcludedStepMoveTo || null)\n\n    let AppAccess = getAppAccess()\n    let CardAccess = getUserAccess(sideModule.id)\n\n    React.useEffect(() => {\n        if (data._id !== sideModule.data._id) {\n            setData(sideModule.data)\n            setReqSave(false)\n        }\n        if (!mounted) {\n            if (sideModule.data.startDate)\n                setStartDate(sideModule.data && sideModule.data.startDate ? sideModule.data.startDate : null)\n\n            if (sideModule.data.endDate)\n                setEndDate(sideModule.data && sideModule.data.endDate ? sideModule.data.endDate : null)\n            setData(sideModule.data)\n            setReqSave(false)\n\n            if (data.type === \"link\" && !data.name)\n                loadUrlContent()\n            setMounted(true)\n            reqFullData()\n        }\n        if (sideModule.data.name && sideModule.data.name.trim() !== \"\" && sideModule.data.type === \"link\" && sideModule.data._id === \"new\") {\n            setReqSave(true)\n            if (props.reqSave)\n                props.reqSave(true)\n        }\n        // return () => {\n        //     setMounted(false)\n        // }\n    }, [sideModule.data, data])\n\n    React.useEffect(() => {\n        if (!data.name || (data.name && data.name.trim === \"\")) {\n            setReqSave(false)\n        } else {\n            setReqSave(true)\n        }\n    }, [newData])\n\n    const reqParents = async (parent) => {\n        if (!db.cards[parent]) {\n            await loadCardsV2({ ...props, ignoreLoader: true }, {\n                idRel: [parent],\n                cardLoad: \"parents\"\n            })\n        } else if (db.cards[parent] && db.cards[parent]._parent) {\n            setLoadingData(true)\n            let response = reqParents(db.cards[parent]._parent)\n            if (response)\n                setLoadingData(false)\n        } else {\n            setLoadingData(false)\n        }\n    }\n\n    const reqFullData = async () => {\n        const loadParents = await loadCardsV2({ ...props, ignoreLoader: true }, {\n            idRel: [sideModule.data._id],\n            cardLoad: \"parents\"\n        })\n        if (loadParents)\n            setLoadingData(false)\n    }\n\n    const changeData = (d, d2, clear = false) => {\n        if (\n            (\n                d.value\n                &&\n                (\n                    !sideModule.data[d.name]\n                    &&\n                    !data[d.name]\n                )\n            )\n            ||\n            (\n                sideModule.data[d.name]\n                && sideModule.data[d.name] !== d.value\n            )\n            ||\n            clear\n        ) {\n            // setReqSave(true)\n            if (props.reqSave)\n                props.reqSave(true)\n        }\n\n\n        let newDataCD = {\n            ...data,\n            [d.name]: d.value,\n        }\n        if (d2 && d2.name && d2.value) {\n            newDataCD = {\n                ...data,\n                ...newDataCD,\n                [d2.name]: d2.value\n            }\n        }\n        setData(newDataCD)\n        setNewData({\n            ...newData,\n            [d.name]: d.value,\n            ...d2 && d2.name && d2.value ? {\n                [d2.name]: d2.value\n            } : {}\n        })\n    }\n\n    const close = (cl) => {\n        if (reqSave && !cl) {\n            appAlert({\n                message: translate(\"$__confirmCloseWithUnsavedData\", 1),\n                variant: \"warning\",\n                persist: false,\n                horizontal: \"right\",\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n        }\n    }\n    const save = async (cl = false) => {\n        if (!saveLoader) {\n            setReqSave(false)\n            if (props.reqSave)\n                props.reqSave(false)\n            if (!data.status)\n                data.status = \"notStarted\"\n            if (sideModule.id === \"new\" && sideModule.data) {\n                setData({\n                    ...data,\n                    ...sideModule.data\n                })\n            }\n            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                ...sideModule,\n                data: data\n            })\n\n            if (!data.name || (data.name && data.name.trim() === \"\")) {\n                setSaveLoader(false)\n                appAlert({\n                    message: translate(\"$__fillName\", 1),\n                    variant: \"warning\",\n                    persist: false,\n                    horizontal: \"right\",\n                    confirm: null\n                })\n            } else {\n                const request = await saveCard({\n                    ...props,\n                    store: {\n                        ...props.store,\n                        db: {\n                            ...reduxStore.getState().db\n                        }\n                    }\n                }, cl, data)\n                if (request) {\n                    if (newData && newData.status) {\n                        updateCardStatus(\n                            {\n                                ...props,\n                                data: { _id: data._id }\n                            }, { status: newData.status })\n                        cardStatus(props, data._id, newData.status)\n                    }\n                    setSaveLoader(false)\n                    appAlert({\n                        message: translate(\"$__DataSaved\", 1),\n                        variant: null,\n                        persist: false,\n                        horizontal: \"right\",\n                        confirm: null\n                    })\n                }\n                setReqSave(false)\n                if (props.reqSave)\n                    props.reqSave(false)\n                if (cl)\n                    close(true)\n            }\n        }\n    }\n\n    const loadUrlContent = async () => {\n        const result = await api.post(`/link/content`, {\n            url: data.url\n        })\n        setData({\n            ...data,\n            content: result.data.article,\n        })\n        setReqSave(true)\n        if (props.reqSave)\n            props.reqSave(true)\n    }\n\n    const dataType = sideModule.data && sideModule.data.type ? db.dataType.filter(a => a.name === sideModule.data.type)[0] : {}\n\n    let parentData = null\n    if (data._parent)\n        parentData = reduxStore.getState().db.cards[data._parent]\n\n    if (!data)\n        return null\n\n    let myDay = reduxStore.getState().db.cards[data._id] && reduxStore.getState().db.cards[data._id]._users && reduxStore.getState().db.cards[data._id]._users[session._id] && reduxStore.getState().db.cards[data._id]._users[session._id].myDay ? reduxStore.getState().db.cards[data._id]._users[session._id].myDay : null\n    let myDayOption = !myDay || (myDay && myDay && moment(new Date(myDay * 1000)).format(\"YYYY/MM/DD\") !== moment().format(\"YYYY/MM/DD\")) ? true : false\n\n    // const isTemplate = false\n    const isTemplate = data.isTemplate ? data.isTemplate : verifyTemplate(data._id)\n\n    let permission = props.permission ? props.permission : false\n\n    if (data && data._planId && (!db.cards[data._planId] || !planMyAccountVerify(data._planId)))\n        permission = false\n\n    if (!permission && parseInt(CardAccess) >= 4)\n        permission = true\n\n    if (!permission && planMyAccountVerify(data._planId) && AppAccess && AppAccess.admin && AppAccess.plan && (AppAccess.planAdmin || AppAccess.planModerate))\n        permission = true\n\n\n    let hasYoutube = false\n    let youtube = (<React.Fragment></React.Fragment>)\n    if (data && data.url && data.url.indexOf(\".youtube.com/watch?\") > -1) {\n        let ybQuery = data.url.split(\"?\")[1].split(\"v=\")[1].split(\"&\")[0]\n        if (ybQuery) {\n            youtube = (\n                <iframe\n                    width=\"560\"\n                    height=\"315\"\n                    style={{\n                        top: 0,\n                        width: \"100%\",\n                        maxWidth: \"500px\",\n                        height: \"100%\",\n                        alignSelf: \"center\",\n                        position: \"absolute\",\n                        overflow: \"hidden\"\n                    }}\n                    src={`https://www.youtube.com/embed/${ybQuery}`}\n                    title=\"YouTube video player\"\n                    frameBorder=\"0\"\n                    allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                    allowFullScreen >\n\n                </iframe >\n            )\n            hasYoutube = true\n        }\n    }\n\n    if (data && data.url && data.url.indexOf(\"//youtu.be/\") > -1) {\n        let ybQuery = data.url.split(\".be/\")[1]\n        if (ybQuery) {\n            youtube = (\n                <iframe\n                    width=\"560\"\n                    height=\"315\"\n                    style={{\n                        top: 0,\n                        width: \"100%\",\n                        maxWidth: \"500px\",\n                        height: \"100%\",\n                        alignSelf: \"center\",\n                        position: \"absolute\",\n                        overflow: \"hidden\"\n                    }}\n                    src={`https://www.youtube.com/embed/${ybQuery}`}\n                    title=\"YouTube video player\"\n                    frameBorder=\"0\"\n                    allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                    allowFullScreen >\n\n                </iframe >\n            )\n            hasYoutube = true\n        }\n    }\n\n\n\n    return (\n        <React.Fragment>\n            <SideModuleCloseAndSave\n                save={reqSave ? () => {\n                    setSaveLoader(true)\n                    save()\n                } : null}\n                saveClose={reqSave ? () => {\n                    setSaveLoader(true)\n                    save(true)\n                } : null}\n                saveLoader={saveLoader}\n                close={() => {\n                    if (props.onClose)\n                        props.onClose()\n                }}\n            />\n            <div className={classes.root}>\n                <div className={classes.data}>\n                    <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"space-between\" }}>\n\n                        <div\n                            style={{\n                                display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\"\n                            }}\n                        >\n                            {\n                                data.type === \"step\" && data._id && permission ?\n                                    <CustomButton\n                                        title={translate(\"$__openBoard\", 1)}\n                                        icon={\"launch\"}\n                                        color={\"lightgray\"}\n                                        onClick={() => {\n                                            console.log(\"openBoard\", data._id)\n                                        }\n                                        }\n                                        size={\"25px\"}\n                                    />\n                                    : <React.Fragment></React.Fragment>\n                            }\n                        </div>\n                    </div>\n                    <fieldset style={{ marginBottom: \"14px\" }}>\n                        <legend>{data.type === 'plan' && data._id ? translate(`$__plan ${data.planType ? planType[1].label : planType[0].label}`, 1) : translate(\"$__data\", 1)}</legend>\n                        {data.created_at ?\n                            <div\n                                style={{\n                                    position: \"relative\",\n                                    fontSize: 12,\n                                    color: \"#bfbfbf\",\n                                    padding: \"3px 0px\",\n                                    marginTop: -8,\n                                    textAlign: \"right\",\n                                }}>\n                                {translate(\"$__createdAt\")}: {getDate(data.created_at)}\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                        <TextField\n                            label={translate(dataType && dataType.fieldsTitle && dataType.fieldsTitle.name ? dataType.fieldsTitle.name : \"$__titleOfCard\", 1)}\n                            variant={customApp(\"fieldVariant\")}\n                            name={\"name\"}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: \"new-password\",\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon=\"view_headline\" />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.name ? data.name : \"\"}\n                            placeholder={translate(dataType && dataType.fieldsTitle && dataType.fieldsTitle.placeholder && dataType.fieldsTitle.placeholder.name ? dataType.fieldsTitle.placeholder.name : \"$__titleOfCard_placeholder\", 1)}\n                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"name\") > -1) ? true : false}\n                        />\n                        {(CardAccess > 3 || data.description || permission)\n                            ?\n                            <React.Fragment>\n                                <TextField\n                                    label={translate(\"$__description\", 1)}\n                                    variant={customApp(\"fieldVariant\")}\n                                    name=\"description\"\n\n                                    InputProps={{\n                                        autoComplete: \"new-password\",\n                                        multiline: true,\n                                        minRows: 3,\n                                        endAdornment: (\n                                            <InputAdornment position=\"end\">\n                                                <Icon icon=\"toc\" />\n                                            </InputAdornment>\n                                        ),\n                                        onChange: (d) => {\n                                            changeData(d.target)\n                                        },\n                                    }}\n                                    value={data && data.description ? data.description : \"\"}\n                                    placeholder={translate(\"$__descriptionOfCard_placeholder\", 1)}\n                                    disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"description\") > -1) ? true : false}\n                                />\n                            </React.Fragment>\n                            :\n                            <React.Fragment></React.Fragment>\n                        }\n                    </fieldset>\n\n\n                    <fieldset style={{ marginBottom: \"14px\" }}>\n                        <legend>{translate(`$__automation`, 1)}</legend>\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <legend>{translate(`$__users`, 1)}</legend>\n                            <div\n                                style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    color: \"gray\",\n                                    fontSize: 10\n                                }}\n                            >{translate('$__automationUsersExplain', 1)}</div>\n                            <AutomationAction\n                                value={\n                                    data.automationUsers\n                                    || null\n                                }\n                                onChange={(e) => {\n                                    changeData({\n                                        name: \"automationUsers\",\n                                        value: e\n                                    })\n                                }}\n                                {...data.step === \"0\" ? { ignoreValues: ['remove'] } : {}}\n                            />\n                            {data._id && db.cards[data._id] && db.cards[data._id]._users &&\n                                <QuickUsers\n                                    _id={data._id}\n                                    noLimit\n                                    avatarSize=\"33px\"\n                                    permission={permission}\n                                />\n                            }\n                        </fieldset>\n                        <fieldset\n                            style={{\n                                marginBottom: \"14px\"\n                            }}\n                        >\n                            <legend>{translate(`$__dueDate`, 1)}</legend>\n                            <fieldset style={{ marginBottom: \"14px\" }}>\n                                <legend>{translate(\"$__due\", 1)}</legend>\n                                <AutomationAction\n                                    value={data.automationDueDateType || null}\n                                    onChange={(e) => {\n                                        changeData({ name: \"automationDueDateType\", value: e })\n                                    }}\n                                    ignoreValues={['replace']}\n                                />\n                                {(\n                                    data.automationDueDateType && data.automationDueDateType === 'add'\n                                ) ?\n                                    <TextField\n                                        label={translate(\"$__automationDueDate\", 1)}\n                                        variant={customApp(\"fieldVariant\")}\n                                        name=\"automationDueDate\"\n                                        min={1}\n                                        InputProps={{\n                                            type: \"number\",\n                                            min: 1,\n                                            autoComplete: \"new-password\",\n                                            endAdornment: (\n                                                <InputAdornment position=\"end\">\n                                                    {translate(\"$__days\", '*')}\n                                                </InputAdornment>\n                                            ),\n                                            onChange: (d) => {\n                                                let value = d.target.value || 1\n                                                if (parseInt(value) < 1) value = 1\n                                                changeData({ name: \"automationDueDate\", value: value })\n                                            },\n                                        }}\n                                        value={data && data.automationDueDate ? data.automationDueDate : 1}\n                                    />\n                                    : <React.Fragment></React.Fragment>\n                                }\n                            </fieldset>\n                        </fieldset>\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <legend>{translate(`$__tags`, 1)}</legend>\n                            <fieldset style={{ marginBottom: \"14px\" }}>\n                                <legend>{translate(\"$__tags\", 1)}</legend>\n                                <AutomationAction\n                                    value={data.automationTags || null}\n                                    onChange={(e) => {\n                                        changeData({ name: \"automationTags\", value: e })\n                                    }}\n                                />\n                                {data.automationTags && data.automationTags !== \"doNotChange\" ?\n                                    <TagsInput\n                                        data={{\n                                            values: data._tags ? data._tags : [],\n                                        }}\n                                        callBack={(v) => {\n                                            if (permission)\n                                                changeData({ name: \"_tags\", value: v })\n                                        }}\n                                        disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"_tags\") > -1) ? true : false}\n                                        placeholder={translate(\"$__selectTheOptions\", 1)}\n                                    />\n                                    : <React.Fragment></React.Fragment>\n                                }\n                            </fieldset>\n                        </fieldset>\n                        {Object.keys(reduxStore.getState().db.cards).filter(card => reduxStore.getState().db.cards[card]._parent === data._parent && reduxStore.getState().db.cards[card].type === 'step' && !reduxStore.getState().db.cards[card].deleted).length === parseInt(data.step) + 1 ?\n                            <fieldset style={{ marginBottom: \"14px\" }}>\n                                <div\n                                    style={{\n                                        position: \"relative\",\n                                        width: \"100%\",\n                                        color: \"gray\",\n                                        fontSize: 10\n                                    }}\n                                >{translate('$__onConcludedStepMoveTo', 1)}</div>\n                                <div className={classes.switch}>\n                                    {onConcludedStepMoveTo && onConcludedStepMoveTo === data.onConcludedStepMoveTo ?\n                                        <CustomButton\n                                            title={translate(`$__selectTarget`, 1)}\n                                            text={translate(`$__selectTarget`, 1)}\n                                            color={customApp(\"menu\")}\n                                            icon={\"assistant_navigation\"}\n                                            onClick={() => {\n                                                setOnConcludedStepMoveTo(null)\n                                            }}\n                                            size={\"14px\"}\n                                            textSize={\"14px\"}\n                                        />\n                                        :\n                                        <div>\n                                            <Navigation\n                                                onSelect={(e) => {\n                                                    console.log(e)\n                                                    if (!reduxStore.getState().db.cards[e._id])\n                                                        loadCardsV2({ ...props, ignoreLoader: true }, { cardLoad: 'parents', idRel: e._id })\n                                                    setOnConcludedStepMoveTo(e._id)\n                                                }}\n                                                ignoreTypes={['chatGroup']}\n                                                types={['plan', 'guideline', 'guidelineC', 'guidelineD', 'guidelineE', 'guidelineR', 'objective', 'goal', 'step']}\n                                            />\n                                            {onConcludedStepMoveTo && onConcludedStepMoveTo !== data.onConcludedStepMoveTo ?\n                                                <div\n                                                    style={{\n                                                        width: \"100%\",\n                                                        display: \"flex\",\n                                                        justifyContent: \"center\",\n                                                        alignItems: \"center\"\n                                                    }}\n                                                >\n                                                    <CustomButton\n                                                        title={translate(`$__cancel`, 1)}\n                                                        text={translate(`$__cancel`, 1)}\n                                                        color={\"lightgray\"}\n                                                        icon={\"cancel\"}\n                                                        onClick={() => {\n                                                            changeData({ name: \"onConcludedStepMoveTo\", value: data?.onConcludedStepMoveTo || null })\n                                                        }}\n                                                    />\n                                                    <CustomButton\n                                                        title={translate(`$__save`, 1)}\n                                                        text={translate(`$__save`, 1)}\n                                                        color={customApp(\"menu\")}\n                                                        icon={\"check\"}\n                                                        onClick={() => {\n                                                            changeData({ name: \"onConcludedStepMoveTo\", value: onConcludedStepMoveTo })\n                                                        }}\n                                                    />\n                                                </div>\n                                                : <React.Fragment></React.Fragment>\n                                            }\n                                        </div>\n\n                                    }\n                                    {data.onConcludedStepMoveTo && onConcludedStepMoveTo === data.onConcludedStepMoveTo && reduxStore.getState().db.cards[data.onConcludedStepMoveTo] ?\n                                        <React.Fragment>\n                                            <ConnectedIn\n                                                id={data.onConcludedStepMoveTo}\n                                                // loading={loadingData}\n                                                showLegend={true}\n                                                legend={translate(\"$__target\")}\n                                            />\n                                        </React.Fragment>\n                                        : <React.Fragment></React.Fragment>\n                                    }\n                                </div>\n                            </fieldset>\n                            : <React.Fragment></React.Fragment>\n                        }\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <legend>{translate(`$__status`, 1)}</legend>\n                            <fieldset style={{ marginBottom: \"14px\" }}>\n                                <legend>{translate(\"$__changeStatusTo\", 1)}</legend>\n                                <AutomationAction\n                                    value={data.automationStatusType || null}\n                                    onChange={(e) => {\n                                        changeData({ name: \"automationStatusType\", value: e })\n                                    }}\n                                    ignoreValues={['add', 'remove']}\n                                />\n                                {data.automationStatusType && data.automationStatusType !== \"doNotChange\" ?\n                                    <Autocomplete\n                                        id=\"combo-box-demo\"\n                                        options={db.status}\n                                        getOptionLabel={(option) => translate(option.label, 1)}\n                                        style={{ width: \"100%\" }}\n                                        name=\"automationStatus\"\n                                        disableClearable\n                                        value={\n                                            data\n                                                && data.automationStatus\n                                                && db.status\n                                                ? db.status.filter(a =>\n                                                    String(a.value) === String(data.automationStatus)\n                                                )[0]\n                                                : db.status[0]\n                                        }\n                                        renderInput={(params) =>\n                                            <TextField\n                                                {...params}\n                                                label={translate(\"$__status\", 1)}\n                                                variant={customApp(\"fieldVariant\")}\n                                                value={\n                                                    data\n                                                        && data.automationStatus\n                                                        && db.status\n                                                        ? db.status.filter(a =>\n                                                            String(a.value) === String(data.automationStatus)\n                                                        )[0]\n                                                        : db.status[0]\n                                                }\n                                            />\n                                        }\n                                        onChange={\n                                            (d, v) => {\n                                                if (permission || String(CardAccess) !== \"0\")\n                                                    changeData({ name: \"automationStatus\", value: v[\"value\"] })\n                                            }\n                                        }\n                                    /> : <React.Fragment></React.Fragment>\n                                }\n                            </fieldset>\n                        </fieldset>\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <div\n                                style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    color: \"gray\",\n                                    fontSize: 10\n                                }}\n                            >{translate('$__automationApprovalExplain', 1)}</div>\n                            <div className={classes.switch}>\n                                <Switch\n                                    checked={\n                                        data.requireApproval\n                                            ? true\n                                            : false\n                                    }\n                                    onChange={(d) => {\n                                        changeData({\n                                            name: \"requireApproval\",\n                                            value: data.requireApproval ? false : true\n                                        })\n                                    }}\n                                    name=\"requireApproval\"\n                                    inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                />\n                                {translate(\"$__requireApproval\", 1)}\n                            </div>\n                            {data.requireApproval ?\n                                <QuickUsers\n                                    _id={data._id}\n                                    noLimit\n                                    avatarSize=\"33px\"\n                                    permission={permission}\n                                    customDefine={{\n                                        name: \"approvalResponsible\",\n                                        icon: \"gavel\"\n                                    }}\n                                />\n                                : <React.Fragment></React.Fragment>}\n                        </fieldset>\n                        <fieldset style={{ marginBottom: \"14px\" }}>\n                            <div\n                                style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    color: \"gray\",\n                                    fontSize: 10\n                                }}\n                            >{translate('$__showInPanel', 1)}</div>\n                            <div className={classes.switch}>\n                                <Switch\n                                    checked={\n                                        data.showInPanel\n                                            ? true\n                                            : false\n                                    }\n                                    onChange={(d) => {\n                                        changeData({\n                                            name: \"showInPanel\",\n                                            value: data.showInPanel ? false : true\n                                        })\n                                    }}\n                                    name=\"showInPanel\"\n                                    inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                />\n                                {translate(\"$__permitOpenTicketInPanel\", 1)}\n                            </div>\n                            {data.showInPanel ?\n                                <React.Fragment>\n                                    <fieldset\n                                        style={{ marginBottom: '14px' }}\n                                        id={`sideModule_user_group`}\n                                    >\n                                        <MultInput\n                                            data={{\n                                                values: data.showGroups || [],\n                                                _id: data._id,\n                                            }}\n                                            options={reduxStore.getState().db.userGroup ? reduxStore.getState().db.userGroup : []}\n                                            placeholder={\"$__userGroupPlaceholder\"}\n                                            dbNode={\"userGroup\"}\n                                            callBack={(v) => {\n                                                changeData({ name: 'showGroups', value: v })\n                                            }}\n                                        />\n                                    </fieldset>\n                                    <TextField\n                                        label={translate(\"$__shortCutTitle\", 1)}\n                                        variant={customApp(\"fieldVariant\")}\n                                        name={\"shortCutTitle\"}\n                                        InputLabelProps={{\n                                            shrink: true,\n                                        }}\n                                        InputProps={{\n                                            autoComplete: \"new-password\",\n                                            endAdornment: (\n                                                <InputAdornment position=\"end\">\n                                                    <Icon icon=\"view_headline\" />\n                                                </InputAdornment>\n                                            ),\n                                            onChange: (d) => {\n                                                changeData(d.target)\n                                            },\n                                        }}\n                                        value={data && data.shortCutTitle ? data.shortCutTitle : \"\"}\n                                        placeholder={translate(\"$__shortCutTitlePlaceholder\")}\n                                    />\n                                    <TextField\n                                        label={translate(\"$__shortCutDescription\", 1)}\n                                        variant={customApp(\"fieldVariant\")}\n                                        name=\"shortCutDescription\"\n\n                                        InputProps={{\n                                            autoComplete: \"new-password\",\n                                            multiline: true,\n                                            minRows: 3,\n                                            endAdornment: (\n                                                <InputAdornment position=\"end\">\n                                                    <Icon icon=\"toc\" />\n                                                </InputAdornment>\n                                            ),\n                                            onChange: (d) => {\n                                                changeData(d.target)\n                                            },\n                                        }}\n                                        value={data && data.shortCutDescription ? data.shortCutDescription : \"\"}\n                                        placeholder={translate(\"$__shortCutDescriptionPlaceholder\", 1)}\n                                    />\n                                    <TextField\n                                        label={translate(\"$__shortCutButtonToAdd\", 1)}\n                                        variant={customApp(\"fieldVariant\")}\n                                        name={\"shortCutButtonToAdd\"}\n                                        InputLabelProps={{\n                                            shrink: true,\n                                        }}\n                                        InputProps={{\n                                            autoComplete: \"new-password\",\n                                            endAdornment: (\n                                                <InputAdornment position=\"end\">\n                                                    <Icon icon=\"view_headline\" />\n                                                </InputAdornment>\n                                            ),\n                                            onChange: (d) => {\n                                                changeData(d.target)\n                                            },\n                                        }}\n                                        value={data && data.shortCutButtonToAdd ? data.shortCutButtonToAdd : \"\"}\n                                        placeholder={translate(\"$__shortCutButtonToAddPlaceholder\")}\n                                    />\n                                </React.Fragment>\n                                :\n                                <React.Fragment></React.Fragment>\n                            }\n                        </fieldset>\n                    </fieldset>\n                </div>\n            </div>\n        </React.Fragment>\n    )\n}\n\nconst AutomationAction = (props) => {\n    const { db } = reduxStore.getState()\n    return (\n        <Autocomplete\n            id=\"combo-box-demo\"\n            options={props.ignoreValues ? db.automation.filter(r => props.ignoreValues.indexOf(r.value) === -1) : db.automation}\n            getOptionLabel={(option) => translate(option.label, 1)}\n            style={{ width: \"100%\" }}\n            name={props.name || \"AutomationAction\"}\n            disableClearable\n            value={props.value ? db.automation.filter(a =>\n                String(a.value) === props.value\n            )[0]\n                : db.automation[0]\n            }\n            renderInput={(params) =>\n                <TextField\n                    {...params}\n                    label={translate(\"$__action\", 1)}\n                    variant={customApp(\"fieldVariant\")}\n                    inputProps={{\n                        ...params && params.inputProps ? params.inputProps : {},\n                        style: {\n                            ...params && params.inputProps && params.inputProps.style ? params.inputProps.style : {},\n                            paddingLeft: 7,\n                            marginTop: 3,\n                            marginLeft: -5,\n                            width: \"calc(100% - 7px)\",\n                        }\n                    }}\n                    value={props.value ? db.automation.filter(a =>\n                        String(a.value) === props.value\n                    )[0]\n                        : db.automation[0]\n                    }\n                />\n            }\n            renderOption={(option, { inputValue }) => {\n                return (\n                    <span>\n                        {translate(option.label, 1)}\n                    </span>\n                )\n            }}\n            onChange={\n                (d, v) => {\n                    props.onChange(v[\"value\"])\n                }\n            }\n        />\n    )\n}\nconst mapStateToProps = (store) => ({\n    sideModule: store.sideModule,\n    card: store.db.cards[store.sideModule.id],\n    cards: store.db.cards\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React from 'react';\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\";\nimport { makeStyles } from '@material-ui/core/styles';\nimport Tooltip from \"@material-ui/core/Tooltip\";\n\n\nconst useStyles = makeStyles((theme) => ({\n    root: {\n        display: 'flex',\n        '& > *': {\n            margin: theme.spacing(1),\n        },\n    },\n    sm: {\n        width: theme.spacing(3),\n        height: theme.spacing(3),\n    },\n    md: {\n        width: theme.spacing(5),\n        height: theme.spacing(5),\n    },\n    lg: {\n        width: theme.spacing(7),\n        height: theme.spacing(7),\n    },\n}));\n\nexport default function Component(props) {\n    const classes = useStyles();\n    let AvatarProps = { ...props }\n    if (AvatarProps.title)\n        delete AvatarProps.title\n    if (props.title)\n        return (\n            <Tooltip\n                title={props.title}\n            >\n                <Avatar {...AvatarProps} className={classes[props.size]} >\n                    {props.children}\n                </Avatar>\n            </Tooltip>\n        )\n    return (\n        <Avatar {...AvatarProps} className={classes[props.size]} >\n            {props.children}\n        </Avatar>\n    )\n}","//CORE\r\nimport React from \"react\"\r\nimport ReactAudioPlayer from \"react-audio-player\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store\"\r\n\r\n//COMPONENTS\r\nimport Card from \"components/Card\";\r\nimport Icon from \"components/Icon\";\r\nimport Message from \"components/Timeline/message\";\r\nimport HeaderWithIcon from \"components/Header/card\";\r\n\r\n//@MATERIAL\r\nimport Avatar from \"components/Avatar\";\r\n\r\n//FUNCTIONS\r\nimport { translate, customApp, getDate } from \"functions\";\r\n\r\nfunction Component(props) {\r\n    const { timeline, functions, session } = reduxStore.getState()\r\n    const { socket } = functions\r\n    const { db } = reduxStore.getState()\r\n    const [file, setFile] = React.useState(props.data)\r\n\r\n    React.useEffect(() => {\r\n        return () => {\r\n            // return false\r\n        }\r\n    }, [])\r\n    const fileName = file.name.split(\".\")\r\n    let ext = fileName[fileName.length - 1]\r\n\r\n    if (file.name === \"blob\") {\r\n        file.name = `${translate(\"$__coverImage\", \"*\")}.jpg`\r\n        ext = \"jpg\"\r\n    }\r\n\r\n    let img = `attachment`\r\n    if (reduxStore.getState().db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0)\r\n        img = reduxStore.getState().db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].icon\r\n            || `https://machen.azureedge.net/${file.file}`\r\n\r\n\r\n    const update = async (dataUpdate) => {\r\n        try {\r\n            socket.emit(\"data\", {\r\n                module: \"node\",\r\n                method: \"put\",\r\n                action: \"update\"\r\n            }, {\r\n                _id: file._id,\r\n                ...dataUpdate\r\n            }, async () => {\r\n                setFile({ ...file, ...dataUpdate })\r\n            })\r\n        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    }\r\n\r\n    let viewer = \"img\"\r\n    if (db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0 && db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].viewer)\r\n        viewer = db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].viewer\r\n    return (\r\n        <div>\r\n            <div\r\n                style={{\r\n                    position: \"relative\",\r\n                    float: \"left\",\r\n                    width: \"100%\",\r\n                    marginBottom: \"5px\",\r\n                    cursor: \"pointer\",\r\n                }}\r\n            >\r\n                <div\r\n                    style={{\r\n                        position: \"relative\",\r\n                        width: \"100%\",\r\n                    }}\r\n\r\n                >\r\n                    {/* {file.parents && file.parents.length > 0 ?\r\n                        <div style={{ position: \"relative\", width: \"100%\", display: \"flex\", fontSize: 10, color: \"gray\" }}>\r\n                            {file.parents.reverse().map(p =>\r\n                                <div key={p._id}>\r\n                                    {p.name} /\r\n                                </div>\r\n                            )}\r\n                        </div>\r\n                        : <React.Fragment></React.Fragment>} */}\r\n                    <div style={{\r\n                        display: \"flex\",\r\n                        alignItems: \"center\"\r\n                    }}>\r\n                        {file.in && file.in.private && !props.showPrivate\r\n                            ?\r\n                            <div\r\n                                style={{\r\n                                    position: \"relative\",\r\n                                    float: \"left\",\r\n                                    width: \"33px\",\r\n                                    height: \"33px\",\r\n                                    alignItems: \"center\",\r\n                                    justifyContent: \"center\",\r\n                                    backgroundColor: \"lightgray\",\r\n                                    backgroundSize: \"cover\",\r\n                                    backgroundRepeat: \"no-repeat\",\r\n                                    borderRadius: 7,\r\n                                    display: \"flex\"\r\n                                }}\r\n                            >\r\n                                <Icon icon={'lock'} size=\"17px\" />\r\n                            </div>\r\n                            :\r\n                            <React.Fragment>\r\n                                {typeof img === \"string\" && img.indexOf(\"https\") === -1 && img.indexOf(\"svg\") === -1 ?\r\n                                    <div\r\n                                        style={{\r\n                                            position: \"relative\",\r\n                                            float: \"left\",\r\n                                            width: \"33px\",\r\n                                            height: \"33px\",\r\n                                            alignItems: \"center\",\r\n                                            display: \"flex\",\r\n                                            cursor: \"pointer\"\r\n                                        }}\r\n                                        onClick={(e) => {\r\n\r\n                                            if (props.openLightBox)\r\n                                                props.openLightBox()\r\n                                        }}\r\n                                    >\r\n                                        <Icon icon={img} size=\"33px\" />\r\n                                    </div>\r\n                                    :\r\n                                    <div\r\n                                        style={{\r\n                                            position: \"relative\",\r\n                                            float: \"left\",\r\n                                            width: \"33px\",\r\n                                            height: \"33px\",\r\n                                            alignItems: \"center\",\r\n                                            backgroundImage: `url(\"${img}\")`,\r\n                                            backgroundSize: \"cover\",\r\n                                            backgroundRepeat: \"no-repeat\",\r\n                                            borderRadius: 7,\r\n                                            cursor: \"pointer\"\r\n                                        }}\r\n                                        onClick={(e) => {\r\n                                            if (props.openLightBox)\r\n                                                props.openLightBox()\r\n                                        }}\r\n                                    ></div>\r\n                                }\r\n                            </React.Fragment>\r\n                        }\r\n                        <div\r\n                            style={{\r\n                                display: \"flex\",\r\n                                paddingLeft: 15,\r\n                                alignItems: \"center\",\r\n                                maxWidth: \"calc(100% - 40px)\"\r\n                            }}\r\n                        >\r\n                            {file.in && file.in.name &&\r\n                                <div style={{ display: \"flex\", alignItems: \"center\" }}>\r\n                                    {file.in.db === \"User\" && file.in._id === session._id ?\r\n                                        <div>\r\n                                            <Avatar\r\n                                                alt={file.createdBy.name}\r\n                                                src={file.createdBy.image}\r\n                                                style={{ width: \"21px\", height: \"21px\" }}\r\n                                            >\r\n                                                {file.createdBy.name}\r\n                                            </Avatar>\r\n                                        </div>\r\n                                        : <React.Fragment></React.Fragment>\r\n                                    }\r\n\r\n                                    {file.in.db === \"User\" && file.in._id !== session._id ?\r\n                                        <div>\r\n                                            <Avatar\r\n                                                alt={file.in.name}\r\n                                                src={file.in.image}\r\n                                                style={{ width: \"21px\", height: \"21px\" }}\r\n                                            >\r\n                                                {file.in.name}\r\n                                            </Avatar>\r\n                                        </div>\r\n                                        : <React.Fragment></React.Fragment>\r\n                                    }\r\n                                    <HeaderWithIcon\r\n                                        private={file.in && file.in.private ? true : false}\r\n                                        title={`${file.in.db === \"User\"\r\n                                            ? `${translate('$__chatWithUser', '*')} - ${file.in._id !== session._id ? `${file.in.name}` : `${file.createdBy.name}`}`\r\n                                            : file.in.type === \"chatGroup\"\r\n                                                ? `${translate('$__chatGroup', '*')} - ${file.in.name}`\r\n                                                : file.in.db !== \"User\" && file.in.type !== \"chatGroup\" ? `${file.in.name}` : ``}`\r\n                                        }\r\n                                        icon={\r\n                                            file.in.db === \"User\" || file.in.type === \"chatGroup\" ? null\r\n                                                :\r\n                                                (\r\n                                                    file.in.type\r\n                                                    && db\r\n                                                    && db.dataType\r\n                                                    && db.dataType.filter(a =>\r\n                                                        a.name === file.in.type\r\n                                                    )[0]\r\n                                                    && db.dataType.filter(a =>\r\n                                                        a.name === file.in.type\r\n                                                    )[0].icon\r\n                                                )\r\n                                                || \"$__topic\"\r\n                                        }\r\n                                        color={customApp(\"medium\")}\r\n                                        style={{\r\n                                            padding: \"7px\",\r\n                                            minHeight: \"21px !important\",\r\n                                            textAlign: \"left\"\r\n                                        }}\r\n                                        textStyle\r\n                                    />\r\n                                    <span style={{ marginRight: 7 }}>/</span>\r\n                                </div>\r\n                            }\r\n                            <HeaderWithIcon\r\n                                private={file.in && file.in.private ? true : false}\r\n                                privateTitle={translate(\"$__privateFile\")}\r\n                                title={file.name}\r\n                                value={file.name.replace(`.${ext}`, \"\")}\r\n                                searchText={props.searchText ? props.searchText : null}\r\n                                color={props.dark ? customApp(\"lightgray\") : customApp(\"gray\")}\r\n                                editable={props.admin ? true : false}\r\n                                _id={file._id}\r\n                                dark={props.dark ? true : false}\r\n                                inputStyle={props.dark ? {\r\n                                    backgroundColor: \"rgba(250,250,250,0.8)\",\r\n                                    borderRadius: 7,\r\n                                } : null}\r\n                                textStyle={{\r\n                                    fontSize: 12,\r\n                                    fontWeight: \"normal\",\r\n                                }}\r\n                                searchTextStyle={{\r\n                                    fontSize: 12,\r\n                                    ...props.dark ? { color: \"#FFFFFF\" } : {}\r\n                                }}\r\n                                style={{\r\n                                    minHeight: \"21px !important\",\r\n                                }}\r\n                                onEdit={\r\n                                    props.admin ? (res) => {\r\n                                        update({\r\n                                            name: `${res}.${ext}`\r\n                                        })\r\n                                    } : null}\r\n                            />\r\n                        </div>\r\n                    </div>\r\n                    {viewer === \"audio\"\r\n                        &&\r\n                        <div style={{\r\n                            position: \"relative\",\r\n                            width: \"100%\",\r\n                            float: \"left\"\r\n                        }}>\r\n                            <ReactAudioPlayer\r\n                                src={`https://machen.azureedge.net/${file.file}`}\r\n                                controls\r\n                            />\r\n                        </div>\r\n                    }\r\n                    {file.createdBy &&\r\n                        <div style={{\r\n                            position: \"relative\",\r\n                            display: \"flex\",\r\n                            alignItems: \"center\",\r\n                            color: props.dark ? \"lightgray\" : \"gray\",\r\n                            fontSize: 10,\r\n                            marginLeft: \"57px\",\r\n                            clear: \"both\"\r\n                        }}>\r\n                            {((file.in && !file.in.private)) ?\r\n                                <React.Fragment>\r\n                                    <span style={{ color: \"lightgray\", fontSize: 10, marginRight: 7 }}>{translate(\"$__sendedBy\")}:</span>\r\n                                    <Avatar\r\n                                        alt={file.createdBy.name}\r\n                                        src={file.createdBy.image}\r\n                                        style={{ width: \"15px\", height: \"15px\" }}\r\n                                    >\r\n                                        {file.createdBy.name}\r\n                                    </Avatar>\r\n                                    <span style={{ marginLeft: 3 }}>\r\n                                        {file.createdBy.name}\r\n                                    </span>\r\n                                </React.Fragment>\r\n                                : <React.Fragment></React.Fragment>\r\n                            }\r\n                            <span style={{ marginLeft: 3 }}>\r\n                                {getDate(file.created_at)}\r\n                            </span>\r\n                        </div>\r\n\r\n                    }\r\n                </div>\r\n                {props.showParent &&\r\n                    (\r\n                        file.timelineId\r\n                        || file.message\r\n                    )\r\n                    &&\r\n                    (\r\n                        (\r\n                            db.cards[file.cardId]\r\n                            && timeline[file.cardId]\r\n                            && timeline[file.cardId][file.timelineId]\r\n                        )\r\n                        ||\r\n                        (\r\n                            file.message\r\n                        )\r\n                    )\r\n                    &&\r\n                    <div style={{ width: \"100%\", marginBottom: \"33px\" }} >\r\n                        <Message\r\n                            openLightBox={(e) => {\r\n                                if (props.openLightBox)\r\n                                    props.openLightBox(e)\r\n                            }}\r\n                            storie={db.cards[file.cardId] && timeline[file.cardId] && timeline[file.cardId][file.timelineId] ? timeline[file.cardId][file.timelineId] : file.message}\r\n                            db={\"cards\"} nodeId={file.cardId}\r\n                        />\r\n                        <div style={{ clear: \"both\" }}></div>\r\n                    </div>\r\n                }\r\n                {props.showParent && file.cardId && db.cards[file.cardId] &&\r\n                    <div style={{ width: \"100%\", top: \"33px\" }}>\r\n                        <Card db=\"cards\" data={db.cards[file.cardId]} showConnectedIn />\r\n                    </div>\r\n                }\r\n                <div style={{ width: \"100%\", height: \"1px\", backgroundColor: \"rgba(0,0,0,0.1)\", marginTop: \"15px\" }}></div>\r\n            </div >\r\n            {/* {\r\n                (file.timelineId || file.message)\r\n                && viewMessage\r\n                &&\r\n                (\r\n                    (\r\n                        db.cards[file.cardId]\r\n                        && timeline[file.cardId]\r\n                        && timeline[file.cardId][file.timelineId]\r\n                    )\r\n                    ||\r\n                    (\r\n                        file.message\r\n                    )\r\n                )\r\n                &&\r\n                <div style={{ width: \"100%\" }} >\r\n                    <Message\r\n                        openLightBox={(e) => {\r\n                            if (props.openLightBox)\r\n                                props.openLightBox(e)\r\n                        }}\r\n                        storie={db.cards[file.cardId] && timeline[file.cardId] && timeline[file.cardId][file.timelineId] ? timeline[file.cardId][file.timelineId] : file.message}\r\n                        db={\"cards\"} nodeId={file.cardId}\r\n                    />\r\n                </div>\r\n            } */}\r\n        </div >\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    showPrivate: store.controls.lockPrivate,\r\n    history: store.db.history\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(Component)\r\n","// ID_CREATED*************************\n\n//CORE\nimport React from 'react'\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport TextField from \"components/TextField\";\n\n//@MATERIAL\nimport LinearProgress from \"components/Progress/linear\"\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\n\n//DEPENDENCIES\nimport File from \"./file_V2\";\n\n//FUNCTIONS\nimport { loadFiles } from \"functions/files\";\nimport {\n    customApp,\n    translate,\n    removeSeats\n} from 'functions';\n\nfunction Component(props) {\n    const { db, session } = reduxStore.getState()\n    const [loading, setLoading] = React.useState(true)\n    const [files, setFiles] = React.useState([])\n    const [endLoad, setEndLoad] = React.useState(false)\n    const [loadingFiles, setLoadingFiles] = React.useState(false)\n    const [searchValue, setSearchValue] = React.useState('')\n    const [page, setPage] = React.useState(0)\n\n    let lightBoxfiles = [];\n\n    React.useEffect(() => {\n        setLoadingFiles(true)\n        return () => {\n            setFiles([])\n            setLoading(true)\n        }\n    }, [props.nodeId])\n\n    React.useEffect(() => {\n        setLoadingFiles(true)\n    }, [page])\n\n    React.useEffect(() => {\n        if (loadingFiles)\n            init()\n    }, [loadingFiles])\n\n    const init = async () => {\n        if (!endLoad) {\n            let lf = await loadFiles({ ids: [props.nodeId], type: db.cards[props.nodeId] ? 'cards' : 'users', page })\n            if (lf) {\n                if (lf.length < 20)\n                    setEndLoad(true)\n                let newFiles = Array.from(files)\n                lf.map(x => {\n                    // console.log(x)\n                    if (newFiles.filter(fl => fl && fl.data && x && x.data && fl.data._id === x.data._id).length === 0)\n                        newFiles.push(x)\n                })\n                setFiles(newFiles)\n                setLoading(false)\n                setLoadingFiles(false)\n            }\n        }\n    }\n\n    const openLightBox = (f) => {\n        props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n            open: true,\n            files: lightBoxfiles,\n            file: f\n        })\n    }\n\n    const scrollFunction = (e) => {\n        var scrollDiv = document.getElementById(`filesList_${props.nodeId}`);\n        if (scrollDiv.scrollTop + window.innerHeight + 150 > scrollDiv.scrollHeight && !loadingFiles)\n            setPage(page + 1)\n    }\n\n    return (\n        <div style={{\n            position: 'relative',\n            width: \"100%\",\n            height: \"100%\"\n        }}\n            id=\"sideModule_files\"\n        >\n            {((!searchValue && files.length > 10) || searchValue) &&\n                <div style={{ position: 'relative', padding: '10px' }}>\n                    <TextField\n                        label={translate('$__fileNameSearch', 1)}\n                        variant={customApp('fieldVariant')}\n                        name={'name'}\n                        id=\"sideModule_files_search\"\n                        InputLabelProps={{\n                            shrink: true,\n                        }}\n                        InputProps={{\n                            autoComplete: 'new-password',\n                            endAdornment: (\n                                <InputAdornment position=\"end\">\n                                    <Icon icon='find_in_page' />\n                                </InputAdornment>\n                            ),\n                            onChange: (d) => {\n                                setSearchValue(d.target.value)\n                            },\n                        }}\n                        value={removeSeats(searchValue).toLowerCase()}\n                        placeholder={translate(\"$__fileNameSearch\")}\n                    />\n                </div>\n            }\n            <div\n                style={{\n                    position: \"absolute\",\n                    bottom: 0,\n                    top: files && files.length > 10 ? 63 : 0,\n                    padding: 15,\n                    left: 0,\n                    right: 0\n                }}\n                id=\"sideModule_files_list\"\n            >\n                <legend style={{\n                    display: 'flex',\n                    alignItems: 'center',\n                    color: props.dark ? customApp('color') : customApp('menu'),\n                    fontSize: 14\n                }}><Icon\n                        color={customApp('color')}\n                        icon={'folder_open'}\n                        title={translate('$__files', '*')}\n                        size={'20px'}\n                        style={{ marginRight: '15px' }}\n                    />{translate('$__files', '*')}</legend>\n\n\n                <ul\n                    id={`filesList_${props.nodeId}`}\n                    style={{\n                        listStyle: 'none',\n                        padding: '0px',\n                        position: \"absolute\",\n                        bottom: 0,\n                        top: 33,\n                        overflowY: \"auto\",\n                        overflowX: \"hidden\",\n                        left: 15,\n                        right: 15\n                    }}\n                    onScroll={!props.horizontal ? (e) => {\n                        scrollFunction(e)\n                    } : null}\n                >\n\n                    {files && files.length > 0 &&\n                        files\n                            .filter(f =>\n                            (\n                                (\n                                    !searchValue\n                                    || searchValue === ''\n                                    ||\n                                    (\n                                        searchValue\n                                        && f.data.name.toLowerCase().indexOf(searchValue.toLocaleLowerCase()) > -1\n                                    )\n                                )\n                            )\n                            )\n                            .sort((a, b) => parseInt(a.data.created_at) < parseInt(b.data.created_at))\n                            .map((f, i) => {\n                                lightBoxfiles.push(f.data)\n                                let file = {\n                                    ...f.data,\n                                    createdBy: f.createdBy\n                                }\n\n                                let permission = false\n                                if (\n                                    (\n                                        file.createdBy\n                                        && file.createdBy._id === session._id\n                                    )\n                                    ||\n                                    (\n                                        props.nodeId\n                                        && db.cards[props.nodeId]\n                                        && db.cards[props.nodeId]._users\n                                        && db.cards[props.nodeId]._users[session._id]\n                                        && db.cards[props.nodeId]._users[session._id].access > 2\n                                    )\n                                ) permission = true\n\n\n                                return (\n                                    <li\n                                        key={f.data._id}\n                                        onClick={!permission ? (e) => {\n                                            openLightBox(f.data._id)\n                                            e.preventDefault();\n                                        } : null}\n                                        id={`sideModule_files_file_${f.data._id}`}\n                                    >\n                                        <File\n                                            data={file}\n                                            resume\n                                            dark={props.dark ? true : false}\n                                            admin={permission}\n                                            searchText={searchValue}\n                                            openLightBox={() => {\n                                                openLightBox(f.data._id)\n                                            }}\n                                        />\n                                    </li>\n                                )\n                            })}\n                    {((files.length > 0 || loadingFiles) && !endLoad) ?\n                        <li style={{\n                            width: '100%',\n                            textAlign: 'center',\n                            position: \"relative\",\n                            float: \"left\",\n                            color: props.dark ? customApp('color') : customApp('menu')\n                        }}><LinearProgress />{translate('$__checkingFiles', '*')}</li>\n                        : files.length === 0 && !loadingFiles ?\n                            translate('$__hasNoFiles', '*')\n                            : <React.Fragment></React.Fragment>\n                    }\n                </ul>\n            </div>\n        </div>\n    )\n}\nconst mapStateToProps = () => ({});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n\n","//CORE\r\nimport React from \"react\";\r\nimport styled from \"styled-components\";\r\nimport { DragDropContext, Droppable, Draggable } from \"react-beautiful-dnd\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store/\";\r\n\r\n//COMPONENTS\r\nimport Card from \"components/Card/\";\r\n\r\nfunction Component(props) {\r\n    const { db, session } = reduxStore.getState()\r\n    const { socket } = reduxStore.getState().functions\r\n    const [name, setName] = React.useState(props.name ? props.name : '')\r\n    const [add, setAdd] = React.useState(false)\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace('#', '')\r\n    if (hashs[0].length !== 36) {\r\n        hashs[0] = null\r\n    }\r\n\r\n    let parent = {}\r\n    if (reduxStore.getState().db[props.db] && reduxStore.getState().db[props.db][props.nodeId])\r\n        parent = reduxStore.getState().db[props.db][props.nodeId]\r\n\r\n    let tasksCards = Object.keys(reduxStore.getState().db.cards)\r\n        .filter(fil => {\r\n            if (\r\n                !reduxStore.getState().db.cards[fil].deleted\r\n                && !reduxStore.getState().db.cards[fil].checklist\r\n                && reduxStore.getState().db.cards[fil]._recurrenceId\r\n                && reduxStore.getState().db.cards[fil]._parent === props.nodeId\r\n            )\r\n                return true\r\n        }\r\n        )\r\n        .map(card => card)\r\n\r\n    const onDragEnd = async result => {\r\n        let cardsOn = Object.keys(reduxStore.getState().db.cards)\r\n            .filter(fil => {\r\n                if (reduxStore.getState().db.cards[fil] && reduxStore.getState().db.cards[fil].checklist && reduxStore.getState().db.cards[fil]._parent === props.nodeId)\r\n                    return true\r\n            }\r\n            )\r\n            .sort((a, b) => {\r\n                if (db.cards[a].order && db.cards[b].order && String(db.cards[a].order.low) && String(db.cards[b].order.low) && parseInt(db.cards[a].order.low) < parseInt(db.cards[b].order.low)) {\r\n                    return -1\r\n                } else if (db.cards[a].order && db.cards[b].order && String(db.cards[a].order.low) && String(db.cards[b].order.low) && parseInt(db.cards[a].order.low) > parseInt(db.cards[b].order.low)) {\r\n                    return 1\r\n                } else {\r\n                    return 0\r\n                }\r\n            })\r\n            .map(card => card)\r\n\r\n        const { destination, source, draggableId } = result\r\n\r\n        if (!destination) return false\r\n\r\n        if (destination.droppableId === source.droppableId && destination.id === source.index) return false\r\n\r\n        const itemOrderIds = cardsOn\r\n        itemOrderIds.splice(source.index, 1)\r\n        itemOrderIds.splice(destination.index, 0, draggableId)\r\n\r\n        socket.emit(\"data\", {\r\n            module: \"cards\",\r\n            method: \"put\",\r\n            action: \"reorder\"\r\n        }, {\r\n            cards: itemOrderIds\r\n        })\r\n        let cards = {}\r\n\r\n        itemOrderIds.map((a, i) => {\r\n            cards = {\r\n                ...cards,\r\n                [a]: db.cards[a]\r\n            }\r\n            cards = {\r\n                ...cards,\r\n                [a]: {\r\n                    ...cards[a],\r\n                    order: {\r\n                        low: `${i + 1}`\r\n                    }\r\n                }\r\n            }\r\n            return true\r\n        })\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...reduxStore.getState().db,\r\n            cards: {\r\n                ...reduxStore.getState().db.cards,\r\n                ...cards\r\n            }\r\n        });\r\n        return\r\n\r\n    }\r\n    const onDragStart = async result => {\r\n    }\r\n    const onDragUpdate = async result => {\r\n    }\r\n\r\n    return (\r\n        <div style={{ width: '100%' }}>\r\n            <DragDropContext\r\n                onDragEnd={onDragEnd}\r\n                onDragStart={onDragStart}\r\n                onDragUpdate={onDragUpdate}\r\n            >\r\n                <Droppable\r\n                    droppableId={`Drop_tasks`} //ID OF BOARD\r\n                    type=\"column\"\r\n                    direction={\"vertical\"}\r\n                >\r\n                    {(provided, snapshot) => (\r\n                        <Container\r\n                            ref={provided.innerRef}\r\n                            {...provided.droppableProps}\r\n                            isDraggingOver={snapshot.isDraggingOver}\r\n                        >\r\n                            {tasksCards\r\n                                .sort((a, b) => {\r\n                                    if (db.cards[a].order && db.cards[b].order && String(db.cards[a].order.low) && String(db.cards[b].order.low) && parseInt(db.cards[a].order.low) < parseInt(db.cards[b].order.low)) {\r\n                                        return -1\r\n                                    } else if (db.cards[a].order && db.cards[b].order && String(db.cards[a].order.low) && String(db.cards[b].order.low) && parseInt(db.cards[a].order.low) > parseInt(db.cards[b].order.low)) {\r\n                                        return 1\r\n                                    } else {\r\n                                        return 0\r\n                                    }\r\n                                })\r\n                                .map((card, index) => (\r\n                                    <Draggable\r\n                                        draggableId={card}\r\n                                        index={index}\r\n                                        key={card}\r\n                                    >\r\n                                        {(provided, snapshot) => (\r\n                                            <Card\r\n                                                provided={provided}\r\n                                                snapshot={snapshot}\r\n                                                data={db.cards[card]}\r\n                                                db={'cards'}\r\n                                                onlyOption\r\n                                                showCompleteOption\r\n                                                directDeletion\r\n                                                editable\r\n                                                noShowRecurrenceCard\r\n                                            />\r\n                                        )}\r\n                                    </Draggable>\r\n                                ))}\r\n                            {provided.placeholder}\r\n                        </Container>\r\n                    )}\r\n                </Droppable>\r\n            </DragDropContext>\r\n        </div >\r\n    )\r\n}\r\n\r\nconst Container = styled.div`\r\n            background-color:none;\r\n            `;\r\n\r\nconst ContainerDeleted = styled.div\r\n    `background-color:red;\r\n            padding:7px;`\r\n\r\nconst mapStateToProps = store => ({\r\n    store\r\n});\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = theme => ({\r\n    root: {\r\n        height: 'auto',\r\n        transform: 'translateZ(0px)',\r\n        flexGrow: 1,\r\n        zIndex: 1000,\r\n        height: '100vh'\r\n    },\r\n    speedDial: {\r\n        position: 'absolute',\r\n        bottom: theme.spacing(2),\r\n        right: theme.spacing(2),\r\n        '& .MuiFab-root': {\r\n            backgroundColor: customApp('color'),\r\n            color: customApp('lightText'),\r\n            display: 'flex',\r\n            alignItems: 'center',\r\n            justifyContent: 'center'\r\n        }\r\n    },\r\n    speedDialInvisible: {\r\n        //position: 'relative',\r\n        //float: 'right',\r\n        //bottom: theme.spacing(2),\r\n        right: theme.spacing(2),\r\n        bottom: '-60px',\r\n        position: 'absolute',\r\n        '& .MuiFab-root': {\r\n            backgroundColor: customApp('color'),\r\n            color: customApp('lightText'),\r\n            display: 'flex',\r\n            alignItems: 'center',\r\n            justifyContent: 'center'\r\n        },\r\n        '& .MuiButtonBase-root': {\r\n            //display: 'none'\r\n        }\r\n    }\r\n})\r\n\r\nexport default style;","import React from 'react';\nimport { v4 as uuid } from \"uuid\";\n\n//@MATERIAL\nimport { withStyles } from '@material-ui/core/styles';\nimport Pagination from '@material-ui/lab/Pagination';\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport AutoComplete from \"components/AutoComplete\";\nimport Card from \"components/Card\";\nimport TextField from \"components/TextField\";\nimport Button from \"components/CustomButtons/Custom\";\n\n\n//FUNCTIONS\nimport { translate, customApp, appAlert } from \"functions/\";\nimport { loadCards } from \"functions/loadData\";\nimport { cardCopyTo, cardMoveTo } from \"functions/cards\";\nimport { timelineComment } from \"functions/chat\";\n\nimport api from \"api\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/SpeedDial.js\";\n\nfunction Component(props) {\n    const { classes } = props;\n    const { socket } = reduxStore.getState().functions\n    const [typeFilter, setTypeFilter] = React.useState({ name: 'plan' });\n    const [search, setSearch] = React.useState('');\n    const [message, setMessage] = React.useState('');\n    const [selectCard, setSelectCard] = React.useState(null);\n    const [page, setPage] = React.useState(0);\n    const { db, session } = reduxStore.getState();\n    const { cards } = db;\n    const { data } = reduxStore.getState().sideModule;\n    const limit = 25\n\n    React.useEffect(() => {\n        (async () => {\n            await loadCards(props, null, false, null, 'plans', false)\n        })()\n    }, [])\n\n    const myRef = React.useRef(null)\n    const dataTypeOptions = []\n\n    db.dataType.filter(fil => fil.sendTo).map(a => {\n        dataTypeOptions.push({ name: a.name })\n    })\n\n    const AppAccess = db.users[Object.keys(db.users).find(a => a.indexOf(session._id) > -1)]._access\n\n    let CardAccess = 0\n\n    if (session._id\n        && db.cards[data._id]\n        && db.cards[data._id]._users\n        && db.cards[data._id]._users[Object.keys(db.cards[data._id]._users).find(a => a.indexOf(session._id) > -1)])\n        CardAccess = db.cards[data._id]._users[Object.keys(db.cards[data._id]._users).find(a => a.indexOf(session._id) > -1)]\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    let cardsResults = cards\n\n    cardsResults = Object.keys(cardsResults).filter(fil => {\n        if (\n            !cardsResults[fil].archived\n            && !cardsResults[fil].deleted\n            &&\n            (\n                (\n                    cardsResults[fil]._users\n                    && cardsResults[fil]._id !== data._id\n                    && cardsResults[fil]._users[session._id]\n                    && parseInt(cardsResults[fil]._users[session._id].access) > 2\n                )\n                ||\n                ((\n                    AppAccess\n                    &&\n                    (\n                        AppAccess.owner\n                        || AppAccess.planAdmin\n                        || AppAccess.planModerate\n                    )\n                ) ||\n                    (\n                        CardAccess\n                        && CardAccess.access\n                        && parseInt(CardAccess.access) > 2\n                    )\n                )\n            )\n        )\n            return true\n    }).map(a => cardsResults[a])\n    //}\n\n    if (search)\n        cardsResults = Object.keys(cardsResults).filter(fil => {\n            if (cardsResults[fil] && cardsResults[fil].name && cardsResults[fil].name.toLowerCase().indexOf(search.toLowerCase()) > -1)\n                return true\n        }).map(a => cardsResults[a])\n\n    if (typeFilter)\n        cardsResults = Object.keys(cardsResults).filter(fil => {\n            if (cardsResults[fil] && cardsResults[fil].type && cardsResults[fil].type === typeFilter.name)\n                return true\n        }).map(a => cardsResults[a])\n\n    cardsResults = Object.keys(cardsResults).filter(fil =>\n        data.type\n        && cardsResults[fil].type\n        && db.dataType.filter(a => a.name === data.type)\n        && db.dataType.filter(a => a.name === data.type).length > 0\n        && db.dataType.filter(a => a.name === data.type)[0].sharedIn\n        && (\n            db.dataType.filter(a => a.name === data.type)[0].sharedIn.copy.indexOf(cardsResults[fil].type) > -1\n            || db.dataType.filter(a => a.name === data.type)[0].sharedIn.attach.indexOf(cardsResults[fil].type) > -1\n            || db.dataType.filter(a => a.name === data.type)[0].sharedIn.shared.indexOf(cardsResults[fil].type) > -1\n        )\n    ).map(a => cardsResults[a])\n\n    const shareThis = async () => {\n        let dataSave = {\n            _id: uuid(),\n            cardId: data._id,\n            idRel: selectCard,\n            _parent: selectCard,\n            type: 'comment',\n            message: message || '',\n            shared: true\n        }\n        timelineComment(props, {\n            ...dataSave,\n            user: {\n                ...db.users[session._id]\n            },\n            files: {}\n        })\n        // socket.emit(\"data\", {\n        //     module: \"timeline\",\n        //     method: \"post\",\n        //     action: \"add\"\n        // },\n        //     dataSave,\n        //     (response) => {\n\n        //     })\n\n        api.post(\"timeline/add\", dataSave)\n        setSelectCard(null)\n        setTypeFilter({ name: 'plan' })\n    }\n\n    const copyTo = async () => {\n        appAlert({\n            message: translate('$__confirmCopyCard', 1),\n            variant: 'warning',\n            persist: false,\n            horizontal: 'right',\n            confirm: () => {\n                let dataSave = {\n                    cardId: data._id,\n                    idRel: selectCard,\n                    type: 'comment',\n                    message: message || '',\n                    shared: true\n                }\n                cardCopyTo(props, dataSave)\n                setSelectCard(null)\n                setTypeFilter({ name: 'plan' })\n            }\n        })\n    }\n    const moveTo = async () => {\n        appAlert({\n            message: translate('$__confirmMoveCard', 1),\n            variant: 'warning',\n            persist: false,\n            horizontal: 'right',\n            confirm: () => {\n                let dataSave = {\n                    cardId: data._id,\n                    newRel: selectCard,\n                    planId: db.cards[selectCard]._planId ? db.cards[selectCard]._planId : db.cards[selectCard].type === 'plan' ? selectCard : null,\n                    oldRel: data._parent\n                }\n                if (cardMoveTo(props, dataSave)) {\n                    setSelectCard(null)\n                    setTypeFilter({ name: 'plan' })\n                }\n            }\n        })\n    }\n\n    return (\n        <div className={classes.root}>\n            <div style={{ width: '100%', padding: '15px' }} ref={myRef}>\n                {selectCard && db.cards[selectCard] &&\n                    <React.Fragment>\n                        <Card db=\"cards\" data={db.cards[selectCard]} onlyOption />\n                        <fieldset style={{ maxWidth: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' }}>\n                            <legend>{translate('$__action')}</legend>\n                            {db.dataType.filter(a => a.name === data.type).length > 0\n                                && db.dataType.filter(a => a.name === data.type)[0].sharedIn\n                                && db.dataType.filter(a => a.name === data.type)[0].sharedIn.shared\n                                && db.dataType.filter(a => a.name === data.type)[0].sharedIn.shared.indexOf(db.cards[selectCard].type) > -1 &&\n                                <Button\n                                    style={{\n                                        position: 'relative',\n                                        float: 'left',\n                                        margin: '3px'\n                                    }}\n                                    onClick={() => shareThis()}\n                                >\n                                    {translate('$__share', '*')}\n                                </Button>\n                            }\n                        </fieldset>\n                        {db.dataType.filter(a => a.name === data.type).length > 0\n                            && db.dataType.filter(a => a.name === data.type)[0].sharedIn\n                            && db.dataType.filter(a => a.name === data.type)[0].sharedIn.attach\n                            && db.dataType.filter(a => a.name === data.type)[0].sharedIn.attach.indexOf(db.cards[selectCard].type) > -1 &&\n                            <fieldset style={{ maxWidth: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' }}>\n                                <legend>{translate('$__AttachInCard')}</legend>\n                                <Button\n                                    style={{\n                                        position: 'relative',\n                                        float: 'left',\n                                        margin: '3px'\n                                    }}\n                                    onClick={() => moveTo()}\n                                >\n                                    {translate('$__Attach', '*')}\n                                </Button>\n                            </fieldset>\n                        }\n                        <fieldset style={{ maxWidth: '100%', display: 'flex', justifyContent: 'center', alignItems: 'center' }}>\n                            <Button\n                                style={{ position: 'relative', float: 'left', margin: '3px' }}\n                                color={'red'}\n                                onClick={() => {\n                                    setSelectCard(null)\n                                }}\n                            >\n                                {translate('$__cancel', '*')}\n                            </Button>\n                        </fieldset>\n                    </React.Fragment>\n                }\n            </div>\n            <div style={{ padding: '15px' }}>\n                <AutoComplete\n                    dbNode={'typeFilter'}\n                    options={dataTypeOptions}\n                    getOptionLabel={(option) => translate(`$__${option.name}`, 1)}\n                    style={{ width: '100%' }}\n                    name=\"typeFilter\"\n                    disableClearable\n                    value={typeFilter}\n                    renderInput={(params) =>\n                        <TextField\n                            {...params}\n                            label={translate('$__cardType', 1)}\n                            variant={customApp('outlined')}\n\n                        />\n                    }\n                    onChange={\n                        (d, v) => {\n                            setTypeFilter(v)\n                        }\n                    }\n                />\n            </div>\n            <div style={{ padding: '15px' }}>\n                <TextField\n                    label={translate('$__search', 1)}\n                    variant={'outlined'}\n                    name=\"search\"\n                    InputLabelProps={{\n                        shrink: true,\n                    }}\n                    InputProps={{\n                        autoComplete: 'new-password',\n                        onChange: (d) => {\n                            setSearch(d.target.value)\n                            setPage(0)\n                        },\n                    }}\n                    value={search}\n                />\n            </div>\n            <div style={{ maxWidth: '100%' }}>\n                {Object.keys(cardsResults).length > 25 &&\n                    <div style={{ width: '100%', display: 'flex', justifyContent: 'center' }}>\n                        <Pagination\n                            count={Object.keys(cardsResults).length}\n                            size=\"small\"\n                            page={page} onChange={(e, newPage) => {\n                                setPage(newPage)\n                            }} />\n                    </div>\n                }\n                {Object.keys(cardsResults).filter(fil => {\n                    if (!selectCard)\n                        return true\n                    if (selectCard && (cardsResults[fil]._parent === selectCard || cardsResults[fil]._planId === selectCard))\n                        return true\n                }).map((card, i) => {\n                    if (i <= ((page + 1) * limit) && i >= page * limit)\n                        return (\n                            <Card db=\"cards\" key={i} data={cardsResults[card]} notGlobalExpanded onlyOption onClick={(a) => {\n                                setSelectCard(cardsResults[card]._id)\n                                setPage(0)\n                                myRef.current.scrollIntoView()\n                            }\n                            } />\n                        )\n                }\n                )}\n            </div>\n        </div>\n    );\n}\n\n//REACT\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));\n","//CORE\r\nimport React from \"react\";\r\nimport ReactExport from \"react-export-excel\";\r\nimport moment from \"moment-timezone\";\r\n\r\n//REDUX\r\nimport reduxStore from \"store/\";\r\n\r\n//@MATERIAL\r\nimport CustomButton from \"components/Buttons/custom\"\r\n\r\n\r\n//FUNCTIONS\r\nimport { translate, customApp } from \"functions/\";\r\n\r\nfunction Component(props) {\r\n    const ExcelFile = ReactExport.ExcelFile;\r\n    const ExcelSheet = ReactExport.ExcelFile.ExcelSheet;\r\n    const ExcelColumn = ReactExport.ExcelFile.ExcelColumn;\r\n    const data = props.data\r\n\r\n    let dataSet1 = []\r\n    let dataUsers = []\r\n\r\n    let total_time = 0\r\n    let total_hours = 0\r\n    let total_minutes = 0\r\n    let total_seconds = 0\r\n\r\n    if (data && Object.keys(data).length > 0) {\r\n        Object.keys(data).map(user => {\r\n            let userData = []\r\n            if (data[user]._times && Object.keys(data[user]._times > 0))\r\n                Object.keys(data[user]._times).map(tm => {\r\n                    let card = reduxStore.getState().db.cards[data[user]._times[tm].cardId]\r\n                    let time = parseInt(data[user]._times[tm].fin) - parseInt(data[user]._times[tm].ini)\r\n                    total_time = total_time + time\r\n                    let diff = time\r\n                    let diffText = ``\r\n                    let hours = 0\r\n                    let minutes = 0\r\n                    let seconds = 0\r\n                    if (time < 60) {\r\n                        diffText = `${diff} ${translate('$__seconds', 1)}`\r\n                    } else if (time > 3600) {\r\n                        hours = Math.trunc(diff / 3600)\r\n                        diff = diff - (hours * 3600)\r\n                        minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\r\n                        diff = diff - (minutes * 60)\r\n                        seconds = diff > 0 ? diff : 0\r\n                        diffText = `${hours} ${translate('$__hour', 1)}${hours > 1 ? 's' : ''} ${minutes} ${translate('$__minutes', 1)} ${seconds} ${translate('$__seconds', 1)}`\r\n                    } else {\r\n                        minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\r\n                        diff = diff - (minutes * 60)\r\n                        seconds = diff > 0 ? diff : 0\r\n                        diffText = `${minutes} ${translate('$__minutes', 1)} ${seconds} ${translate('$__seconds', 1)}`\r\n                    }\r\n\r\n                    dataSet1.push({\r\n                        name: data[user].name,\r\n                        // email: data[user].email,\r\n                        type: translate(`$__${card.type}`, 1),\r\n                        card: card.name,\r\n                        description: data[user]._times[tm].message,\r\n                        iniData: moment(data[user]._times[tm].ini * 1000).tz('America/Sao_Paulo').format('YYYY/MM/DD HH:mm:ss'),\r\n                        finalData: moment(data[user]._times[tm].fin * 1000).tz('America/Sao_Paulo').format('YYYY/MM/DD HH:mm:ss'),\r\n                        total: diffText,\r\n                        hours: hours,\r\n                        minutes: minutes,\r\n                        seconds: seconds,\r\n                        calc: (parseInt(data[user]._times[tm].fin) - parseInt(data[user]._times[tm].ini)) / 3600\r\n                    })\r\n                    userData.push({\r\n                        name: data[user].name,\r\n                        // email: data[user].email,\r\n                        type: translate(`$__${card.type}`, 1),\r\n                        card: card.name,\r\n                        description: data[user]._times[tm].message,\r\n                        iniData: moment(data[user]._times[tm].ini * 1000).tz('America/Sao_Paulo').format('YYYY/MM/DD HH:mm:ss'),\r\n                        finalData: moment(data[user]._times[tm].fin * 1000).tz('America/Sao_Paulo').format('YYYY/MM/DD HH:mm:ss'),\r\n                        total: diffText,\r\n                        hours: hours,\r\n                        minutes: minutes,\r\n                        seconds: seconds,\r\n                        calc: (parseInt(data[user]._times[tm].fin) - parseInt(data[user]._times[tm].ini)) / 3600\r\n                    })\r\n                })\r\n            console.log(data[user])\r\n            userData.push({\r\n                name: '',\r\n                email: '',\r\n                type: '',\r\n                card: '',\r\n                description: '',\r\n                iniData: '',\r\n                finalData: '',\r\n                total: data[user].timerText,\r\n                hours: '',\r\n                minutes: '',\r\n                seconds: '',\r\n                calc: parseInt(data[user].totalTimer) / 3600,\r\n            })\r\n            dataUsers = {\r\n                ...dataUsers,\r\n                [user]: userData\r\n            }\r\n\r\n        }\r\n        )\r\n        let total_diff = total_time\r\n        let total_diffText = ``\r\n        if (total_time < 60) {\r\n            total_seconds = total_diff\r\n            total_diffText = `${total_diff} ${translate('$__seconds', 1)}`\r\n        } else if (total_time > 3600) {\r\n            total_hours = Math.trunc(total_diff / 3600)\r\n            total_diff = total_diff - (total_hours * 3600)\r\n            total_minutes = Math.trunc(total_diff / 60) > 0 ? Math.trunc(total_diff / 60) : 0\r\n            total_diff = total_diff - (total_minutes * 60)\r\n            total_seconds = total_diff > 0 ? total_diff : 0\r\n            total_diffText = `${total_hours} ${translate('$__hour', 1)}${total_hours > 1 ? 's' : ''} ${total_minutes} ${translate('$__minutes', 1)} ${total_seconds} ${translate('$__seconds', 1)}`\r\n        } else {\r\n            total_minutes = Math.trunc(total_diff / 60) > 0 ? Math.trunc(total_diff / 60) : 0\r\n            total_diff = total_diff - (total_minutes * 60)\r\n            total_seconds = total_diff > 0 ? total_diff : 0\r\n            total_diffText = `${total_minutes} ${translate('$__minutes', 1)} ${total_seconds} ${translate('$__seconds', 1)}`\r\n        }\r\n\r\n        dataSet1.push({\r\n            name: '',\r\n            type: '',\r\n            card: '',\r\n            description: '',\r\n            iniData: '',\r\n            finalData: '',\r\n            total: total_diffText,\r\n            hours: '',\r\n            minutes: '',\r\n            seconds: '',\r\n            calc: ''\r\n        })\r\n    }\r\n\r\n\r\n\r\n    return (\r\n        <ExcelFile\r\n            filename={`${moment(new Date()).tz('America/Sao_Paulo').format('YYYY-MM-DDTHHMM')}_timeSheet`}\r\n            element={\r\n                <CustomButton\r\n                    title={translate(\"$__export\")}\r\n                    text={translate(\"$__export\")}\r\n                    icon={\"file_download\"}\r\n                    size={\"25px\"}\r\n                />\r\n            }\r\n        >\r\n            <ExcelSheet data={dataSet1} name=\"timeSheet\">\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__name', 1)}`} value=\"name\" />\r\n                {/* <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__email', 1)}`} value=\"email\" /> */}\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__type', 1)}`} value=\"type\" />\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__card', 1)}`} value=\"card\" />\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__description', 1)}`} value=\"description\" />\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__initialTimer', 1)}`} value=\"iniData\" />\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__finalTimer', 1)}`} value=\"finalData\" />\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__totalTime', 1)}`} value=\"total\" />\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__hours', 1)}`} value=\"hours\" />\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__minutes', 1)}`} value=\"minutes\" />\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__seconds', 1)}`} value=\"seconds\" />\r\n                <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__valueForCalculation', 1)}`} value=\"calc\" />\r\n            </ExcelSheet>\r\n            {dataUsers && Object.keys(dataUsers).length > 0 && Object.keys(dataUsers).map((ds, i) => {\r\n                let userName = dataUsers[ds][0].name\r\n                return (\r\n                    <ExcelSheet data={dataUsers[ds]} name={userName} key={ds}>\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__name', 1)}`} value=\"name\" />\r\n                        {/* <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__email', 1)}`} value=\"email\" /> */}\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__type', 1)}`} value=\"type\" />\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__card', 1)}`} value=\"card\" />\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__description', 1)}`} value=\"description\" />\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__initialTimer', 1)}`} value=\"iniData\" />\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__finalTimer', 1)}`} value=\"finalData\" />\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__totalTime', 1)}`} value=\"total\" />\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__hours', 1)}`} value=\"hours\" />\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__minutes', 1)}`} value=\"minutes\" />\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__seconds', 1)}`} value=\"seconds\" />\r\n                        <ExcelColumn style={{ alignment: { wrapText: true } }} label={`${translate('$__valueForCalculation', 1)}`} value=\"calc\" />\r\n                    </ExcelSheet>\r\n                )\r\n            })}\r\n            {/*  */}\r\n        </ExcelFile>\r\n    )\r\n}\r\nexport default Component","import {\r\n  primaryColor,\r\n  infoColor,\r\n  successColor,\r\n  dangerColor,\r\n  warningColor,\r\n  roseColor,\r\n  whiteColor,\r\n  blackColor,\r\n  grayColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst cardStyle = {\r\n  card: {\r\n    border: \"0\",\r\n    marginBottom: \"30px\",\r\n    marginTop: \"30px\",\r\n    borderRadius: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n    background: whiteColor,\r\n    width: \"100%\",\r\n    boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n    position: \"relative\",\r\n    display: \"flex\",\r\n    flexDirection: \"column\",\r\n    minWidth: \"0\",\r\n    wordWrap: \"break-word\",\r\n    fontSize: \".875rem\"\r\n  },\r\n  cardPlain: {\r\n    background: \"transparent\",\r\n    boxShadow: \"none\"\r\n  },\r\n  cardProfile: {\r\n    marginTop: \"30px\",\r\n    textAlign: \"center\"\r\n  },\r\n  cardBlog: {\r\n    marginTop: \"60px\"\r\n  },\r\n  cardRaised: {\r\n    boxShadow:\r\n      \"0 16px 38px -12px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.56), 0 4px 25px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.12), 0 8px 10px -5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.2)\"\r\n  },\r\n  cardBackground: {\r\n    backgroundPosition: \"center center\",\r\n    backgroundSize: \"cover\",\r\n    textAlign: \"center\",\r\n    \"&:after\": {\r\n      position: \"absolute\",\r\n      zIndex: \"1\",\r\n      width: \"100%\",\r\n      height: \"100%\",\r\n      display: \"block\",\r\n      left: \"0\",\r\n      top: \"0\",\r\n      content: '\"\"',\r\n      backgroundColor: \"rgba(\" + hexToRgb(blackColor) + \", 0.56)\",\r\n      borderRadius: \"6px\"\r\n    },\r\n    \"& small\": {\r\n      color: \"rgba(\" + hexToRgb(whiteColor) + \", 0.7) !important\"\r\n    }\r\n  },\r\n  cardPricing: {\r\n    textAlign: \"center\",\r\n    \"&:after\": {\r\n      backgroundColor: \"rgba(\" + hexToRgb(blackColor) + \", 0.7) !important\"\r\n    },\r\n    \"& ul\": {\r\n      listStyle: \"none\",\r\n      padding: 0,\r\n      maxWidth: \"240px\",\r\n      margin: \"10px auto\"\r\n    },\r\n    \"& ul li\": {\r\n      color: grayColor[0],\r\n      textAlign: \"center\",\r\n      padding: \"12px 0px\",\r\n      borderBottom: \"1px solid rgba(\" + hexToRgb(grayColor[0]) + \",0.3)\"\r\n    },\r\n    \"& ul li:last-child\": {\r\n      border: 0\r\n    },\r\n    \"& ul li b\": {\r\n      color: grayColor[2]\r\n    },\r\n    \"& h1\": {\r\n      marginTop: \"30px\"\r\n    },\r\n    \"& h1 small\": {\r\n      display: \"inline-flex\",\r\n      height: 0,\r\n      fontSize: \"18px\"\r\n    },\r\n    \"& h1 small:first-child\": {\r\n      position: \"relative\",\r\n      top: \"-16px\",\r\n      fontSize: \"26px\"\r\n    },\r\n    \"& ul li svg, & ul li .fab,& ul li .fas,& ul li .far,& ul li .fal,& ul li .material-icons\": {\r\n      position: \"relative\",\r\n      top: \"7px\"\r\n    }\r\n  },\r\n  cardPricingColor: {\r\n    \"& ul li\": {\r\n      color: whiteColor,\r\n      borderColor: \"rgba(\" + hexToRgb(whiteColor) + \",0.3)\",\r\n      \"& b, & svg,& .fab,& .fas,& .far,& .fal,& .material-icons\": {\r\n        color: whiteColor,\r\n        fontWeight: \"700\"\r\n      }\r\n    }\r\n  },\r\n  cardProduct: {\r\n    marginTop: \"30px\"\r\n  },\r\n  primary: {\r\n    background:\r\n      \"linear-gradient(60deg,\" + primaryColor[1] + \",\" + primaryColor[4] + \")\",\r\n    \"& h1 small\": {\r\n      color: \"rgba(\" + hexToRgb(whiteColor) + \", 0.8)\"\r\n    },\r\n    color: whiteColor\r\n  },\r\n  info: {\r\n    background:\r\n      \"linear-gradient(60deg,\" + infoColor[1] + \",\" + infoColor[4] + \")\",\r\n    \"& h1 small\": {\r\n      color: \"rgba(\" + hexToRgb(whiteColor) + \", 0.8)\"\r\n    },\r\n    color: whiteColor\r\n  },\r\n  success: {\r\n    background:\r\n      \"linear-gradient(60deg,\" + successColor[1] + \",\" + successColor[4] + \")\",\r\n    \"& h1 small\": {\r\n      color: \"rgba(\" + hexToRgb(whiteColor) + \", 0.8)\"\r\n    },\r\n    color: whiteColor\r\n  },\r\n  warning: {\r\n    background:\r\n      \"linear-gradient(60deg,\" + warningColor[1] + \",\" + warningColor[4] + \")\",\r\n    \"& h1 small\": {\r\n      color: \"rgba(\" + hexToRgb(whiteColor) + \", 0.8)\"\r\n    },\r\n    color: whiteColor\r\n  },\r\n  danger: {\r\n    background:\r\n      \"linear-gradient(60deg,\" + dangerColor[1] + \",\" + dangerColor[4] + \")\",\r\n    \"& h1 small\": {\r\n      color: \"rgba(\" + hexToRgb(whiteColor) + \", 0.8)\"\r\n    },\r\n    color: whiteColor\r\n  },\r\n  rose: {\r\n    background:\r\n      \"linear-gradient(60deg,\" + roseColor[1] + \",\" + roseColor[4] + \")\",\r\n    \"& h1 small\": {\r\n      color: \"rgba(\" + hexToRgb(whiteColor) + \", 0.8)\"\r\n    },\r\n    color: whiteColor\r\n  },\r\n  cardChart: {\r\n    \"& p\": {\r\n      marginTop: \"0px\",\r\n      paddingTop: \"0px\"\r\n    }\r\n  },\r\n  cardLogin: {\r\n    transform: \"translate3d(\" + hexToRgb(blackColor) + \")\",\r\n    transition: \"all 300ms linear\"\r\n  }\r\n};\r\n\r\nexport default cardStyle;\r\n","import React from \"react\";\nimport classNames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/cardStyle.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function Card(props) {\n  const classes = useStyles();\n  const {\n    className,\n    children,\n    plain,\n    profile,\n    blog,\n    raised,\n    background,\n    pricing,\n    color,\n    product,\n    testimonial,\n    chart,\n    login,\n    ...rest\n  } = props;\n  const cardClasses = classNames({\n    [classes.card]: true,\n    [classes.cardPlain]: plain,\n    [classes.cardProfile]: profile || testimonial,\n    [classes.cardBlog]: blog,\n    [classes.cardRaised]: raised,\n    [classes.cardBackground]: background,\n    [classes.cardPricingColor]:\n      (pricing && color !== undefined) || (pricing && background !== undefined),\n    [classes[color]]: color,\n    [classes.cardPricing]: pricing,\n    [classes.cardProduct]: product,\n    [classes.cardChart]: chart,\n    [classes.cardLogin]: login,\n    [className]: className !== undefined\n  });\n  return (\n    <div className={cardClasses} {...rest}>\n      {children}\n    </div>\n  );\n}\n\nCard.propTypes = {\n  className: PropTypes.string,\n  plain: PropTypes.bool,\n  profile: PropTypes.bool,\n  blog: PropTypes.bool,\n  raised: PropTypes.bool,\n  background: PropTypes.bool,\n  pricing: PropTypes.bool,\n  testimonial: PropTypes.bool,\n  color: PropTypes.oneOf([\n    \"primary\",\n    \"info\",\n    \"success\",\n    \"warning\",\n    \"danger\",\n    \"rose\"\n  ]),\n  product: PropTypes.bool,\n  chart: PropTypes.bool,\n  login: PropTypes.bool,\n  children: PropTypes.node\n};\n","import {\r\n  whiteColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst cardBodyStyle = {\r\n  cardBody: {\r\n    padding: \"0.9375rem 20px\",\r\n    flex: \"1 1 auto\",\r\n    WebkitBoxFlex: \"1\",\r\n    position: \"relative\"\r\n  },\r\n  cardBodyBackground: {\r\n    position: \"relative\",\r\n    zIndex: \"2\",\r\n    minHeight: \"280px\",\r\n    paddingTop: \"40px\",\r\n    paddingBottom: \"40px\",\r\n    maxWidth: \"440px\",\r\n    margin: \"0 auto\"\r\n  },\r\n  cardBodyPlain: {\r\n    paddingLeft: \"5px\",\r\n    paddingRight: \"5px\"\r\n  },\r\n  cardBodyFormHorizontal: {\r\n    paddingLeft: \"15px\",\r\n    paddingRight: \"15px\",\r\n    \"& form\": {\r\n      margin: \"0\"\r\n    }\r\n  },\r\n  cardPricing: {\r\n    padding: \"15px!important\",\r\n    margin: \"0px!important\"\r\n  },\r\n  cardSignup: {\r\n    padding: \"0px 30px 0px 30px\"\r\n  },\r\n  cardBodyColor: {\r\n    borderRadius: \"6px\",\r\n    \"& h1,& h2,& h3\": {\r\n      \"& small\": {\r\n        color: \"rgba(\" + hexToRgb(whiteColor) + \", 0.8)\"\r\n      }\r\n    }\r\n  },\r\n  cardBodyProfile: {\r\n    marginTop: \"15px\"\r\n  },\r\n  cardBodyCalendar: {\r\n    padding: \"0px !important\"\r\n  }\r\n};\r\n\r\nexport default cardBodyStyle;\r\n","import React from \"react\";\nimport classNames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//@MATERIAL\nimport styles from \"assets/jss/material-dashboard-pro-react/components/cardBodyStyle.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function CardBody(props) {\n  const classes = useStyles();\n  const {\n    className,\n    children,\n    background,\n    plain,\n    formHorizontal,\n    pricing,\n    signup,\n    color,\n    profile,\n    calendar,\n    ...rest\n  } = props;\n  const cardBodyClasses = classNames({\n    [classes.cardBody]: true,\n    [classes.cardBodyBackground]: background,\n    [classes.cardBodyPlain]: plain,\n    [classes.cardBodyFormHorizontal]: formHorizontal,\n    [classes.cardPricing]: pricing,\n    [classes.cardSignup]: signup,\n    [classes.cardBodyColor]: color,\n    [classes.cardBodyProfile]: profile,\n    [classes.cardBodyCalendar]: calendar,\n    [className]: className !== undefined\n  });\n  return (\n    <div className={cardBodyClasses} {...rest}>\n      {children}\n    </div>\n  );\n}\n\nCardBody.propTypes = {\n  className: PropTypes.string,\n  background: PropTypes.bool,\n  plain: PropTypes.bool,\n  formHorizontal: PropTypes.bool,\n  pricing: PropTypes.bool,\n  signup: PropTypes.bool,\n  color: PropTypes.bool,\n  profile: PropTypes.bool,\n  calendar: PropTypes.bool,\n  children: PropTypes.node\n};\n","import {\r\n  warningCardHeader,\r\n  successCardHeader,\r\n  dangerCardHeader,\r\n  infoCardHeader,\r\n  primaryCardHeader,\r\n  roseCardHeader,\r\n  customCardHeader,\r\n  whiteColor,\r\n  blackColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\nconst cardHeaderStyle = {\r\n  cardHeader: {\r\n    padding: \"0.75rem 1.25rem\",\r\n    marginBottom: \"0\",\r\n    borderBottom: \"none\",\r\n    background: \"transparent\",\r\n    zIndex: \"3 !important\",\r\n    \"&$cardHeaderPlain,&$cardHeaderImage,&$cardHeaderContact,&$cardHeaderSignup,&$cardHeaderIcon,&$cardHeaderStats,&$warningCardHeader,&$successCardHeader,&$dangerCardHeader,&$infoCardHeader,&$primaryCardHeader,&$roseCardHeader, &$customCardHeader\": {\r\n      margin: \"0 15px\",\r\n      padding: \"0\",\r\n      position: \"relative\",\r\n      color: whiteColor\r\n    },\r\n    \"&:first-child\": {\r\n      borderRadius: \"calc(.25rem - 1px) calc(.25rem - 1px) 0 0\"\r\n    },\r\n    \"&$warningCardHeader,&$successCardHeader,&$dangerCardHeader,&$infoCardHeader,&$primaryCardHeader,&$roseCardHeader,&$customCardHeader\": {\r\n      \"&:not($cardHeaderIcon):not($cardHeaderImage):not($cardHeaderText)\": {\r\n        borderRadius: \"3px\",\r\n        marginTop: \"-20px\",\r\n        padding: \"15px\"\r\n      }\r\n    },\r\n    \"&$cardHeaderStats svg\": {\r\n      fontSize: \"36px\",\r\n      lineHeight: \"56px\",\r\n      textAlign: \"center\",\r\n      width: \"36px\",\r\n      height: \"36px\",\r\n      margin: \"10px 10px 4px\"\r\n    },\r\n    \"&$cardHeaderStats .fab,&$cardHeaderStats .fas,&$cardHeaderStats .far,&$cardHeaderStats .fal,&$cardHeaderStats .material-icons\": {\r\n      fontSize: \"36px\",\r\n      lineHeight: \"56px\",\r\n      width: \"56px\",\r\n      height: \"56px\",\r\n      textAlign: \"center\",\r\n      overflow: \"unset\",\r\n      marginBottom: \"1px\"\r\n    },\r\n    \"&$cardHeaderStats$cardHeaderIcon\": {\r\n      textAlign: \"right\"\r\n    },\r\n    \"&$cardHeaderImage\": {\r\n      marginLeft: \"15px\",\r\n      marginRight: \"15px\",\r\n      marginTop: \"-30px\",\r\n      borderRadius: \"6px\"\r\n    },\r\n    \"&$cardHeaderText\": {\r\n      display: \"inline-block\"\r\n    }\r\n  },\r\n  cardHeaderPlain: {\r\n    marginLeft: \"0px\",\r\n    marginRight: \"0px\",\r\n    \"&$cardHeaderImage\": {\r\n      margin: \"0 !important\"\r\n    }\r\n  },\r\n  cardHeaderImage: {\r\n    position: \"relative\",\r\n    padding: \"0\",\r\n    zIndex: \"1\",\r\n    \"& img\": {\r\n      width: \"100%\",\r\n      borderRadius: \"6px\",\r\n      pointerEvents: \"none\",\r\n      boxShadow:\r\n        \"0 5px 15px -8px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.24), 0 8px 10px -5px rgba(\" +\r\n        hexToRgb(blackColor) +\r\n        \", 0.2)\"\r\n    },\r\n    \"& a\": {\r\n      display: \"block\"\r\n    }\r\n  },\r\n  cardHeaderContact: {\r\n    margin: \"0 15px\",\r\n    marginTop: \"-20px\"\r\n  },\r\n  cardHeaderSignup: {\r\n    marginLeft: \"20px\",\r\n    marginRight: \"20px\",\r\n    marginTop: \"-40px\",\r\n    padding: \"20px 0\",\r\n    width: \"100%\",\r\n    marginBottom: \"15px\"\r\n  },\r\n  cardHeaderStats: {\r\n    \"& $cardHeaderIcon\": {\r\n      textAlign: \"right\"\r\n    },\r\n    \"& h1,& h2,& h3,& h4,& h5,& h6\": {\r\n      margin: \"0 !important\"\r\n    }\r\n  },\r\n  cardHeaderIcon: {\r\n    \"&$warningCardHeader,&$successCardHeader,&$dangerCardHeader,&$infoCardHeader,&$primaryCardHeader,&$roseCardHeader,&$customCardHeader\": {\r\n      background: \"transparent\",\r\n      boxShadow: \"none\"\r\n    },\r\n    \"& .fab,& .fas,& .far,& .fal,& .material-icons\": {\r\n      width: \"33px\",\r\n      height: \"33px\",\r\n      textAlign: \"center\",\r\n      lineHeight: \"33px\"\r\n    },\r\n    \"& svg\": {\r\n      width: \"24px\",\r\n      height: \"24px\",\r\n      textAlign: \"center\",\r\n      lineHeight: \"33px\",\r\n      margin: \"5px 4px 0px\"\r\n    }\r\n  },\r\n  cardHeaderText: {},\r\n  warningCardHeader: {\r\n    color: whiteColor,\r\n    \"&:not($cardHeaderText):not($cardHeaderIcon)\": {\r\n      ...warningCardHeader\r\n    }\r\n  },\r\n  successCardHeader: {\r\n    color: whiteColor,\r\n    \"&:not($cardHeaderText):not($cardHeaderIcon)\": {\r\n      ...successCardHeader\r\n    }\r\n  },\r\n  dangerCardHeader: {\r\n    color: whiteColor,\r\n    \"&:not($cardHeaderText):not($cardHeaderIcon)\": {\r\n      ...dangerCardHeader\r\n    }\r\n  },\r\n  infoCardHeader: {\r\n    color: whiteColor,\r\n    \"&:not($cardHeaderText):not($cardHeaderIcon)\": {\r\n      ...infoCardHeader\r\n    }\r\n  },\r\n  primaryCardHeader: {\r\n    color: whiteColor,\r\n    \"&:not($cardHeaderText):not($cardHeaderIcon)\": {\r\n      ...primaryCardHeader\r\n    }\r\n  },\r\n  roseCardHeader: {\r\n    color: whiteColor,\r\n    \"&:not($cardHeaderText):not($cardHeaderIcon)\": {\r\n      ...roseCardHeader\r\n    }\r\n  },\r\n  customCardHeader: {\r\n    color: whiteColor,\r\n    \"&:not($cardHeaderText):not($cardHeaderIcon)\": {\r\n      ...customCardHeader\r\n    }\r\n  }\r\n};\r\n\r\nexport default cardHeaderStyle;\r\n","import React from \"react\";\nimport classNames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\n//MATERIALS\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/cardHeaderStyle.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function CardHeader(props) {\n  const classes = useStyles();\n  const {\n    className,\n    children,\n    color,\n    plain,\n    image,\n    contact,\n    signup,\n    stats,\n    icon,\n    text,\n    ...rest\n  } = props;\n  const cardHeaderClasses = classNames({\n    [classes.cardHeader]: true,\n    [classes[color + \"CardHeader\"]]: color,\n    [classes.cardHeaderPlain]: plain,\n    [classes.cardHeaderImage]: image,\n    [classes.cardHeaderContact]: contact,\n    [classes.cardHeaderSignup]: signup,\n    [classes.cardHeaderStats]: stats,\n    [classes.cardHeaderIcon]: icon,\n    [classes.cardHeaderText]: text,\n    [className]: className !== undefined\n  });\n  return (\n    <div className={cardHeaderClasses} {...rest}>\n      {children}\n    </div>\n  );\n}\n\nCardHeader.propTypes = {\n  className: PropTypes.string,\n  color: PropTypes.oneOf([\n    \"warning\",\n    \"success\",\n    \"danger\",\n    \"info\",\n    \"primary\",\n    \"rose\",\n    \"custom\"\n  ]),\n  plain: PropTypes.bool,\n  image: PropTypes.bool,\n  contact: PropTypes.bool,\n  signup: PropTypes.bool,\n  stats: PropTypes.bool,\n  icon: PropTypes.bool,\n  text: PropTypes.bool,\n  children: PropTypes.node\n};\n","import React from \"react\";\nimport moment from \"moment-timezone\";\nimport { ResponsivePie } from \"@nivo/pie\";\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Checkbox from \"components/Checkbox\"\nimport CustomButton from \"components/Buttons/custom\"\nimport ExportTimer from \"components/Timer/exportAll\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport Icon from \"components/Icon\"\nimport TextField from \"components/TextField\"\nimport UiCard from \"components/Card/Card\"\nimport UiCardBody from \"components/Card/CardBody\"\nimport UiCardHeader from \"components/Card/CardHeader\"\nimport PreLoader from \"components/PreLoader\"\n\n//@MATERIAL\nimport Accordion from \"@material-ui/core/Accordion\"\nimport AccordionDetails from \"@material-ui/core/AccordionDetails\"\nimport AccordionSummary from \"@material-ui/core/AccordionSummary\"\nimport Avatar from \"@material-ui/core/Avatar\"\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\"\nimport FormControlLabel from \"@material-ui/core/FormControlLabel\"\nimport FormGroup from \"@material-ui/core/FormGroup\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\nimport { makeStyles } from \"@material-ui/core/styles\"\n\nimport { translate, customApp } from \"functions\"\n\nimport { loadTimeline } from \"functions/chat\"\n\nimport { getChildrens } from \"functions/cards\"\n\nconst useStyles = makeStyles((props) => ({\n    iconButtonStyleTransaparent: {\n        margin: 0,\n        \"&:hover\": {\n            backgroundColor: \"rgba(250,250,250,0.9)\"\n        }\n    },\n    iconButtonStyleWhite: {\n        margin: 0,\n        backgroundColor: \"#FFFFFF\",\n        \"&:hover\": {\n            backgroundColor: \"rgba(250,250,250,0.9)\"\n        }\n    },\n}))\n\n\nfunction Timesheet(props) {\n    const { db, timeline } = reduxStore.getState()\n    const [startDate, setStartDate] = React.useState(moment(new Date()).tz(\"America/Sao_Paulo\").subtract(720, \"d\").format(\"YYYY-MM-DD\"))\n    const [endDate, setEndDate] = React.useState(moment(new Date()).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\"))\n    const [exportTimers, setExport] = React.useState(false)\n    const [selectedUsers, setSelectedUsers] = React.useState({})\n    const [cards, setCards] = React.useState({})\n    const [loading, setLoading] = React.useState(true)\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace('#', '')\n\n    React.useEffect(() => {\n        init()\n        return () => {\n\n        }\n    }, [])\n\n    React.useEffect(() => {\n        iniCards()\n    }, [props.cards])\n\n    const iniCards = async () => {\n        let ncards = await getChildrens(props.nodeId)\n\n        setCards(ncards)\n    }\n\n    const init = async () => {\n        try {\n            let lt = await loadTimeline(\n                {\n                    ...props,\n                    fnIdentification: \"StrategyAndPlans/Dashboard/Widgers/timeSheet/init()\"\n                },\n                {\n                    ids: [props.nodeId],\n                    db: \"cards\",\n                    type: \"timer\",\n                    reqChildrens: true\n                })\n            if (lt) {\n                setLoading(false)\n            }\n        } catch (e) {\n            console.log(e)\n            setLoading(false)\n        }\n    }\n\n    let timeSheet = {}\n    let users = {}\n    let timeSheetTotal = 0\n    let totalSeconds = 0\n\n    const convertSecondsToText = (diff, mini = false) => {\n        let diffText = ``\n        let diffTextMini = ``\n        if (diff < 60) {\n            diffText = `${diff} ${translate(\"$__seconds\", 1)}`\n            diffText = `${diff}s`\n        } else if (diff > 3600) {\n            let hours = Math.trunc(diff / 3600)\n            diff = diff - (hours * 3600)\n            let minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\n            diff = diff - (minutes * 60)\n            let seconds = diff > 0 ? diff : 0\n            diffText = `${hours} ${translate(\"$__hour\", 1)}${hours > 1 ? \"s\" : \"\"} ${minutes} ${translate(\"$__minutes\", 1)} ${seconds > 0 ? `${seconds} ${translate(\"$__seconds\", 1)}` : ``}`\n            diffTextMini = `${hours}H ${minutes}M ${seconds} S`\n        } else {\n            let minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\n            diff = diff - (minutes * 60)\n            let seconds = diff > 0 ? diff : 0\n            diffText = `${minutes} ${translate(\"$__minutes\", 1)} ${seconds > 0 ? `${seconds} ${translate(\"$__seconds\", 1)}` : ``}`\n            diffTextMini = `${minutes}M ${seconds} S`\n        }\n        if (mini) return diffTextMini\n        return diffText\n    }\n\n\n    Object.keys(cards).filter(a =>\n        timeline[a]\n        && (\n            Object.keys(timeline[a]).filter(tm => timeline[a][tm].type === \"timer\").length > 0\n        )\n    ).map(a => {\n        Object.keys(timeline[a]).filter(tm =>\n            timeline[a][tm].type === \"timer\"\n            && !timeline[a][tm].deleted\n        ).map(ts => {\n\n            if (timeline[a][ts]._toUser && Object.keys(timeline[a][ts]._toUser).length > 0) {\n                Object.keys(timeline[a][ts]._toUser).map(userId => {\n                    users = {\n                        ...users,\n                        [userId]: {\n                            ...timeline[a][ts]._toUser[userId] ? timeline[a][ts]._toUser[userId] : {},\n                        }\n                    }\n                })\n            } else {\n                users = {\n                    ...users,\n                    [timeline[a][ts].user._id]: {\n                        ...timeline[a][ts].user,\n                    }\n                }\n            }\n\n        })\n        Object.keys(timeline[a]).filter(tm =>\n            timeline[a]\n            && timeline[a][tm]\n            && timeline[a][tm].type === \"timer\"\n            && !timeline[a][tm].deleted\n            &&\n            (\n                Object.keys(selectedUsers).length === 0\n                ||\n                (\n                    Object.keys(selectedUsers).length > 0\n                    && Object.keys(selectedUsers).filter(su =>\n                        timeline[a]\n                        && timeline[a][tm]\n                        && timeline[a][tm].type\n                        && timeline[a][tm].type === \"timer\"\n                        && selectedUsers[su]\n                        && timeline[a][tm].user\n                        &&\n                        (\n                            (\n                                timeline[a]\n                                && timeline[a][tm]\n                                && timeline[a][tm].user\n                                && (\n                                    !timeline[a][tm]._toUser\n                                    || (\n                                        timeline[a][tm]._toUser\n                                        && !timeline[a][tm]._toUser[su]\n                                    )\n                                )\n                                && timeline[a][tm].user._id === su\n                            )\n                            ||\n                            (\n                                timeline[a]\n                                && timeline[a][tm]\n                                && timeline[a][tm]._toUser\n                                && timeline[a][tm]._toUser[su]\n                                && timeline[a][tm]._toUser[su] !== timeline[a][tm].user._id\n                            )\n                        )\n                    ).length > 0\n                )\n            )\n        ).map(ts => {\n            if (timeline[a][ts].message.indexOf(\"Primeira Entrevistas\") > -1)\n                console.log(timeline[a][ts]._toUser)\n            Object.keys(users).map(userId => {\n                if (\n                    userId\n                    && timeline[a]\n                    && timeline[a][ts]\n                    && timeline[a][ts].type === \"timer\"\n                    && !timeline[a][ts].deleted\n                    && (\n                        parseInt(timeline[a][ts].ini) >= moment(`${startDate} 00:00:01`).unix(\"X\")\n                        || parseInt(timeline[a][ts].ini) === 0\n                    )\n                    &&\n                    (\n                        parseInt(timeline[a][ts].fin) <= moment(`${endDate} 23:59:59`).unix(\"X\")\n                    )\n                    && (\n                        (\n                            timeline[a][ts].user\n                            && (\n                                timeline[a][ts].user._id === userId\n                                && (\n                                    timeline[a][ts]._toUser\n                                    && Object.keys(timeline[a][ts]._toUser).length === 0\n                                )\n                            )\n                        )\n                        || (\n                            timeline[a][ts]._toUser\n                            && Object.keys(timeline[a][ts]._toUser).length > 0\n                            && timeline[a][ts]._toUser[userId]\n                        )\n                    )\n                    // && (\n                    //     !timeline[a][ts]._toUser\n                    //     || timeline[a][ts]._toUser && Object.keys(timeline[a][ts]._toUser).length === 0\n                    //     || (\n                    //         timeline[a][ts]._toUser\n                    //         && timeline[a][ts]._toUser[userId]\n                    //     )\n                    // )\n                ) {\n                    totalSeconds = totalSeconds + (parseInt(timeline[a][ts].fin) - parseInt(timeline[a][ts].ini))\n                    let time = (parseInt(timeline[a][ts].fin) - parseInt(timeline[a][ts].ini))\n\n                    if (timeSheet && timeSheet[userId] && timeSheet[userId].totalTimer) {\n                        time = parseInt(timeSheet[userId].totalTimer) + (parseInt(timeline[a][ts].fin) - parseInt(timeline[a][ts].ini))\n                    } else {\n                        time = parseInt(timeline[a][ts].fin) - parseInt(timeline[a][ts].ini)\n                    }\n\n                    let diff = time\n                    let diffText = ``\n                    let diffTextMini = ``\n                    if (time < 60) {\n                        diffText = `${diff} ${translate(\"$__seconds\", 1)}`\n                        diffText = `${diff}s`\n                    } else if (time > 3600) {\n                        let hours = Math.trunc(diff / 3600)\n                        diff = diff - (hours * 3600)\n                        let minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\n                        diff = diff - (minutes * 60)\n                        let seconds = diff > 0 ? diff : 0\n                        diffText = `${hours} ${translate(\"$__hour\", 1)}${hours > 1 ? \"s\" : \"\"} ${minutes} ${translate(\"$__minutes\", 1)} ${seconds > 0 ? `${seconds} ${translate(\"$__seconds\", 1)}` : ``}`\n                        diffTextMini = `${hours}H ${minutes}M ${seconds} S`\n                    } else {\n                        let minutes = Math.trunc(diff / 60) > 0 ? Math.trunc(diff / 60) : 0\n                        diff = diff - (minutes * 60)\n                        let seconds = diff > 0 ? diff : 0\n                        diffText = `${minutes} ${translate(\"$__minutes\", 1)} ${seconds > 0 ? `${seconds} ${translate(\"$__seconds\", 1)}` : ``}`\n                        diffTextMini = `${minutes}M ${seconds} S`\n                    }\n\n                    timeSheet = {\n                        ...timeSheet,\n                        [userId]: {\n                            ...timeSheet[userId] ? timeSheet[userId] : {},\n                            ...users[userId] ? users[userId] : {},\n                            ...timeSheet && timeSheet[userId] && timeSheet[userId].totalTimer ?\n                                { totalTimer: parseInt(timeSheet[userId].totalTimer) + (parseInt(timeline[a][ts].fin) - parseInt(timeline[a][ts].ini)) }\n                                : { totalTimer: parseInt(timeline[a][ts].fin) - parseInt(timeline[a][ts].ini) },\n                            timerText: diffText,\n                            timerTextMini: diffTextMini,\n                            _times: {\n                                ...timeSheet[userId] && timeSheet[userId]._times ? timeSheet[userId]._times : {},\n                                [ts]: {\n                                    ...timeline[a][ts],\n                                    cardId: a\n                                }\n                            }\n                        }\n                        // }\n                    }\n                }\n                timeSheetTotal = timeSheetTotal + 1\n            })\n        })\n    })\n\n\n    const TimeSheetData = (props) => {\n        return (\n            <div style={{ width: \"100%\", marginBottom: \"10px\", display: \"flex\", alignItems: \"center\" }}>\n                {props.data && props.data.name &&\n                    <React.Fragment>\n                        <div\n                            style={{ width: \"33px\" }}\n                        >\n                            <Tooltip\n                                title={props.data.name}\n                            >\n                                <Avatar alt={props.data.name} src={props.data.image || null} style={{ width: \"33px\", height: \"33px\" }}>\n                                    {props.data.name.substr(0, 1)}\n                                </Avatar>\n                            </Tooltip>\n                        </div>\n                        <div style={{ marginLeft: \"10px\", fontWeight: \"bold\", color: customApp(\"menu\"), width: \"33%\", minWidth: \"150px\" }}>{props.data.name}</div>\n                    </React.Fragment>\n                }\n                <div style={{ marginLeft: \"10px\", fontWeight: \"bold\", color: customApp(\"menu\") }}>{props.data.timerText}</div>\n            </div>\n        )\n    }\n\n    const selectUser = (pr) => {\n        if (selectedUsers[pr] && Object.keys(selectedUsers).filter(a => selectedUsers[a]).length <= 1) {\n            setSelectedUsers({})\n        } else {\n            setSelectedUsers({\n                ...selectedUsers,\n                [pr]: !selectedUsers[pr],\n            })\n        }\n    }\n\n    return (\n        <UiCard>\n            <HeaderWithIcon\n                title={translate(`$__timeSheet`, 1)}\n                icon={\"update\"}\n                color={customApp(\"colorText\")}\n                style={{\n                    background: customApp(\"ColumnTitleColor\"),\n                    padding: \"7px\"\n                }}\n                customButtons={[\n                    !exportTimers &&\n                    {\n                        title: \"$__timeSheetExport\",\n                        icon: \"file_download\",\n                        color: customApp(\"colorText\"),\n                        onClick: () => {\n                            setExport(!exportTimers)\n                        },\n                    },\n                ]}\n            />\n            {loading ?\n                <div\n                    style={{\n                        position: \"absolute\",\n                        top: 0,\n                        left: 0,\n                        right: 0,\n                        bottom: 0,\n                        backgroundColor: \"rgba(250,250,250,0.7)\",\n                        display: \"flex\",\n                        justifyContent: \"center\",\n                        alignItems: \"center\",\n                        zIndex: 10\n                    }}\n                >\n                    <PreLoader />\n                </div>\n                : <React.Fragment></React.Fragment>\n            }\n            {exportTimers &&\n                <div style={{ padding: \"15px\" }}>\n                    <fieldset style={{ position: \"relative\", width: \"100%\", marginLeft: \"7px\", display: \"flex\", justifyContent: \"space-between\", marginBottom: \"14px\", marginTop: \"7px\" }}>\n                        <legend>{translate(\"$__timeCourse\", 1)}</legend>\n                        <TextField\n                            label={translate(\"$__initialDate\", 1)}\n                            variant={customApp(\"fieldVariant\", 1)}\n                            name=\"startDate\"\n                            style={{ marginRight: \"15px\" }}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            type=\"date\"\n                            inputProps={{\n                                max: endDate ? endDate : null,\n                            }}\n                            InputProps={{\n                                autoComplete: \"new-password\",\n                                onChange: (d) => {\n                                    setStartDate(d.target.value)\n                                },\n                            }}\n                            value={startDate}\n                        />\n                        <TextField\n                            label={translate(\"$__endDate\", 1)}\n                            variant={customApp(\"fieldVariant\")}\n                            name=\"endDate\"\n                            type=\"date\"\n                            min={startDate ? startDate : null}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            inputProps={{\n                                min: startDate ? startDate : null,\n                            }}\n                            InputProps={{\n                                autoComplete: \"new-password\",\n                                onChange: (d) => {\n                                    setEndDate(d.target.value)\n                                },\n                            }}\n                            value={endDate}\n                        />\n\n                    </fieldset>\n                    {/* FILTER BY USER */}\n                    {db.users && Object.keys(db.users).length > 0 &&\n                        <Accordion style={{ width: \"100%\" }}>\n                            <AccordionSummary\n                                style={{ minWidth: \"100%\" }}\n                                expandIcon={\n                                    <Icon>expand_more</Icon>\n                                }\n                                aria-controls=\"panel1a-content\"\n                                id=\"panel1a-header\"\n                            ><div style={{ color: customApp(\"color\"), fontSize: \"12px\" }}>\n                                    {translate(\"$__users\")}\n                                    <AvatarGroup max={6}>\n                                        {Object.keys(selectedUsers).length > 0 && Object.keys(selectedUsers).map((a, i) => (\n                                            <Tooltip\n                                                title={db.users[a].name}\n                                                key={i}\n                                            >\n                                                <Avatar alt={db.users[a].name} src={db.users[a].image || null} >\n                                                    {db.users[a].name.substr(0, 1)}\n                                                </Avatar>\n                                            </Tooltip>\n                                        ))}\n                                    </AvatarGroup>\n                                </div>\n                            </AccordionSummary>\n                            <AccordionDetails\n                                style={{ minWidth: \"100%\" }}\n                            >\n                                <FormGroup>\n                                    {Object.keys(users).map(pr => {\n                                        return (\n                                            db.users && db.users[pr] && db.users[pr]._id &&\n                                            <React.Fragment key={pr}>\n                                                <FormControlLabel\n                                                    key={pr}\n                                                    style={{ minWidth: \"100%\" }}\n                                                    control={\n                                                        <React.Fragment>\n                                                            <Avatar alt={db.users[pr].name.substr(0, 1)} src={db.users[pr].image || null} >\n                                                                {db.users[pr].name.substr(0, 1)}\n                                                            </Avatar>\n                                                            <Checkbox\n                                                                checked={selectedUsers && selectedUsers[pr] ? true : false}\n                                                                onChange={() => {\n                                                                    selectUser(pr)\n                                                                }}\n                                                                color=\"default\"\n                                                            />\n                                                        </React.Fragment>\n                                                    }\n                                                    label={db.users[pr].name || db.users[pr].name}\n                                                />\n                                            </React.Fragment>\n                                        )\n                                    }\n                                    )}\n                                </FormGroup>\n                            </AccordionDetails>\n                        </Accordion>\n                    }\n                    <div style={{ display: \"flex\", justifyContent: \"center\", marginTop: \"7px\" }}>\n                        <ExportTimer data={timeSheet} />\n                        <CustomButton\n                            title={translate(\"$__closeFilter\")}\n                            text={translate(\"$__closeFilter\")}\n                            color={\"lightgrey\"}\n                            textColor={\"lightgrey\"}\n                            icon={\"cancel\"}\n                            onClick={() => { setExport(!exportTimers) }}\n                            size={\"25px\"}\n                        />\n                    </div>\n                </div>\n            }\n            <UiCardHeader style={{ height: \"333px\" }}>\n                <ResponsivePie\n                    data={[\n                        ...Object.keys(timeSheet).sort((a, b) => {\n                            if (parseInt(timeSheet[a].totalTimer) > parseInt(timeSheet[b].totalTimer)) {\n                                return -1\n                            } else if (parseInt(timeSheet[a].totalTimer) < parseInt(timeSheet[b].totalTimer)) {\n                                return 1\n                            } else {\n                                return 0\n                            }\n                        }).map((ts, i) => {\n                            return {\n                                id: timeSheet[ts].name,\n                                label: timeSheet[ts].name,\n                                value: timeSheet[ts].totalTimer,\n                                color: \"#929497\",\n                                textMini: timeSheet[ts].timerText,\n                            }\n                        }\n                        )\n                    ]}\n                    // legends={[\n                    //     {\n                    //         anchor: \"right\",\n                    //         direction: \"column\",\n                    //         justify: false,\n                    //         translateX: -20,\n                    //         translateY: -100,\n                    //         itemsSpacing: 0,\n                    //         itemWidth: 100,\n                    //         itemHeight: 18,\n                    //         itemTextColor: \"#999\",\n                    //         itemDirection: \"left-to-right\",\n                    //         itemOpacity: 1,\n                    //         symbolSize: 18,\n                    //         symbolShape: \"circle\",\n                    //         effects: [\n                    //             {\n                    //                 on: \"hover\",\n                    //                 style: {\n                    //                     itemTextColor: \"#000\"\n                    //                 }\n                    //             }\n                    //         ]\n                    //     }\n                    // ]}\n                    valueFormat={value => {\n                        convertSecondsToText(value, true)\n                        return convertSecondsToText(value)\n                    }}\n                    enableArcLabels={false}\n                    colors={{ scheme: \"purpleRed_green\" }}\n                    activeOuterRadiusOffset={8}\n                    arcLabelsTextColor={{ from: \"color\", modifiers: [[\"brighter\", 3]] }}\n                    borderWidth={1}\n                    cornerRadius={3}\n                    enableArcLinkLabels={true}\n                    innerRadius={0.5}\n                    leavesOnly={true}\n                    margin={{ top: 10, right: 80, bottom: 10, left: 0 }}\n                    padAngle={1.3}\n                    sortByValue={true}\n                />\n            </UiCardHeader>\n            <UiCardBody>\n                <GridContainer>\n                    {Object.keys(timeSheet).sort((a, b) => {\n                        if (parseInt(timeSheet[a].totalTimer) > parseInt(timeSheet[b].totalTimer)) {\n                            return -1\n                        } else if (parseInt(timeSheet[a].totalTimer) < parseInt(timeSheet[b].totalTimer)) {\n                            return 1\n                        } else {\n                            return 0\n                        }\n                    }).map((ts, i) =>\n                        <TimeSheetData data={timeSheet[ts]} key={ts} />\n                    )}\n                </GridContainer>\n            </UiCardBody>\n            <div style={{\n                color: \"#CCCCCC\",\n                fontSize: \"12px\",\n                padding: \"15px\",\n                textAlign: \"center\"\n            }}>\n                {db.cards[props.nodeId] && db.cards[props.nodeId].type === 'plan' ?\n                    translate(\"$__timeSheetShowingAllTimesRegisteredInAllActivitiesOfPlan\")\n                    :\n                    translate(\"$__timeSheetShowingAllTimesRegisteredInActivityAndLinkedActivities\")\n                }\n            </div>\n        </UiCard>\n    );\n}\nconst mapStateToProps = (store) => ({\n    cards: store.db.cards,\n    timeline: store.timeline\n}\n)\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(Timesheet);","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst headerStyle = theme => ({\r\n    btClose: {\r\n        position: 'relative',\r\n        zIndex: theme.zIndex.drawer + 1,\r\n        right: '0',\r\n        top: '-64px',\r\n        backgroundColor: '#FFFFFF',\r\n        display: 'flex',\r\n    },\r\n    data: {\r\n        marginTop: '10px',\r\n        padding: '10px',\r\n        '& fieldset': {\r\n            border: 'solid 1px rgba(0,0,0,0.1)',\r\n            '& legend': {\r\n                marginBottom: '0px',\r\n                fontSize: '16px',\r\n                color: customApp('color')\r\n            }\r\n        }\r\n    },\r\n    timeline: {\r\n        position: 'absolute',\r\n        width: '100%',\r\n        // top: '70px',\r\n        bottom: '0px',\r\n    },\r\n    avatar: {\r\n        width: '22px',\r\n        height: '22px'\r\n    },\r\n    switch: {\r\n        fontSize: '16px',\r\n        fontWeight: 'bold',\r\n        color: customApp('medium')\r\n    }\r\n});\r\n\r\nexport default headerStyle;\r\n","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Timeline from \"components/Timeline\"\nimport KPITimer from \"./timer\"\nimport Timesheet from \"components/Timer/chart\"\nimport CustomButton from \"components/Buttons/custom\"\n\n//@MATERIAL\n\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/timerLog\"\n\n//FUNCTIONS\nimport {\n    translate,\n    getAppAccess\n} from \"functions/\"\n\n\nfunction Component(props) {\n    const { classes } = props;\n    const { db, sideModule, session } = reduxStore.getState()\n    const data = sideModule.data || {}\n    const [addTimer, setAddTimer] = React.useState(false)\n    const [view, setView] = React.useState(!reduxStore.getState().db.cards[data._id]._users[session._id] ? \"chart\" : \"timeline\")\n\n    let AppAccess = getAppAccess()\n    let CardAccess = 0\n\n    if (session._id\n        && db.cards[data._id]\n        && db.cards[data._id]._users\n        && db.cards[data._id]._users[Object.keys(db.cards[data._id]._users).find(a => a.indexOf(session._id) > -1)])\n        CardAccess = db.cards[data._id]._users[Object.keys(db.cards[data._id]._users).find(a => a.indexOf(session._id) > -1)]\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    let kpi_flow = db.cards[data._id]._timeline || {}\n    kpi_flow = Object.keys(kpi_flow).filter(a => kpi_flow[a].type === \"kpi\").map(a => kpi_flow[a])\n\n    let parentData = null\n    if (data._parent && data._parent !== hashs[0]) {\n        parentData = reduxStore.getState().db.cards[data._parent]\n    }\n\n    return (\n        <div>\n            {!addTimer &&\n                <div style={{\n                    position: 'relative',\n                    width: '100%',\n                    display: 'flex'\n                }}>\n                    {view !== 'chart' && reduxStore.getState().db.cards[data._id]._users[session._id] &&\n                        <CustomButton\n                            title={translate(\"$__add\")}\n                            text={translate(\"$__add\")}\n                            icon={\"more_time\"}\n                            size={\"25px\"}\n                            onClick={() => {\n                                setAddTimer(true)\n                            }}\n                        />\n                    }\n                    {view !== 'chart' &&\n                        <CustomButton\n                            title={translate(\"$__showChart\")}\n                            text={translate(\"$__showChart\")}\n                            icon={\"analytics\"}\n                            size={\"25px\"}\n                            onClick={() => {\n                                setView(\"chart\")\n                            }}\n                        />\n                    }\n                    {view !== 'timeline' &&\n                        <CustomButton\n                            title={translate(\"$__showTimeline\")}\n                            text={translate(\"$__showTimeline\")}\n                            icon={\"timeline\"}\n                            size={\"25px\"}\n                            onClick={() => {\n                                setView(\"timeline\")\n                            }}\n                        />\n                    }\n                </div>\n            }\n            {view === 'chart' &&\n                <div style={{ width: \"calc(100% - 30px)\", marginLeft: \"15px\" }}>\n                    <Timesheet nodeId={data._id} />\n                </div>\n            }\n            {(addTimer || view === 'timeline') &&\n                <div\n                    // className={classes.timeline} \n                    style={{\n                        position: \"absolute\",\n                        // ...addTimer ? { top: 333 } : { top: 35 },\n                        top: 35,\n                        left: 0,\n                        right: 0,\n                        bottom: 0,\n                    }}>\n                    <Timeline nodeId={data._id} type={\"timer\"} db={'cards'} disabledSend loadTimeline noSearch />\n                </div>\n            }\n            {addTimer &&\n                <div className={classes.timeline} style={{\n                    top: '0px',\n                    zIndex: 100,\n                    backgroundColor: '#FFFFFF'\n                }}>\n                    <KPITimer data={data} manualAdd callBack={() => {\n                        setAddTimer(false)\n                    }} />\n                </div>\n            }\n        </div >\n    )\n}\nconst mapStateToProps = () => ({\n\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport Buttom from \"components/CustomButtons/Custom\"\nimport CircularProgress from \"components/Progress/circular\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\nimport TextField from \"components/TextField/\"\nimport Icon from \"components/Icon\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport InputAdornment from '@material-ui/core/InputAdornment'\n\n//FUNCTIONS\nimport { translate, customApp, appAlert, deleteNode } from \"functions/\"\nimport { getChildrens, deleteCard } from \"functions/cards\"\n\nimport apims from \"apims\"\nimport api from \"api\"\n\nfunction Component(props) {\n    const { sideModule, db, functions } = reduxStore.getState()\n    const { socket } = functions\n    const [migrateComplete, setMigrateComplete] = React.useState(false)\n    const [Load, setLoading] = React.useState(false)\n    const [SelectedUser, setSelectedUser] = React.useState(null)\n    const [childrensCards, setChildrensCards] = React.useState({})\n    const [countCards, setCountCards] = React.useState(0)\n    const [findNameUser, setFindNameUser] = React.useState(\"\")\n    const data = sideModule.data || {}\n\n    React.useEffect(() => {\n        if (data.type === 'user') {\n            loadUserCards()\n        } else {\n            setLoading(false)\n        }\n        return () => { }\n    }, [])\n\n    React.useEffect(() => {\n        iniChildrens()\n    }, [data._id])\n\n    const iniChildrens = async () => {\n        let cards = await getChildrens(data._id)\n        if (cards)\n            setChildrensCards(cards)\n    }\n\n    const deleteThis = async () => {\n        appAlert({\n            message: translate(\"$__confirmDeleteThis\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                deleteCard(props, { _id: data._id }, false)\n                deleteNode(props, { _id: data._id }, false)\n                props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n            }\n        })\n    }\n\n\n    const loadUserCards = async () => {\n        setLoading(true)\n        const countChildrens = await apims.post(\"/Card_Count\", { id: data._id, all: true, rel: \"INN\", node: \"User\" })\n        if (countChildrens) {\n            setLoading(false)\n            setCountCards(countChildrens.data)\n        }\n\n    }\n\n    const migrate = async () => {\n        setLoading(true)\n\n        try {\n            let response = await api.post(\"/user/migrateActivities\", {\n                from: data._id,\n                fromData: data,\n                to: [SelectedUser],\n                toData: db.users[SelectedUser]\n            })\n            if (response) {\n                setMigrateComplete(true)\n                let cards = { ...db.cards }\n                Object.keys(cards).filter(a =>\n                    cards[a]._users && cards[a]._users[data._id]\n                ).map(a => {\n                    if (!cards[a]._users[SelectedUser])\n                        cards[a]._users = {\n                            ...cards[a]._users,\n                            [SelectedUser]: {\n                                access: cards[a]._users[data._id].access,\n                                _id: SelectedUser\n                            }\n                        }\n                    delete cards[a]._users[data._id]\n                })\n                setLoading(false)\n            }\n        } catch (e) {\n            console.log(e)\n            setTimeout(() => {\n                migrate()\n            }, 3000)\n        }\n        return\n        socket.emit(\"data\", {\n            module: \"user\",\n            method: \"post\",\n            action: \"migrate\"\n        }, {\n            from: data._id,\n            fromData: data,\n            to: SelectedUser,\n            toData: db.users[SelectedUser]\n        }, async () => {\n            setMigrateComplete(true)\n            let cards = { ...db.cards }\n            Object.keys(cards).filter(a =>\n                cards[a]._users && cards[a]._users[data._id]\n            ).map(a => {\n                if (!cards[a]._users[SelectedUser])\n                    cards[a]._users = {\n                        ...cards[a]._users,\n                        [SelectedUser]: {\n                            access: cards[a]._users[data._id].access,\n                            _id: SelectedUser\n                        }\n                    }\n                delete cards[a]._users[data._id]\n            })\n            setLoading(false)\n        })\n    }\n\n    return (\n        <div style={{ width: '100%' }}>\n            <SideModuleCloseAndSave\n                close={() => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n                }}\n            />\n\n            {/* DELETE CLIENT */}\n            {data._id && db.users[data._id] &&\n                (\n                    db.users[data._id].type === 'client' ||\n                    db.users[data._id].type === 'group' ||\n                    db.users[data._id].type === 'sic' ||\n                    db.users[data._id].type === 'unity'\n                ) &&\n                <fieldset style={{ textAlign: \"center\" }}>\n                    <legend style={{ color: customApp(\"color\") }}>{translate(\"$__deleteOptions\", 1)}</legend>\n                    <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                        {Object.keys(db.users).filter(a => db.users[a]._parent === data._id).length > 0 ?\n                            translate(`$__delete${db.users[data._id].type}WithUsersDescription`, 1)\n                            :\n                            translate(`$__delete${db.users[data._id].type}NoUsersDescription`, 1)\n                        }\n                    </div>\n                    <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                        {translate(\"$__deleteThisDescription\", 1)}\n                    </div>\n                    <Buttom onClick={() => { deleteThis() }} >{translate(\"$__deleteThis\", 1)}</Buttom>\n                </fieldset>\n            }\n\n            {/* DELETE USER */}\n            {data._id && db.users[data._id] &&\n                db.users[data._id].type === 'user' &&\n                <React.Fragment>\n                    {!Load ?\n                        <React.Fragment>\n                            {countCards > 0 && !migrateComplete ?\n                                <React.Fragment>\n                                    <fieldset>\n                                        <legend style={{ color: customApp(\"color\") }}>{translate(\"$__thisUserHas\", 1)}</legend>\n                                        <div style={{\n                                            position: \"relative\",\n                                            marginTop: \"22px\",\n                                            bottom: \"7px\",\n                                            width: \"100%\",\n                                            fontSize: \"12px\",\n                                            color: customApp('mediumText'),\n                                            display: \"flex\",\n                                            justifyContent: \"center\",\n                                            textAlign: \"center\"\n                                        }}>\n                                            {countCards} {translate(\"$__items\")}\n                                            <br></br>\n                                            {translate(\"$__deleteCountCardsExplain\")}\n                                        </div>\n                                    </fieldset>\n                                    {SelectedUser ?\n                                        <fieldset>\n                                            <legend>{translate('$__selectedUserToMigrationCards')}</legend>\n                                            <div\n                                                style={{\n                                                    cursor: 'pointer',\n                                                    marginBottom: '7px',\n                                                    display: 'flex',\n                                                    alignItems: 'center'\n                                                }}\n                                                onClick={() => {\n                                                    setSelectedUser(null)\n                                                }}\n                                            >\n                                                <Avatar alt={db.users[SelectedUser].name} src={db.users[SelectedUser].image || null}\n                                                    style={{ marginRight: '15px' }}\n                                                >\n                                                    {db.users[SelectedUser].name.substr(0, 1)}\n                                                </Avatar>\n                                                <span>{db.users[SelectedUser].name}</span>\n                                            </div>\n                                            <Buttom onClick={() => {\n                                                appAlert({\n                                                    message: translate('$__confirmUserTransferData', 1),\n                                                    autoClose: 50000,\n                                                    buttons: [\n                                                        {\n                                                            shadow: true,\n                                                            title: translate(\"$__confirm\"),\n                                                            text: translate(\"$__confirm\"),\n                                                            color: \"green\",\n                                                            icon: \"done_all\",\n                                                            size: \"25px\",\n                                                            style: { marginLeft: 15 },\n                                                            onClick: () => {\n                                                                migrate()\n                                                            },\n                                                        },\n                                                        {\n                                                            shadow: true,\n                                                            title: translate(\"$__cancel\"),\n                                                            text: translate(\"$__cancel\"),\n                                                            color: \"red\",\n                                                            icon: \"close\",\n                                                            size: \"25px\",\n                                                            style: { marginLeft: 15 },\n                                                            onClick: () => {\n\n                                                            },\n                                                        }],\n                                                    variant: 'warning',\n                                                    persist: false,\n                                                    horizontal: 'right',\n                                                })\n\n                                            }} >{translate(\"$__migrate\", 1)}</Buttom>\n                                        </fieldset>\n                                        :\n                                        <fieldset\n                                            style={{ marginTop: 7, marginBottom: 7 }}\n                                        >\n                                            <legend>{translate('$__chooseAUserToTransferCardsBeforeDeletingUser')}</legend>\n                                            <TextField\n                                                label={translate('$__search', '*')}\n                                                variant={'standard'}\n                                                autoFocus\n                                                value={findNameUser}\n                                                InputProps={{\n                                                    endAdornment: (\n                                                        <InputAdornment position=\"start\">\n                                                            <Icon color={customApp('color')}>search</Icon>\n                                                        </InputAdornment>\n                                                    ),\n                                                    onChange: e => {\n                                                        setFindNameUser(e.target.value)\n                                                    },\n                                                }}\n                                            />\n                                            {Object.keys(db.users)\n                                                .filter(a =>\n                                                    // a === a\n                                                    a !== data._id\n                                                    && db.users[a].type === 'user'\n                                                    && !db.users[a].deleted\n                                                    && (\n                                                        (!data._parent\n                                                            &&\n                                                            !db.users[a]._parent\n                                                        )\n                                                        || (\n                                                            data._parent\n                                                            && db.users[a]._parent === data._parent\n                                                        )\n                                                    )\n                                                    && (\n                                                        !findNameUser || (\n                                                            findNameUser && db.users[a].name.toLowerCase().indexOf(findNameUser.toLowerCase().trim()) > -1\n                                                        )\n                                                    )\n                                                )\n                                                .sort((a, b) => {\n                                                    var nameA = db.users[a].name.toLowerCase()\n                                                    var nameB = db.users[b].name.toLowerCase()\n                                                    if (nameA < nameB)\n                                                        return -1\n                                                    if (nameA > nameB)\n                                                        return 1\n                                                    return 0\n                                                })\n                                                .map(pr =>\n                                                    <div\n                                                        style={{\n                                                            cursor: 'pointer',\n                                                            marginBottom: '7px',\n                                                            display: 'flex',\n                                                            alignItems: 'center'\n                                                        }}\n                                                        onClick={() => {\n                                                            setSelectedUser(pr)\n                                                        }}\n                                                        key={pr}\n                                                    >\n                                                        <Avatar alt={db.users[pr].name} src={db.users[pr].image || null}\n                                                            style={{ marginRight: '15px' }}\n                                                        >\n                                                            {db.users[pr].name.substr(0, 1)}\n                                                        </Avatar>\n                                                        <span>{db.users[pr].name}</span>\n                                                    </div>\n                                                )}\n                                        </fieldset>\n                                    }\n                                    <fieldset style={{ textAlign: \"center\" }} >\n                                        <legend style={{ color: customApp(\"color\") }}>{translate(\"$__deactivateThis\", 1)}</legend>\n                                        <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                                            {translate(\"$__deactivateWhithoutMigration\", 1)}\n                                        </div>\n                                        <Buttom onClick={() => { deleteThis() }} >{translate(\"$__deactivateThis\", 1)}</Buttom>\n                                    </fieldset>\n                                </React.Fragment>\n                                :\n                                <fieldset style={{ textAlign: \"center\" }} >\n                                    <legend style={{ color: customApp(\"color\") }}>{translate(\"$__deactivateThis\", 1)}</legend>\n                                    <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                                        {translate(\"$__deactivateUserDescription\", 1)}\n                                    </div>\n                                    <Buttom onClick={() => { deleteThis() }} >{translate(\"$__deactivateThis\", 1)}</Buttom>\n                                </fieldset>\n                            }\n\n                        </React.Fragment>\n                        :\n                        <React.Fragment></React.Fragment>\n                    }\n                    {Load ?\n                        <div style={{\n                            position: 'relative',\n                            width: '100%',\n                            display: 'flex',\n                            justifyContent: 'center',\n                            alignItems: 'center',\n                            marginTop: '33px'\n                        }}>\n                            <CircularProgress />\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                </React.Fragment>\n            }\n        </div >\n    )\n}\nconst mapStateToProps = store => ({\n    store\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","import React from 'react';\nimport clsx from 'clsx';\n\n//@MATERIAL\nimport Radio from '@material-ui/core/Radio';\nimport { makeStyles } from '@material-ui/core/styles';\n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\nconst useStyles = makeStyles({\n    root: {\n        '&:hover': {\n            backgroundColor: 'transparent',\n        },\n    },\n    icon: {\n        borderRadius: '50%',\n        width: 16,\n        height: 16,\n        boxShadow: `inset 0 0 0 1px ${customApp('color', .2)}, inset 0 -1px 0 ${customApp('color', .1)}`,\n        backgroundColor: `#f5f8fa`,\n        backgroundImage: `linear-gradient(180deg,hsla(0,0%,100%,.8),hsla(0,0%,100%,0))`,\n        '$root.Mui-focusVisible &': {\n            outline: `2px auto ${customApp('color', .6)}`,\n            outlineOffset: 2,\n        },\n        'input:hover ~ &': {\n            backgroundColor: '#ebf1f5',\n        },\n        'input:disabled ~ &': {\n            boxShadow: 'none',\n            background: 'rgba(206,217,224,.5)',\n        },\n    },\n    checkedIcon: {\n        backgroundColor: customApp('color', 1),\n        backgroundImage: 'linear-gradient(180deg,hsla(0,0%,100%,.1),hsla(0,0%,100%,0))',\n        '&:before': {\n            display: 'block',\n            width: 16,\n            height: 16,\n            backgroundImage: 'radial-gradient(#fff,#fff 28%,transparent 32%)',\n            content: '\"\"',\n        },\n        'input:hover ~ &': {\n            backgroundColor: customApp('color', 1),\n        },\n    },\n});\n\n// Inspired by blueprintjs\nfunction StyledRadio(props) {\n    const classes = useStyles();\n\n    return (\n        <Radio\n            className={classes.root}\n            disableRipple\n            color=\"default\"\n            checkedIcon={<span className={clsx(classes.icon, classes.checkedIcon)} />}\n            icon={<span className={classes.icon} />}\n            {...props}\n        />\n    );\n}\n\nexport default StyledRadio","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst headerStyle = theme => ({\r\n  root: {\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    width: \"calc(100% - 20px)\",\r\n    margin: \"10px\",\r\n  },\r\n  user: {\r\n    position: \"relative\",\r\n    width: \"calc(100% - 20px)\",\r\n    margin: \"10px\",\r\n    float: \"left\",\r\n    height: \"50px\"\r\n  },\r\n  avatar: {\r\n    position: \"absolute\",\r\n    left: \"-5px\",\r\n    top: \"0px\",\r\n    border: `1px solid ${customApp(\"color\")}`,\r\n    width: \"57px\",\r\n    height: \"57px\",\r\n    borderRadius: \"50%\",\r\n    backgroundSize: \"cover\",\r\n    backgroundRepeat: \"no-repeat\",\r\n    backgroundPosition: \"center center\",\r\n    backgroundColor: \"#FFFFFF\"\r\n  },\r\n  name: {\r\n    position: \"absolute\",\r\n    top: \"5px\",\r\n    left: \"36px\",\r\n    right: \"0px\",\r\n    height: \"30px\",\r\n    border: `1px solid ${customApp(\"color\", 0.2)}`,\r\n    borderRadius: \"5px\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"space-between\",\r\n    paddingLeft: \"16px\",\r\n    paddingRight: \"7px\",\r\n    fontWeight: \"bold\",\r\n    fontSize: \"12px\",\r\n    color: customApp(\"darkText\"),\r\n    boxShadow: \"-5px 3px 7px 1px rgba(0,0,0,0.1)\"\r\n  },\r\n  access: {\r\n    position: \"absolute\",\r\n    top: \"33px\",\r\n    left: \"45px\",\r\n    right: \"0px\",\r\n    height: \"30px\",\r\n    border: `1px solid ${customApp(\"color\", 0.2)}`,\r\n    borderRadius: \"0 0 5px 5px\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    paddingLeft: \"16px\",\r\n    fontSize: \"12px\",\r\n    color: customApp(\"color\"),\r\n    boxShadow: \"0px 3px 7px 1px rgba(0,0,0,0.05)\"\r\n  },\r\n  accessEditing: {\r\n    position: \"absolute\",\r\n    top: \"33px\",\r\n    left: \"0px\",\r\n    right: \"0px\",\r\n    height: \"auto\",\r\n    minHeight: \"290px\",\r\n    padding: \"7px\",\r\n    border: `1px solid ${customApp(\"color\", 0.2)}`,\r\n    borderRadius: \"0 0 5px 5px\",\r\n    // display: \"flex\",\r\n    // alignItems: \"center\",\r\n    paddingTop: '15px',\r\n    paddingLeft: \"16px\",\r\n    fontSize: \"12px\",\r\n    fontWeight: \"bold\",\r\n    color: customApp(\"color\"),\r\n    backgroundColor: \"#FFFFFF\",\r\n    boxShadow: \"0px 3px 7px 1px rgba(0,0,0,0.05)\",\r\n    \"& ul\": {\r\n      fontSize: \"12px\"\r\n    }\r\n  },\r\n  btActions: {\r\n    position: \"absolute\",\r\n    right: \"7px\",\r\n    top: \"7px\",\r\n    display: \"flex\"\r\n  },\r\n  switch: {\r\n    fontSize: \"12px\",\r\n    fontWeight: \"bold\",\r\n    color: customApp(\"medium\")\r\n  },\r\n  accessDescription: {\r\n    fontSize: \"12px\",\r\n    color: customApp(\"medium\"),\r\n  }\r\n});\r\n\r\nexport default headerStyle;\r\n","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Radio from \"components/Radio\"\nimport Icon from \"components/Icon\"\nimport CustomButton from \"components/Buttons/custom\"\nimport MoreMenu from \"components/MoreMenu/\"\nimport TextField from \"components/TextField\";\n\n\n//@MATERIAL\nimport FormControlLabel from '@material-ui/core/FormControlLabel'\nimport RadioGroup from '@material-ui/core/RadioGroup'\nimport { withStyles } from \"@material-ui/core/styles\"\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card-Users.js\"\n\n//IMAGES\nimport defaultAvatar from \"assets/img/default-avatar.png\"\n\n//FUNCTIONS\nimport { translate, customApp, appAlert, getAppAccess } from \"functions\"\nimport { cardsAccess, groupAccess, groupAccessRemove, isResponsible } from \"functions/users\"\nimport api from \"api/\"\n\nimport {\n    planMyAccountVerify,\n} from \"functions/cards\"\n\nfunction Component(props) {\n    const { classes } = props\n    const { db, sideModule, session } = reduxStore.getState()\n    const [userEditing, setUserEditing] = React.useState({ id: null })\n    const [reqSave, setReqSave] = React.useState(false)\n    const [view, setView] = React.useState(\"users\")\n    const [searchValue, setSearchValue] = React.useState(\"\")\n    const [search, setSearch] = React.useState(false)\n\n    const card = db.cards[sideModule.data._id]\n    // console.log(card)\n    let client = db.cards[card._planId]?.client || null\n\n    let users = { ...db.users }\n    let unSelectedUsers = {\n        ...card && card._users ? { ...card._users } : {},\n        ...card._parent && db.cards[card._parent] && db.cards[card._parent]._users ? { ...db.cards[card._parent]._users } : {},\n        ...card._planId && db.cards[card._planId] && db.cards[card._planId]._users ? { ...db.cards[card._planId]._users } : {},\n        ...users,\n    }\n\n    let unSelectedGroups = Array.from(reduxStore.getState().db.userGroup)\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    let AppAccess = getAppAccess()\n    let CardAccess = card && card._id && db.cards[card._id] && db.cards[card._id]._users && Object.keys(db.cards[card._id]._users).length > 0 ? db.cards[card._id]._users[Object.keys(db.cards[card._id]._users).find(a => a.indexOf(session._id) > -1)] : 0\n\n    if (!sideModule || !sideModule.data)\n        return null\n\n    const close = () => {\n        if (reqSave) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    setUserEditing({ _id: null })\n                    setReqSave(false)\n                }\n            })\n        } else {\n            setUserEditing({ _id: null })\n            setReqSave(false)\n        }\n\n    }\n    const saveUser = async (id, acc, userData) => {\n        let access = 1\n        if (card && card.type === 'plan')\n            access = 3\n        if (!acc) {\n            if (\n                card._planId\n                && db.cards[card._planId]\n                && db.cards[card._planId]._users\n                && db.cards[card._planId]._users[id]\n                && db.cards[card._planId]._users[id].access\n            ) {\n                if (card._parent\n                    && db.cards[card._parent]\n                    && db.cards[card._parent]._users\n                    && db.cards[card._parent]._users[id]\n                    && db.cards[card._parent]._users[id].access\n                    && parseInt(db.cards[card._parent]._users[id].access) > parseInt(db.cards[card._planId]._users[id].access)\n                ) {\n                    access = parseInt(db.cards[card._parent]._users[id].access)\n                } else {\n                    access = parseInt(db.cards[card._planId]._users[id].access)\n                }\n            }\n        } else {\n            access = acc\n        }\n        const noNotification = db.cards[sideModule.data._id] && db.cards[sideModule.data._id]._users && db.cards[sideModule.data._id]._users[id] ? true : false\n        const saved = await cardsAccess(props, id, access, sideModule.data._id, noNotification, userData)\n        if (saved) {\n            setReqSave(false)\n            setUserEditing({ _id: null })\n            return true\n        }\n    }\n\n    const saveGroup = async (id) => {\n        const saved = await groupAccess(props, id, sideModule.data._id)\n        if (saved) {\n            setReqSave(false)\n            setUserEditing({ _id: null })\n            return true\n        }\n    }\n\n    const deleteAccessUser = async (id, close) => {\n        const response = await api.put(`cards/removeAccess/`, {\n            cardId: sideModule.data._id,\n            userIds: [id]\n        })\n        if (response) {\n            if (close)\n                props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\");\n            // delete newUsers[id]\n            setReqSave(false)\n            setUserEditing({ _id: null })\n        }\n    }\n\n    if (!card)\n        return null\n    users = users && Object.keys(users).length > 0 && Object.keys(users)\n        .filter(a =>\n            a &&\n            (\n                card\n                && card._users\n                && card._users[users[a]._id]\n                // && (\n                //     !users[a]._parent\n                //     ||\n                //     (\n                //         users[a]._parent\n                //         && users[a]._parent === session.account\n                //     )\n                // )\n                && !card._users[users[a]._id].deleted\n                // || (card._users && Object.keys(card._users).indexOf(a) > -1)\n            )\n        )\n        .sort((a, b) => {\n            if (a.name < b.name)\n                return -1\n            return 0\n        })\n        .map(a => users[a])\n\n\n\n    // unSelectedUsers = Object.keys(unSelectedUsers)\n    //     .filter(a => {\n    //         if (\n    //             a\n    //             && (\n    //                 (\n    //                     (!card.client\n    //                         && !unSelectedUsers[a].companyName\n    //                         &&\n    //                         (\n    //                             !unSelectedUsers[a]._parent\n    //                             || unSelectedUsers[a]._parent === session.account\n    //                         )\n    //                     )\n    //                     // || (\n    //                     //     card.client\n    //                     //     && unSelectedUsers[a]._parent\n    //                     //     && unSelectedUsers[a]._parent === card.client\n    //                     // )\n    //                     // ||\n    //                     // (\n    //                     //     card.client\n    //                     //     && (\n    //                     //         !unSelectedUsers[a]._parent\n    //                     //         || (\n    //                     //             unSelectedUsers[a]._parent\n    //                     //             && unSelectedUsers[a]._parent === session.account\n    //                     //         )\n    //                     //     )\n    //                     // )\n    //                 )\n    //                 // && (\n    //                 //     unSelectedUsers[a].type === 'user'\n    //                 //     || unSelectedUsers[a].type === 'external'\n    //                 //     || !unSelectedUsers[a].type\n    //                 // )\n    //                 // // && unSelectedUsers[a].type !== 'external'\n    //                 // && !unSelectedUsers[a].deleted\n    //                 // && (\n    //                 //     !card._users\n    //                 //     || (\n    //                 //         card._users\n    //                 //         && !card._users[unSelectedUsers[a]._id]\n    //                 //     )\n    //                 // ))\n    //             )\n    //         )\n    //             return true\n    //     }\n    //     )\n    //     .map(a => unSelectedUsers[a])\n\n\n\n    unSelectedUsers = Object.keys(unSelectedUsers)\n        .filter(a => {\n            // console.log(unSelectedUsers[a])\n            if (unSelectedUsers[a].name === 'A10')\n                console.log(unSelectedUsers[a], client)\n            // return true\n            if (\n                a\n                && (\n                    !unSelectedUsers[a].type\n                    || (\n                        unSelectedUsers[a].type\n                        && unSelectedUsers[a].type !== \"client\"\n                        && unSelectedUsers[a].type !== \"unity\"\n                        && unSelectedUsers[a].type !== \"group\"\n                    )\n                )\n                && (\n                    !unSelectedUsers[a].deleted\n                    && (\n                        (\n                            !client\n                            &&\n                            (\n                                !unSelectedUsers[a]._parent\n                                || (\n                                    unSelectedUsers[a]._parent\n                                    && unSelectedUsers[a]._parent === session.account\n                                )\n                            )\n                        )\n                        ||\n                        (\n                            client\n                            &&\n                            (\n                                (\n                                    unSelectedUsers[a]._parent\n                                    && (\n                                        unSelectedUsers[a]._parent === client\n                                        || unSelectedUsers[a]._parent === session.account\n\n                                    )\n                                )\n                                || !unSelectedUsers[a]._parent\n                            )\n                        )\n                    )\n                )\n            )\n                return true\n        }\n        )\n        .map(a => unSelectedUsers[a])\n\n    unSelectedUsers = unSelectedUsers.filter(a =>\n        a && (\n            (\n                !client\n                || (\n                    client\n                    && (\n                        a._parent === client\n                        || !a._parent\n                    )\n                )\n            )\n            && (!card._users\n                || !card._users[a._id]\n            )\n            && (\n                !searchValue\n                || (\n                    searchValue\n                    && (\n                        (\n                            a.name\n                            && a.name.toLowerCase().indexOf(searchValue.toLowerCase()) > -1\n                        )\n                        ||\n                        (\n                            searchValue.indexOf('>') > -1\n                            && a._parent\n                            && reduxStore.getState().db.users\n                            && reduxStore.getState().db.users[a._parent]\n                            && reduxStore.getState().db.users[a._parent].name\n                            && reduxStore.getState().db.users[a._parent].name.toLowerCase().indexOf(searchValue.toLowerCase().replace('>', \"\").trim()) > -1\n                        )\n                    )\n                )\n            )\n        )\n    ).map(a => a)\n\n\n    const addAllUsers = async (adus) => {\n        setSearchValue(\"\")\n        adus.map(u => {\n            saveUser(u._id, null, u)\n        })\n    }\n\n    const addAllGroups = async (adus) => {\n        setSearchValue(\"\")\n        adus.map(u => {\n            // console.log(u)\n            // saveUser(u._id, null, u)\n        })\n    }\n\n    const renderGroup = (gr) => {\n        return (\n            <div\n                className={classes.user}\n                style={{ height: 37 }}\n            >\n                <div\n                    className={classes.name}\n                    style={{ left: 0 }}\n                >\n                    {gr.label}\n                    <CustomButton\n                        transparent\n                        title={card._groups && card._groups[gr.value] ? translate(\"$__removeTeam\") : translate(\"$__addTeam\")}\n                        icon={card._groups && card._groups[gr.value] ? \"group_remove\" : \"group_add\"}\n                        size={\"20px\"}\n                        onClick={() => {\n                            if (card && (!card._groups || (card._groups && !card._groups[gr.value]))) {\n                                saveGroup(gr.value)\n                            } else {\n                                groupAccessRemove(props, gr.value, card._id)\n                            }\n\n                        }}\n                    />\n                </div>\n\n            </div>\n        )\n    }\n\n    const renderUser = (us, add = false) => {\n        let permission = true\n        let u = us\n        if (us._id && db.users[us._id])\n            u = db.users[us._id]\n        if (\n            (\n                !us.type\n                || us.type === 'external'\n            )\n            && (\n                !u._parent\n                || (\n                    u._parent\n                    && (\n                        !db.users[u._parent]\n                    )\n                )\n            )\n        ) {\n            permission = false\n        }\n\n        if (card && card._planId && planMyAccountVerify(card._planId))\n            permission = true\n\n        let access = 1\n        if (u && u._id && card._users && card._users[u._id] && card._users[u._id].access)\n            access = String(card._users[u._id].access)\n        return (\n            <div className={classes.user}>\n                <div className={classes.name}>\n                    {u.name}\n                    {card._users[u._id] && card._users[u._id].isResponsible ? <span style={{ fontSize: \"9px\", fontWeight: 'normal', color: '#CCCCCC' }}>{translate(\"$__responsible\", 1)}</span>\n                        :\n                        ``\n                    }\n                    {add && !userEditing._id ?\n                        <div>\n                            <CustomButton\n                                transparent\n                                title={translate(\"$__add\")}\n                                icon={\"person_add\"}\n                                size={\"20px\"}\n                                onClick={() => {\n                                    saveUser(u._id, null, u)\n                                }}\n                            />\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {!add ?\n                        <div\n                            style={{\n                                zIndex: 10\n                            }}\n                        >\n                            <MoreMenu\n                                horizontalButton\n                                transparent\n                                size=\"14px\"\n                                btColor={customApp(\"color\")}\n                                options={[\n                                    {\n                                        name: \"$__setAsResponsible\",\n                                        icon: \"admin_panel_settings\",\n                                        onClick: () => {\n                                            appAlert({\n                                                message: translate('$__confirmSetAsResponsibleCard', 1),\n                                                variant: 'warning',\n                                                persist: false,\n                                                horizontal: 'right',\n                                                confirm: () => {\n                                                    isResponsible(props, {\n                                                        cardId: sideModule.data._id,\n                                                        userId: u._id\n                                                    })\n                                                }\n                                            })\n                                        },\n                                    },\n                                    ...permission && (\n                                        (\n                                            u\n                                            &&\n                                            (\n                                                (\n                                                    !u._access\n                                                    ||\n                                                    (\n                                                        u._access\n                                                        && u._access !== 'owner'\n                                                    )\n                                                )\n                                                &&\n                                                (\n                                                    (\n                                                        CardAccess\n                                                        && String(CardAccess.access)\n                                                        && parseInt(CardAccess.access) > 2\n                                                        && parseInt(CardAccess.access) >= parseInt(access)\n                                                    )\n                                                    ||\n                                                    (\n                                                        AppAccess\n                                                        && AppAccess.plan\n                                                        &&\n                                                        (\n                                                            AppAccess.planAdmin\n                                                            || AppAccess.planModerate\n                                                        )\n                                                    )\n                                                )\n                                            )\n\n                                        )\n                                        ||\n                                        u._id === session._id\n                                    ) ? [\n                                        {\n                                            name: \"$__editAccess\",\n                                            icon: \"manage_accounts\",\n                                            onClick: () => {\n                                                setUserEditing({\n                                                    _id: u._id,\n                                                    access: access\n                                                })\n                                            },\n                                        },\n                                        {\n                                            name: \"$__removeAccess\",\n                                            icon: \"delete_forever\",\n                                            color: 'red',\n                                            onClick: () => {\n                                                appAlert({\n                                                    message: u._id !== session._id ? translate('$__confirmRemoveUser', 1) : translate('$__confirmGetOut', 1),\n                                                    variant: 'warning',\n                                                    persist: false,\n                                                    horizontal: 'right',\n                                                    confirm: () => {\n                                                        deleteAccessUser(u._id, u._id !== session._id ? false : true)\n                                                    }\n                                                })\n                                            },\n                                        },\n                                    ] : []\n                                ]}\n                            />\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                </div>\n                <div className={classes.avatar}\n                    style={{\n                        backgroundImage: `url(\"${u.image ? u.image : defaultAvatar}\")`\n                    }}>\n                    {u._parent &&\n                        db.users[u._parent] &&\n                        db.users[u._parent].image ?\n                        <div\n                            style={{\n                                position: \"absolute\",\n                                bottom: -4,\n                                right: -7,\n                                width: 22,\n                                height: 22,\n                                borderRadius: \"50%\",\n                                backgroundImage: `url(${db.users[u._parent].image})`,\n                                backgroundSize: \"cover\",\n                                backgroundRepeat: \"no-repeat\"\n                            }}></div>\n                        : <React.Fragment></React.Fragment>}\n                </div>\n                {!add ?\n                    <div className={classes.access}\n                        style={{\n                            cursor: 'pointer',\n                            paddingLeft: 15,\n                            paddingRight: 15,\n                            paddingTop: 3,\n                            display: \"block\"\n                        }}\n                        onClick={permission ? () => {\n                            if (\n                                (\n                                    u\n                                    &&\n                                    (\n                                        (\n                                            !u._access\n                                            ||\n                                            (\n                                                u._access\n                                                && u._access !== 'owner'\n                                            )\n                                        )\n                                        &&\n                                        (\n                                            (\n                                                CardAccess\n                                                && String(CardAccess.access)\n                                                && parseInt(CardAccess.access) > 2\n                                                && parseInt(CardAccess.access) >= parseInt(access)\n                                            )\n                                            ||\n                                            (\n                                                AppAccess\n                                                && AppAccess.plan\n                                                &&\n                                                (\n                                                    AppAccess.planAdmin\n                                                    || AppAccess.planModerate\n                                                )\n                                            )\n                                        )\n                                    )\n\n                                )\n                                ||\n                                u._id === session._id\n                            ) {\n                                setUserEditing({\n                                    _id: u._id,\n                                    access: access\n                                })\n                            }\n                        }\n                            : null\n                        }>\n                        {u._parent &&\n                            db.users[u._parent] &&\n                            db.users[u._parent].name ?\n                            <div style={{ position: \"relative\", float: \"left\" }}>\n                                {db.users[u._parent].name}\n                            </div>\n                            : <React.Fragment></React.Fragment>}\n                        <div style={{ position: \"relative\", float: \"right\" }}>\n                            ({u._access === 'owner' ? translate('$__owner', 1)\n                                : access === '0' ? translate('$__reader', 1)\n                                    : access === '1' ? translate('$__executioner', 1)\n                                        : access === '2' ? translate('$__collaborator', 1)\n                                            : access === '3' ? translate('$__leadership', 1)\n                                                : access === '4' ? translate('$__supervisor', 1)\n                                                    : access === '5' ? translate('$__admin', 1)\n                                                        : translate('$__reader', 1)\n\n                            })\n                        </div>\n                    </div>\n                    : u._parent &&\n                        db.users[u._parent] &&\n                        db.users[u._parent].name ?\n                        <div className={classes.access}>\n                            <div>\n                                {db.users[u._parent].name}\n                            </div>\n                        </div>\n                        : <React.Fragment></React.Fragment>}\n            </div>\n        )\n    }\n\n    if (userEditing && userEditing._id) {\n        let access = 1\n        if (card._users && card._users[userEditing._id] && card._users[userEditing._id].access)\n            access = String(card._users[userEditing._id].access)\n        let u = card._users[userEditing._id]\n        let permission = false\n        if (card && card._planId && planMyAccountVerify(card._planId))\n            permission = true\n\n        return (\n            <React.Fragment>\n                {renderUser(u, true)}\n                <div\n                    style={{\n                        position: \"relative\",\n                        display: \"flex\",\n                        alignItems: \"center\",\n                        width: \"100%\",\n                        float: \"left\",\n                        justifyContent: \"flex-end\"\n                    }}\n                >\n                    {reqSave &&\n                        <CustomButton\n                            transparent\n                            title={translate(\"$__save\")}\n                            icon={\"save\"}\n                            color={customApp('color')}\n                            onClick={() => {\n                                saveUser(userEditing._id, userEditing.access, u)\n                            }}\n                        />\n                    }\n                    {users.length > 1 &&\n                        <CustomButton\n                            transparent\n                            title={userEditing._id !== session._id ? translate('$__removeAccess', 1) : translate('$__getOut', 1)}\n                            icon={userEditing._id !== session._id ? 'delete_forever' : 'logout'}\n                            color={'red'}\n                            onClick={() => {\n                                appAlert({\n                                    message: userEditing._id !== session._id ? translate('$__confirmRemoveUser', 1) : translate('$__confirmGetOut', 1),\n                                    variant: 'warning',\n                                    persist: false,\n                                    horizontal: 'right',\n                                    confirm: () => {\n                                        deleteAccessUser(userEditing._id, userEditing._id !== session._id ? false : true)\n                                    }\n                                })\n                            }}\n                        />\n                    }\n                    <CustomButton\n                        transparent\n                        title={translate('$__close', '*')}\n                        icon={'undo'}\n                        color={customApp('medium')}\n                        onClick={() => close()}\n                    />\n                </div>\n                <div\n                    style={{\n                        position: \"relative\",\n                        width: \"100%\",\n                        padding: 15,\n                        float: \"left\"\n                    }}\n                >\n                    {(userEditing._id !== session._id || (AppAccess.plan && AppAccess.planAdmin)) &&\n                        <div style={{\n                            position: \"relative\",\n                            float: \"left\",\n                            width: \"100%\",\n                        }}>\n                            <RadioGroup\n                                defaultValue={String(access)}\n                                aria-label=\"gender\"\n                                name=\"customized-radios\"\n                                onChange={(e) => {\n                                    setUserEditing({ ...userEditing, access: e.target.value })\n                                    setReqSave(true)\n                                }}\n                            >\n                                {card.type !== 'plan' && ((CardAccess && parseInt(CardAccess.access) >= 0) || (permission && (AppAccess && AppAccess.plan && (AppAccess.planAdmin || AppAccess.planModerate))))\n                                    &&\n                                    <FormControlLabel value=\"0\" control={<Radio />} label={translate('$__reader', 1)} />\n                                }\n                                {card.type !== 'plan' && ((CardAccess && parseInt(CardAccess.access) >= 1) || (permission && (AppAccess && AppAccess.plan && (AppAccess.planAdmin || AppAccess.planModerate))))\n                                    &&\n                                    <FormControlLabel value=\"1\" control={<Radio />} label={translate('$__executioner', 1)} />\n                                }\n                                {card.type !== 'plan' && card.type !== 'chatGroup' && ((CardAccess && parseInt(CardAccess.access) >= 2) || (permission && (AppAccess && AppAccess.plan && (AppAccess.planAdmin || AppAccess.planModerate))))\n                                    &&\n                                    <FormControlLabel value=\"2\" control={<Radio />} label={translate('$__collaborator', 1)} />\n                                }\n                                {((CardAccess && parseInt(CardAccess.access) >= 3) || (permission && (AppAccess && AppAccess.plan && (AppAccess.planAdmin || AppAccess.planModerate))))\n                                    &&\n                                    <FormControlLabel value=\"3\" control={<Radio />} label={translate('$__leadership', 1)} />\n                                }\n                                {card.type !== 'chatGroup' && ((CardAccess && parseInt(CardAccess.access) >= 4) || (permission && (AppAccess && AppAccess.plan && (AppAccess.planAdmin || AppAccess.planModerate))))\n                                    &&\n                                    <FormControlLabel value=\"4\" control={<Radio />} label={translate('$__supervisor', 1)} />\n                                }\n                                {((CardAccess && parseInt(CardAccess.access) >= 5) || (AppAccess && AppAccess.plan && (permission && (AppAccess.planAdmin || AppAccess.planModerate))))\n                                    &&\n                                    <FormControlLabel value=\"5\" control={<Radio />} label={translate('$__admin', 1)} />\n                                }\n                            </RadioGroup>\n                        </div>\n                    }\n                    {card.type !== 'chatGroup' ?\n                        <ul id=\"ACTIVE_USERS_LIST\" style={{ position: 'relative', float: 'left', width: '100%' }}>\n                            {userEditing.access === \"0\" &&\n                                <React.Fragment>\n                                    <li>{translate('$__readOnlyTodo', 1)}</li>\n                                    <li>{translate('$__readTimeline', 1)}</li>\n                                </React.Fragment>\n                            }\n                            {parseInt(userEditing.access) >= 1 &&\n                                <React.Fragment>\n                                    <li>{translate('$__executioner', 1)}</li>\n                                    <li>{translate('$__timeSheetRegister', 1)}</li>\n                                    <li>{translate('$__interactonTheTimeline', 1)}</li>\n                                </React.Fragment>\n                            }\n                            {parseInt(userEditing.access) > 1 &&\n                                <li>{translate('$__ExecuteAndCreateSubTasks', 1)}</li>\n                            }\n                            {parseInt(userEditing.access) > 2 &&\n                                <React.Fragment>\n                                    {sideModule.data.type === 'plan' &&\n                                        <React.Fragment>\n                                            <li>{translate('$__access', 1)} BRIGHT & CONNECTED</li>\n                                            <li>{translate('$__access', 1)} INSIGHTS</li>\n                                        </React.Fragment>\n                                    }\n                                    <li>{translate('$__updateDueDate', 1)}</li>\n                                    <li>{translate('$__updateTags', 1)}</li>\n                                    <li>{translate('$__updateIndicators', 1)}</li>\n                                    <li>{translate('$__addAndRemoveUsers', 1)}</li>\n                                    <li>{translate('$__defineResponsible', 1)}</li>\n                                </React.Fragment>\n                            }\n                            {parseInt(userEditing.access) > 3 &&\n                                <React.Fragment>\n                                    <li>{translate('$__updateData', 1)}</li>\n                                    <li>{translate('$__usersManager', 1)}</li>\n                                </React.Fragment>\n                            }\n                            {parseInt(userEditing.access) >= 4 &&\n                                <React.Fragment>\n                                    {sideModule.data.type === 'plan' &&\n                                        <React.Fragment>\n                                            <li>{translate('$__access', 1)} MATRIX SWOT</li>\n                                        </React.Fragment>\n                                    }\n                                    <li>{translate('$__settings', 1)}</li>\n                                </React.Fragment>\n                            }\n                            {parseInt(userEditing.access) === 5 &&\n                                <li>{translate('$__deleteActivity', 1)}</li>\n                            }\n                        </ul>\n                        :\n                        <ul id=\"ACTIVE_USERS_LIST\" style={{ position: 'relative', float: 'left', width: '100%' }}>\n                            {parseInt(userEditing.access) > 1 &&\n                                <li>{translate('$__viewAndInteract', 1)}</li>\n                            }\n                            {parseInt(userEditing.access) > 2 &&\n                                <React.Fragment>\n                                    <li>{translate('$__addAndRemoveUsers', 1)}</li>\n                                    <li>{translate('$__update', 1)}</li>\n                                </React.Fragment>\n                            }\n                            {parseInt(userEditing.access) === 5 &&\n                                <li>{translate('$__deleteGroup', 1)}</li>\n                            }\n                        </ul>\n                    }\n\n                    {card._users[userEditing._id] && !card._users[userEditing._id].isResponsible &&\n                        <div className={classes.switch}\n                            style={{\n                                position: 'relative',\n                                width: '100%',\n                                float: 'left',\n                                display: 'flex',\n                                alignItems: 'center',\n                                justifyContent: 'space-between'\n                            }}>\n                            <CustomButton\n                                transparent\n                                title={translate(\"$__setAsResponsible\")}\n                                text={translate(\"$__setAsResponsible\")}\n                                icon={\"admin_panel_settings\"}\n                                size={\"25px\"}\n                                onClick={() => {\n                                    appAlert({\n                                        message: translate('$__confirmSetAsResponsibleCard', 1),\n                                        variant: 'warning',\n                                        persist: false,\n                                        horizontal: 'right',\n                                        confirm: () => {\n                                            // console.log({\n                                            // cardId: sideModule.data._id,\n                                            // userId: userEditing._id\n                                            // })\n                                            isResponsible(props, {\n                                                cardId: sideModule.data._id,\n                                                userId: userEditing._id\n                                            })\n                                        }\n                                    })\n\n                                }}\n                            />\n                        </div>\n                    }\n                </div>\n\n            </React.Fragment>\n        )\n    }\n\n\n\n    return (\n        <div className={classes.root}>\n            {search &&\n                <div style={{\n                    marginTop: 15,\n                    width: \"100%\",\n                    padding: \"4px 15px\",\n                    fontSize: \"16px\",\n                    color: \"lightGray\"\n                }}>\n                    <TextField\n                        id={`quickUser_Search`}\n                        label={translate('$__searchByName', 1)}\n                        variant={customApp('fieldVariant')}\n                        name={'fullName'}\n                        InputLabelProps={{\n                            shrink: true,\n                        }}\n                        InputProps={{\n                            autoComplete: 'new-password',\n                            endAdornment: (\n                                <InputAdornment position=\"end\"\n                                    style={{ cursor: \"pointer\" }}\n                                    onClick={() => {\n                                        setSearchValue(\"\")\n                                        setSearch(false)\n                                    }}>\n                                    <Icon icon='close' />\n                                </InputAdornment>\n                            ),\n                            onChange: (d) => {\n                                setSearchValue(d.target.value)\n                            },\n                            onBlur: (d) => {\n\n                            }\n                        }}\n                        value={searchValue}\n                        placeholder={translate('$__searchByName', 1)}\n                        autoFocus\n                    />\n                </div>\n            }\n            {(searchValue === \"\" || !searchValue) ?\n                <React.Fragment>\n                    <fieldset>\n                        <legend style={{ color: customApp('color') }}>{translate(\"$__permittedUsers\", 1)}</legend>\n                        {users && users.map((u, i) => <React.Fragment key={u._id}>{renderUser(u)}</React.Fragment>)}\n                    </fieldset>\n                    {card && card._groups && Object.keys(card._groups).length > 0 ?\n                        <fieldset>\n                            <legend style={{ color: customApp('color') }}>{translate(\"$__permittedTeams\", 1)}</legend>\n                            {unSelectedGroups.filter(group => card._groups[group.value]).map((u, i) => <React.Fragment key={u}>{renderGroup(u)}</React.Fragment>)}\n                        </fieldset>\n                        : <React.Fragment></React.Fragment>}\n                </React.Fragment>\n                :\n                <React.Fragment></React.Fragment>\n            }\n            {/* {parentUsers && parentUsers.length > 0 &&\n                <fieldset\n                    style={{\n                        marginTop: '7px'\n                    }}\n                >\n                    <legend style={{ color: customApp('color') }}>{translate(\"$__activeExternalUsers\", 1)}</legend>\n                    {parentUsers.map((u, i) => <React.Fragment key={u._id}>{renderUser(u)}</React.Fragment>)}\n                </fieldset>\n            } */}\n            <fieldset\n                style={{\n                    // position: \"relative\",\n                    // padding: 7,\n                    // border: \"solid 1px rgba(0,0,0,0.5)\",\n                    display: \"flex\"\n                }}\n            >\n                <div style={{\n                    // backgroundColor: \"rgba(0,0,0,0.1)\",\n                    padding: 7,\n                    width: \"calc(50% - 4px)\",\n                    display: \"flex\",\n                    alignItems: \"center\",\n                    justifyContent: \"center\",\n                    cursor: \"pointer\",\n                    backgroundColor: view !== 'users' ? \"rgba(0,0,0,0.07)\" : customApp(\"color\"),\n                    color: view !== 'users' ? \"gray\" : \"#FFFFFF\"\n                }}>\n                    <div\n                        style={{\n                            display: \"flex\",\n                            flexDirection: \"column\",\n                            justifyContent: \"center\",\n                            alignItems: \"center\"\n                        }}\n                        onClick={() => {\n                            setView(\"users\")\n                        }}\n                    >\n                        <Icon\n                            icon={\"supervised_user_circle\"}\n                            size={\"33px\"}\n                            color={view !== 'users' ? null : \"#FFFFFF\"}\n                        />\n                        {translate(\"$__showUsers\")}\n                    </div>\n                </div>\n                <div\n                    style={{\n                        padding: 7,\n                        marginLeft: 7,\n                        width: \"calc(50% - 4px)\",\n                        cursor: \"pointer\",\n                        backgroundColor: view !== 'users' ? customApp(\"color\") : \"rgba(0,0,0,0.07)\",\n                        color: view !== 'users' ? \"#FFFFFF\" : \"gray\"\n                    }}\n                >\n                    <div\n                        style={{\n                            display: \"flex\",\n                            flexDirection: \"column\",\n                            justifyContent: \"center\",\n                            alignItems: \"center\",\n\n                        }}\n                        onClick={() => {\n                            setView(\"teams\")\n                        }}\n                    >\n                        <Icon\n                            icon={\"group_work\"}\n                            size={\"33px\"}\n                            color={view !== 'users' ? \"#FFFFFF\" : null}\n\n                        />\n                        {translate(\"$__showTeams\")}\n                    </div>\n                </div>\n            </fieldset>\n            {view === 'users' && unSelectedUsers && unSelectedUsers.length > 0 && !userEditing._id &&\n                <fieldset\n                    style={{\n                        marginTop: '7px'\n                    }}\n                >\n                    <legend style={{ color: customApp('color') }}>{translate(\"$__avaiableUsers\", 1)}</legend>\n                    <div>\n                        <CustomButton\n                            transparent\n                            title={translate(\"$__add\")}\n                            icon={\"person_add\"}\n                            text={translate(\"$__addAllUsers\")}\n                            size={\"20px\"}\n                            onClick={() => {\n                                addAllUsers(unSelectedUsers)\n                            }}\n                        />\n                    </div>\n                    {unSelectedUsers.sort((a, b) => {\n                        if (a.name.toLowerCase().trim() < b.name.toLowerCase().trim())\n                            return -1\n                        if (a.name.toLowerCase().trim() < b.name.toLowerCase().trim())\n                            return 1\n                        return 0\n                    }).map((u, i) => <React.Fragment key={u._id}>{renderUser(u, true)}</React.Fragment>)}\n                </fieldset>\n            }\n            {view !== 'users' && unSelectedGroups && unSelectedGroups.length > 0 && !userEditing._id &&\n                <fieldset\n                    style={{\n                        marginTop: '7px'\n                    }}\n                >\n                    <legend style={{ color: customApp('color') }}>{translate(\"$__avaiableTeams\", 1)}</legend>\n                    <div>\n                        <CustomButton\n                            transparent\n                            title={translate(\"$__add\")}\n                            icon={\"person_add\"}\n                            text={translate(\"$__addAllTeams\")}\n                            size={\"20px\"}\n                            onClick={() => {\n                                addAllGroups(unSelectedGroups)\n                            }}\n                        />\n                    </div>\n                    {unSelectedGroups.filter(group =>\n                        !card._groups\n                        || (card._groups && !card._groups[group.value])\n                    ).sort((a, b) => {\n                        if (a.label.toLowerCase().trim() < b.label.toLowerCase().trim())\n                            return -1\n                        if (a.label.toLowerCase().trim() < b.label.toLowerCase().trim())\n                            return 1\n                        return 0\n                    }).map((u, i) => <div style={{ width: \"100%\", padding: 7 }} key={u._id}>\n                        {renderGroup(u, true)}\n                    </div>)\n                    }\n                </fieldset>\n            }\n            {!search ?\n                <div\n                    style={{\n                        position: \"absolute\",\n                        right: 15,\n                        top: 0,\n                    }}\n                >\n                    <CustomButton\n                        title={translate(`$__search`, 1)}\n                        color={customApp(\"menu\")}\n                        icon={\"search\"}\n                        onClick={() => { setSearch(true) }}\n                        size={\"25px\"}\n                    />\n                </div>\n                :\n                <React.Fragment></React.Fragment>\n            }\n        </div>\n    )\n}\nconst mapStateToProps = (store, props) => ({\n    users: store.db.users,\n    cardUsers: store.db.cards[store.sideModule.data._id]\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst headerStyle = theme => ({\r\n  btClose: {\r\n    position: 'relative',\r\n    zIndex: theme.zIndex.drawer + 1,\r\n    right: '0',\r\n    top: '-64px',\r\n    backgroundColor: '#FFFFFF',\r\n    display: 'flex',\r\n  },\r\n  image: {\r\n    width: '100%',\r\n    backgroundColor: 'rgb(0,88,0)',\r\n    paddingTop: '45%'\r\n  },\r\n  data: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    overflowY: 'auto',\r\n    marginTop: '10px',\r\n    padding: '10px',\r\n    '& fieldset': {\r\n      border: 'solid 1px rgba(0,0,0,0.1)',\r\n      '& legend': {\r\n        marginBottom: '0px',\r\n        fontSize: '16px',\r\n        color: customApp('color')\r\n      }\r\n    }\r\n  },\r\n  loader: {\r\n    position: 'relative', width: '100%', height: '40px', textAlign: 'center',\r\n    '& .MuiCircularProgress-root': {\r\n      color: `${customApp('color')} !important`,\r\n    },\r\n  },\r\n  preview: {\r\n    listStyle: 'none',\r\n    padding: '0px',\r\n    '& li': {\r\n      padding: '7px',\r\n      backgroundColor: 'rgba(0,0,0,0.05)',\r\n      marginBottom: '15px',\r\n      boxShadow: '0 0 7px 3px rgba(0,0,0,0.1)',\r\n    }\r\n  },\r\n  previewTitle: {\r\n    position: 'relative',\r\n    width: '100%',\r\n    fontWeight: 'bold',\r\n    marginBottom: '7px'\r\n  },\r\n  feedTitle: {\r\n    position: 'relative', width: '100%', marginBottom: '7px', borderBottom: `solid 1px ${customApp('medium', 0.2)}`\r\n  },\r\n  feedContent: {\r\n    position: 'relative', width: '100%'\r\n  },\r\n  feedFooter: {\r\n    width: '100%',\r\n    textAlign: 'right',\r\n    height: '16px',\r\n    borderTop: '1px solid rgba(0,0,0,0.05)',\r\n    paddingTop: '3px'\r\n  },\r\n  feedDate: {\r\n    position: 'relative',\r\n    left: '0px',\r\n    fontSize: '12px',\r\n    float: 'left'\r\n  },\r\n  feedLink: {\r\n    position: 'relative',\r\n    left: '0px',\r\n    fontSize: '12px',\r\n    float: 'right'\r\n  },\r\n  switch: {\r\n    fontSize: '16px',\r\n    fontWeight: 'bold',\r\n    color: customApp('medium')\r\n  }\r\n\r\n});\r\n\r\nexport default headerStyle;\r\n","//REDUX\r\nimport reduxStore from \"store\"\r\n\r\n//FUNCTIONS\r\nimport api from \"api\"\r\nimport apims from \"apims\"\r\n\r\nconst saveFeed = async (props) => {\r\n    let newData = reduxStore.getState().sideModule.data\r\n\r\n    if (newData.status)\r\n        delete newData.status\r\n\r\n    let hashs = window.location.hash.split('/')\r\n    hashs[0] = hashs[0].replace('#', '')\r\n    try {\r\n        const response = await api.post('feed/save', {\r\n            ...newData,\r\n            feed: JSON.stringify(newData.feed),\r\n            _parent: hashs[0] || null,\r\n        })\r\n        if (response) {\r\n            if (!newData._id)\r\n                newData._id = response.data._id\r\n            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\r\n                ...reduxStore.getState().sideModule,\r\n                id: response.data._id,\r\n                data: {\r\n                    ...newData,\r\n                }\r\n            })\r\n            console.log(response)\r\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                ...reduxStore.getState().db,\r\n                feeds: {\r\n                    ...reduxStore.getState().db.feeds,\r\n                    [newData._id]: {\r\n                        ...newData,\r\n                        ...reduxStore.getState().db.feeds && reduxStore.getState().db.feeds[newData._id] ? reduxStore.getState().db.feeds[newData._id] : {},\r\n                        _parent: {\r\n                            ...reduxStore.getState().db.feeds && reduxStore.getState().db.feeds[newData._id] && reduxStore.getState().db.feeds[newData._id]._parent ? reduxStore.getState().db.feeds[newData._id]._parent : {},\r\n                            [hashs[0] || null]: {\r\n                                _id: response.data._id,\r\n                                idRel: response.data.idRel\r\n                            }\r\n                        }\r\n                    }\r\n                },\r\n            })\r\n            return true\r\n        }\r\n    } catch (e) {\r\n        return false\r\n    }\r\n}\r\n\r\nconst dbUpdateFeed = (props, data) => {\r\n    let newData = {\r\n        [data._id]: {\r\n            ...reduxStore.getState().db.feeds && reduxStore.getState().db.feeds[data._id] && reduxStore.getState().db.feeds[data._id].feed ? { feed: reduxStore.getState().db.feeds[data._id].feed } : {},\r\n            ...data.data,\r\n            _parent: {\r\n                ...reduxStore.getState().db.feeds && reduxStore.getState().db.feeds[data._id] && reduxStore.getState().db.feeds[data._id]._parent ? reduxStore.getState().db.feeds[data._id]._parent : {},\r\n                [data._parent]: {\r\n                    ...data.rel\r\n                }\r\n            },\r\n        }\r\n    }\r\n\r\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n        ...reduxStore.getState().db,\r\n        feeds: {\r\n            ...reduxStore.getState().db.feeds,\r\n            ...newData\r\n        }\r\n    });\r\n}\r\n\r\nconst loadFeeds = async (props, options = {}) => {\r\n    const load = new Promise(async (resolve, reject) => {\r\n        try {\r\n            let feeds = await apims.post(`/Feed_List_V2`, options)\r\n            if (feeds && feeds.data) {\r\n                let mountFeeds = {}\r\n                feeds.data.map(f => {\r\n                    let parents = {}\r\n                    if (f.parents && f.parents.length > 0)\r\n                        f.parents.map(p => {\r\n                            parents = {\r\n                                ...parents,\r\n                                [p._id]: {\r\n                                    idRel: p.idRel,\r\n                                    ...p.i\r\n                                }\r\n                            }\r\n                        })\r\n                    mountFeeds = {\r\n                        ...mountFeeds,\r\n                        [f.data._id]: {\r\n                            ...f.data,\r\n                            ...f.hide ? { hide: true } : {},\r\n                            feed: [{ ...f.cover }],\r\n                            _parent: parents,\r\n                            ...f.tags && f.tags.filter(a => a.value).length > 0 ? { _tags: f.tags } : {},\r\n                        }\r\n                    }\r\n                })\r\n\r\n                props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                    ...reduxStore.getState().db,\r\n                    feeds: {\r\n                        ...reduxStore.getState().db.feeds,\r\n                        ...mountFeeds,\r\n                    }\r\n                });\r\n                resolve(true)\r\n            }\r\n\r\n        } catch (e) {\r\n            console.group('loadFeeds::ERR::')\r\n            console.log(e)\r\n            console.groupEnd()\r\n            resolve(true)\r\n        }\r\n    })\r\n    const result = await load\r\n    return result\r\n}\r\n\r\nexport {\r\n    saveFeed,\r\n    dbUpdateFeed,\r\n    loadFeeds\r\n}","//CORE\nimport React from 'react'\nimport Moment from \"moment-timezone\"\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Autocomplete from \"components/AutoComplete\"\nimport CircularProgress from \"components/Progress/circular\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Icon from \"components/Icon\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\nimport Switch from \"components/Switch\"\nimport TagsInput from \"components/Tags/input\"\nimport TextField from \"components/TextField\"\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport { makeStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Feed.js\"\n\n//FUNCTIONS\nimport api from \"api/\"\nimport {\n    getAppAccess,\n    appAlert,\n    customApp,\n    translate,\n} from \"functions/\"\n\nimport {\n    getUserAccess,\n} from \"functions/cards\"\n\nimport {\n    saveFeed\n} from \"functions/feeds\"\n\nconst useStyles = makeStyles(styles)\n\nfunction Component(props) {\n    const classes = useStyles()\n    const { sideModule, session, db } = reduxStore.getState()\n    const data = sideModule.data || {}\n    const [reqSave, setReqSave] = React.useState(false)\n    const [feedLoading, setFeedLoading] = React.useState(false)\n    const [saveLoader, setSaveLoader] = React.useState(false)\n\n    const url = React.useRef()\n\n    let CardAccess = 0\n    let AppAccess = getAppAccess()\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    if (hashs[0] && hashs[0].length === 36)\n        CardAccess = getUserAccess(hashs[0])\n\n\n    const changeData = (d) => {\n        if (data.name === '' || (d.name === 'name' && d.value === '')) {\n            setReqSave(false)\n        } else if (data._lock && ((d.value && !sideModule.data[d.name]) || (sideModule.data[d.name] && sideModule.data[d.name] !== d.value))) {\n            setReqSave(true)\n        }\n\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...sideModule,\n            data: {\n                ...sideModule.data,\n                [d.name]: d.value,\n            }\n        })\n    }\n\n    const close = (force = false) => {\n        if (reqSave && !force) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n        }\n    }\n\n    const save = async (cl) => {\n        setReqSave(false)\n        if (!sideModule.data.name) {\n            appAlert({\n                message: translate('$__fillName', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n        } else {\n            const reqSave = await saveFeed(props, true)\n            if (reqSave) {\n                appAlert({\n                    message: translate('$__feedSigned', 1),\n                    variant: null,\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n                if (cl)\n                    close(true)\n            } else {\n                appAlert({\n                    message: translate('$__AnErrorHasOccurredPleaseTryAgain', 1),\n                    variant: 'error',\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n                setReqSave(true)\n            }\n        }\n    }\n\n    const feedValidate = async (str) => {\n        if (str)\n            if (str.indexOf('http') === -1) {\n                appAlert({\n                    message: `${translate('$__invalidUrl', 1)}: ${translate('$__urlMustContainHttps', 1)}`,\n                    variant: 'error',\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                    ...sideModule,\n                    data: {\n                        ...sideModule.data,\n                        url: '',\n                    }\n                })\n            } else {\n                var pattern = new RegExp('^(https?:\\\\/\\\\/)?' + // protocol\n                    '((([a-z\\\\d]([a-z\\\\d-]*[a-z\\\\d])*)\\\\.)+[a-z]{2,}|' + // domain name\n                    '((\\\\d{1,3}\\\\.){3}\\\\d{1,3}))' + // OR ip (v4) address\n                    '(\\\\:\\\\d+)?(\\\\/[-a-z\\\\d%_.~+]*)*' + // port and path\n                    '(\\\\?[&a-z\\\\d%_.~+=-]*)?' + // query string\n                    '(\\\\@[a-z\\\\d%_.~+=-]*)?' + // query string\n                    '(\\\\#[-a-z\\\\d_]*)?$', 'i') // fragment locator\n\n                if (!!pattern.test(str)) {\n                    setFeedLoading(true)\n                    let urlToVerify = str\n                    if (urlToVerify[str.length - 1] === '/')\n                        urlToVerify = urlToVerify.substring(0, str.length - 1)\n                    if (urlToVerify.indexOf(\"http://\") === '/')\n                        urlToVerify = urlToVerify.replace(\"http://\", \"https://\")\n\n                    if (sideModule.data.type === 'feed')\n                        try {\n                            const result = await api.post('/feed/exist', {\n                                url: str\n                            })\n                            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                ...sideModule,\n                                data: {\n                                    ...sideModule.data,\n                                    _id: result.data.id,\n                                    url: urlToVerify,\n                                    _lock: true,\n                                    feed: result.data.feed,\n                                    name: result.data.title,\n                                    customTitle: result.data.customTitle,\n                                    customDescription: result.data.customDescription,\n                                }\n                            })\n                            if (result)\n                                setFeedLoading(false)\n                            if (result.data.title)\n                                setReqSave(true)\n                        } catch (e) {\n                            feedInsert(str)\n                        }\n                    if (sideModule.data.type === 'link')\n                        try {\n                            let hashs = window.location.hash.split('/')\n                            hashs[0] = hashs[0].replace('#', '')\n                            const result = await api.post('/link/exist', {\n                                idRel: hashs[0],\n                                url: urlToVerify\n                            })\n                            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                ...reduxStore.getState().sideModule,\n                                id: 'new',\n                                activeModule: 'cardEdit',\n                                db: 'cards',\n                                data: {\n                                    _id: 'new',\n                                    type: 'link',\n                                    name: result.data.title,\n                                    description: result.data.contentSnippet,\n                                    image: result.data.img,\n                                    url: result.data.link,\n                                    content: result.data.article,\n\n                                }\n                            })\n                            if (result)\n                                setFeedLoading(false)\n                            if (result.data.title)\n                                setReqSave(true)\n                        } catch (e) {\n                            appAlert({\n                                message: `${translate('$__invalidFeedUrl', 1)}: ${translate('$__pleaseVerifyTheFeedAddress', 1)}`,\n                                variant: 'error',\n                                persist: false,\n                                horizontal: 'right',\n                                confirm: null\n                            })\n                        }\n                }\n                return\n            }\n        return false\n    }\n\n    const feedInsert = async (str) => {\n        try {\n            const result = await api.post('/feed/request/', {\n                url: str\n            })\n            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                ...sideModule,\n                data: {\n                    ...sideModule.data,\n                    _id: result.data.id,\n                    url: str,\n                    _lock: true,\n                    feed: result.data.feed,\n                    name: result.data.title,\n                    customTitle: result.data.customTitle,\n                    customDescription: result.data.customDescription,\n                }\n            })\n            if (result)\n                setFeedLoading(false)\n            if (result.data.title)\n                setReqSave(true)\n        } catch (e) {\n            appAlert({\n                message: `${translate('$__invalidFeedUrl', 1)}: ${translate('$__pleaseVerifyTheFeedAddress', 1)}`,\n                variant: 'error',\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n        }\n    }\n\n    let permission = props.permission ? props.permission : false\n    if (!permission && parseInt(CardAccess) >= 3)\n        permission = true\n\n    return (\n        <div>\n            <div className={classes.btClose}>\n                <div\n                    style={{\n                        position: 'fixed',\n                        display: 'inline-flex',\n                        paddingLeft: '10px',\n                        top: '7px',\n                        right: 0,\n                        backgroundColor: \"#FFFFFF\"\n                    }}>\n                    {(permission && reqSave) &&\n                        <SideModuleCloseAndSave\n                            save={reqSave ? () => {\n                                // setSaveLoader(true)\n                                save()\n                            } : null}\n                            saveClose={reqSave ? () => {\n                                // setSaveLoader(true)\n                                save(true)\n                            } : null}\n                            saveLoader={saveLoader}\n                            close={() => {\n                                if (props.onClose)\n                                    props.onClose()\n                            }}\n                        />\n                    }\n                    <CustomButton\n                        title={translate(`$__close`, 1)}\n                        color='lightgrey'\n                        icon={'cancel'}\n                        onClick={() => {\n                            if (props.onClose)\n                                props.onClose()\n                        }}\n                        size={'25px'}\n                    />\n                </div>\n            </div>\n            <div className={classes.data}>\n                {!data._lock ?\n                    <TextField\n                        label={translate('$__feedUrl', '*')}\n                        variant={customApp('fieldVariant')}\n                        ref={url}\n                        name=\"url\"\n                        InputProps={{\n                            autoComplete: 'new-password',\n                            multiline: true,\n                            endAdornment: (\n                                <InputAdornment position=\"end\">\n                                    <Icon icon='rss_feed' />\n                                </InputAdornment>\n                            ),\n                            onChange: (d) => {\n                                changeData(d.target)\n                            },\n                            onBlur: (d) => {\n                                feedValidate(d.target.value)\n                            }\n                        }}\n                        value={data && data.url ? data.url : ''}\n                        placeholder={'http://www.domain.xpto/rss...'}\n                        disabled={data._lock ? true : false}\n                    />\n                    :\n                    <React.Fragment>\n                        <TextField\n                            label={translate('$__titleOfFeed', 1)}\n                            variant={customApp('fieldVariant')}\n                            name={'name'}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='view_headline' />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.name ? data.name : ''}\n                            placeholder={translate('$__titleOfFeed_placeholder')}\n                            {...(\n                                (session\n                                    && session.account !== \"7806912b-4c7d-4f4f-b9e0-b93fc8f08776\"\n                                )\n                                ||\n                                (\n                                    data && data.name\n                                )\n                            ) ? { disabled: true } : {}}\n                        />\n                        <TextField\n                            label={translate('$__customTitle', 1)}\n                            variant={customApp('fieldVariant')}\n                            name={'customTitle'}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='title' />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.customTitle ? data.customTitle : ''}\n                            placeholder={translate('$__customTitle', 1)}\n                        />\n                        {session && session.account !== \"7806912b-4c7d-4f4f-b9e0-b93fc8f08776\" ?\n                            <React.Fragment>\n                                <TextField\n                                    label={translate('$__nameOfFontData', 1)}\n                                    variant={customApp('fieldVariant')}\n                                    name={'font'}\n                                    InputLabelProps={{\n                                        shrink: true,\n                                    }}\n                                    InputProps={{\n                                        autoComplete: 'new-password',\n                                        endAdornment: (\n                                            <InputAdornment position=\"end\">\n                                                <Icon icon='copyright' />\n                                            </InputAdornment>\n                                        ),\n                                        onChange: (d) => {\n                                            changeData(d.target)\n                                        },\n                                    }}\n                                    value={data && data.font ? data.font : ''}\n                                    placeholder={translate('$__nameOfFontData', 1)}\n                                />\n                                <TextField\n                                    label={translate('$__descriptionOfRss', 1)}\n                                    variant={customApp('fieldVariant')}\n                                    name={'description'}\n                                    InputLabelProps={{\n                                        shrink: true,\n                                    }}\n                                    InputProps={{\n                                        autoComplete: 'new-password',\n                                        endAdornment: (\n                                            <InputAdornment position=\"end\">\n                                                <Icon icon='subtitles' />\n                                            </InputAdornment>\n                                        ),\n                                        onChange: (d) => {\n                                            changeData(d.target)\n                                        },\n                                    }}\n                                    value={data && data.description ? data.description : ''}\n                                    placeholder={translate('$__descriptionOfRss', 1)}\n                                />\n                            </React.Fragment>\n                            : <React.Fragment></React.Fragment>\n                        }\n                        <TextField\n                            label={translate('$__customDescription', 1)}\n                            variant={customApp('fieldVariant')}\n                            name={'customDescription'}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='subtitles' />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.customDescription ? data.customDescription : ''}\n                            placeholder={translate('$__customDescription', 1)}\n                        />\n                        <TextField\n                            label={translate('$__url', '*')}\n                            variant={customApp('fieldVariant')}\n                            ref={url}\n                            name=\"url\"\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                multiline: true,\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='http' />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                                onBlur: (d) => {\n                                    feedValidate(d.target.value)\n                                }\n                            }}\n                            value={data && data.url ? data.url : ''}\n                            placeholder={'http://www.domain.xpto/rss...'}\n                            disabled={data._lock ? true : false}\n                        />\n                        {(AppAccess && AppAccess.feed && (\n                            AppAccess.feedAdmin\n                            || AppAccess.feedModerate\n                        )) &&\n                            <fieldset style={{ marginBottom: \"14px\" }}>\n                                <legend>{translate(\"$__tags\", 1)}</legend>\n                                <TagsInput\n                                    data={{\n                                        values: data._tags ? data._tags : [],\n                                    }}\n                                    callBack={(v) => {\n                                        changeData({ name: \"_tags\", value: v })\n                                    }}\n                                />\n                            </fieldset>\n                        }\n                        {AppAccess && AppAccess.feed && AppAccess.feedAdmin ?\n                            <fieldset style={{ marginBottom: \"14px\" }}>\n                                <Autocomplete\n                                    id=\"combo-box-demo\"\n                                    options={db.plans}\n                                    getOptionLabel={(option) => translate(option.label, 1)}\n                                    style={{ width: \"100%\" }}\n                                    name=\"plans\"\n                                    disableClearable\n                                    value={\n                                        data\n                                            && data.plans\n                                            && db.plans\n                                            ? db.plans.filter(a =>\n                                                String(a.value) === String(data.plans)\n                                            )[0]\n                                            : db.plans[0]\n                                    }\n                                    renderInput={(params) =>\n                                        <TextField\n                                            {...params}\n                                            label={translate(\"$__avaiablefromplan\", 1)}\n                                            variant={customApp(\"fieldVariant\")}\n                                            value={\n                                                data\n                                                    && data.plans\n                                                    && db.plans\n                                                    ? db.plans.filter(a =>\n                                                        String(a.value) === String(data.plans)\n                                                    )[0]\n                                                    : db.plans[0]\n                                            }\n                                        />\n                                    }\n                                    onChange={\n                                        (d, v) => {\n                                            if (permission)\n                                                changeData({ name: \"plans\", value: v[\"value\"] })\n                                        }\n                                    }\n                                />\n                            </fieldset>\n                            : <React.Fragment></React.Fragment>\n                        }\n                        <div className={classes.switch}>\n                            <Switch\n                                checked={data.private ? true : false}\n                                onChange={(d) => {\n                                    changeData({\n                                        name: 'private',\n                                        value: data.private ? false : true\n                                    })\n                                }}\n                                name=\"checkedA\"\n                                inputProps={{ 'aria-label': 'secondary checkbox' }}\n                            />\n                            {translate('$__private', 1)}\n                        </div>\n\n                    </React.Fragment>\n                }\n\n                {!data._lock && !feedLoading &&\n                    <IconButton text={translate(sideModule.data.type === 'link' ? \"$__validUrl\" : \"$__validFeedUrl\", 1)} icon=\"check\" onClick={() => feedValidate(url.current.value)} />\n                }\n                {feedLoading &&\n                    <div className={classes.loader}>\n                        <CircularProgress />\n                    </div>\n                }\n                {data.feed && data.feed.length > 0 &&\n                    <ul className={classes.preview}>\n                        <div className={classes.previewTitle}>{translate('$__preview', 1)}</div>\n                        {data.feed.map((f, i) => (\n                            <li\n                                key={i}\n                            >\n                                {f && f.title &&\n                                    <div\n                                        dangerouslySetInnerHTML={{ __html: f.title }}\n                                        className={classes.feedTitle}\n                                    />\n                                }\n                                <div\n                                    dangerouslySetInnerHTML={{ __html: f.contentSnippet }}\n                                    className={classes.feedContent}\n                                />\n                                <div className={classes.feedFooter}>\n                                    <div className={classes.feedDate}>{Moment(f.pubDate).format('DD/MM/YYYY HH:MM')}</div>\n                                    <div className={classes.feedLink}>\n                                        <a href={f.link} target=\"_blank\">{translate('$__openLink', '*')}</a>\n                                    </div>\n                                </div>\n                            </li>\n                        ))}\n                    </ul>\n                }\n            </div>\n        </div>\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)","//CORE\nimport React from 'react'\nimport Moment from \"moment-timezone\"\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport CircularProgress from \"components/Progress/circular\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Icon from \"components/Icon\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport Switch from \"components/Switch\"\nimport TextField from \"components/TextField\"\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport { makeStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Feed.js\"\n\n//FUNCTIONS\nimport api from \"api/\"\nimport { translate, customApp, appAlert, } from \"functions/\"\nimport {\n    getUserAccess,\n} from \"functions/cards\"\nimport { saveFeed } from \"functions/feeds\"\n\nconst useStyles = makeStyles(styles)\n\nfunction Component(props) {\n    const classes = useStyles()\n    const { sideModule } = reduxStore.getState()\n    const data = sideModule.data || {}\n    const [reqSave, setReqSave] = React.useState(false)\n    const [feedLoading, setFeedLoading] = React.useState(false)\n    const [saveLoader, setSaveLoader] = React.useState(false)\n\n    const url = React.useRef()\n\n    let CardAccess = 0\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    if (hashs[0] && hashs[0].length === 36)\n        CardAccess = getUserAccess(hashs[0])\n\n\n    const changeData = (d) => {\n        if (data.name === '' || (d.name === 'name' && d.value === '')) {\n            setReqSave(false)\n        } else if (data._lock && ((d.value && !sideModule.data[d.name]) || (sideModule.data[d.name] && sideModule.data[d.name] !== d.value))) {\n            setReqSave(true)\n        }\n\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...sideModule,\n            data: {\n                ...sideModule.data,\n                [d.name]: d.value,\n            }\n        })\n    }\n\n    const close = (force = false) => {\n        if (reqSave && !force) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n        }\n    }\n\n    const save = async (cl) => {\n        setReqSave(false)\n        if (!sideModule.data.name) {\n            appAlert({\n                message: translate('$__fillName', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n        } else {\n            const reqSave = await saveFeed(props, true)\n            if (reqSave) {\n                appAlert({\n                    message: translate('$__feedSigned', 1),\n                    variant: null,\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n                if (cl)\n                    close(true)\n            } else {\n                appAlert({\n                    message: translate('$__AnErrorHasOccurredPleaseTryAgain', 1),\n                    variant: 'error',\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n                setReqSave(true)\n            }\n        }\n    }\n\n    const urlValidate = async (lk) => {\n        let str = lk.trim()\n        if (str)\n            if (str.indexOf('http') === -1) {\n                appAlert({\n                    message: `${translate('$__invalidUrl', 1)}: ${translate('$__urlMustContainHttps', 1)}`,\n                    variant: 'error',\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                    ...sideModule,\n                    data: {\n                        ...sideModule.data,\n                        url: '',\n                    }\n                })\n            } else {\n                var pattern = new RegExp('^(https?:\\\\/\\\\/)?' + // protocol\n                    '((([a-z\\\\d]([a-z\\\\d-]*[a-z\\\\d])*)\\\\.)+[a-z]{2,}|' + // domain name\n                    '((\\\\d{1,3}\\\\.){3}\\\\d{1,3}))' + // OR ip (v4) address\n                    '(\\\\:\\\\d+)?(\\\\/[-a-z\\\\d%_.~+]*)*' + // port and path\n                    '(\\\\?[&a-z\\\\d%_.~+=-]*)?' + // query string\n                    '(\\\\#[-a-z\\\\d_]*)?$', 'i') // fragment locator\n\n                if (!!pattern.test(str)) {\n                    setFeedLoading(true)\n                    try {\n                        let hashs = window.location.hash.split('/')\n                        hashs[0] = hashs[0].replace('#', '')\n                        const result = await api.post('/link/exist', {\n                            idRel: hashs[0],\n                            url: str\n                        })\n                        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                            ...reduxStore.getState().sideModule,\n                            id: 'new',\n                            activeModule: 'cardEdit',\n                            db: 'cards',\n                            data: {\n                                _id: 'new',\n                                type: 'link',\n                                name: result.data.title,\n                                description: result.data.contentSnippet,\n                                image: result.data.img,\n                                url: result.data.link,\n                                content: result.data.article,\n\n                            }\n                        })\n                        if (result)\n                            setFeedLoading(false)\n                        if (result.data.title)\n                            setReqSave(true)\n                    } catch (e) {\n                        appAlert({\n                            message: `${translate('$__invalidFeedUrl', 1)}: ${translate('$__pleaseVerifyTheFeedAddress', 1)}`,\n                            variant: 'error',\n                            persist: false,\n                            horizontal: 'right',\n                            confirm: null\n                        })\n                    }\n                } else {\n                    appAlert({\n                        message: `${translate('$__invalidUrl', 1)}: ${translate('$__pleaseVerifyTheUrl', 1)}`,\n                        variant: 'error',\n                        persist: false,\n                        horizontal: 'right',\n                        confirm: null\n                    })\n                    props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                        ...sideModule,\n                        data: {\n                            ...sideModule.data,\n                            url: '',\n                        }\n                    })\n                }\n                return true\n            }\n        return false\n    }\n\n    const feedInsert = async (str) => {\n        try {\n            const result = await api.post('/feed/request/', {\n                url: str\n            })\n            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                ...sideModule,\n                data: {\n                    ...sideModule.data,\n                    _id: result.data.id,\n                    url: str,\n                    _lock: true,\n                    feed: result.data.feed,\n                    name: result.data.title,\n                    customTitle: result.data.customTitle,\n                    customDescription: result.data.customDescription,\n                }\n            })\n            if (result)\n                setFeedLoading(false)\n            if (result.data.title)\n                setReqSave(true)\n        } catch (e) {\n            appAlert({\n                message: `${translate('$__invalidFeedUrl', 1)}: ${translate('$__pleaseVerifyTheFeedAddress', 1)}`,\n                variant: 'error',\n                persist: false,\n                horizontal: 'right',\n                confirm: null\n            })\n        }\n    }\n\n    let permission = props.permission ? props.permission : false\n    if (!permission && parseInt(CardAccess) >= 3)\n        permission = true\n\n    return (\n        <div>\n            <div className={classes.btClose}>\n                <div\n                    style={{\n                        position: 'fixed',\n                        display: 'inline-flex',\n                        paddingLeft: '10px',\n                        top: '7px',\n                        right: 0,\n                        backgroundColor: \"#FFFFFF\"\n                    }}>\n                    {saveLoader &&\n                        <React.Fragment>\n                            <CircularProgress size=\"25px\" />\n                        </React.Fragment>\n                    }\n                    {(permission && reqSave) &&\n                        <React.Fragment>\n                            <CustomButton\n                                title={translate(`$__save`, '*')}\n                                color={customApp('color')}\n                                icon={'save'}\n                                onClick={() => { save() }}\n                                size={'25px'}\n                            />\n                            <CustomButton\n                                title={translate(`$__saveAndClose`, 1)}\n                                color='green'\n                                icon={'playlist_add_check'}\n                                onClick={() => { save(true) }}\n                                size={'25px'}\n                            />\n                        </React.Fragment>\n                    }\n                    <CustomButton\n                        title={translate(`$__close`, 1)}\n                        color='lightgrey'\n                        icon={'cancel'}\n                        onClick={() => {\n                            if (props.onClose)\n                                props.onClose()\n                        }}\n                        size={'25px'}\n                    />\n                </div>\n            </div>\n            <div className={classes.data}>\n                {data._lock &&\n                    <React.Fragment>\n                        <TextField\n                            label={translate('$__titleOfUrl', 1)}\n                            variant={customApp('fieldVariant')}\n                            name={'name'}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='view_headline' />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.name ? data.name : ''}\n                            placeholder={translate('$__titleOfUrl_placeholder')}\n                            disabled\n                        />\n                        <TextField\n                            label={translate('$__customTitle', 1)}\n                            variant={customApp('fieldVariant')}\n                            name={'customTitle'}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='title' />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.customTitle ? data.customTitle : ''}\n                            placeholder={translate('$__customTitle', 1)}\n                        />\n                        <TextField\n                            label={translate('$__nameOfFontData', 1)}\n                            variant={customApp('fieldVariant')}\n                            name={'font'}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='copyright' />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.font ? data.font : ''}\n                            placeholder={translate('$__nameOfFontData', 1)}\n                        />\n                        <TextField\n                            label={translate('$__descriptionOfUrl', 1)}\n                            variant={customApp('fieldVariant')}\n                            name={'description'}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='subtitles' />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.description ? data.description : ''}\n                            placeholder={translate('$__descriptionOfUrl', 1)}\n                        />\n                        <TextField\n                            label={translate('$__customDescription', 1)}\n                            variant={customApp('fieldVariant')}\n                            name={'customDescription'}\n                            InputLabelProps={{\n                                shrink: true,\n                            }}\n                            InputProps={{\n                                autoComplete: 'new-password',\n                                endAdornment: (\n                                    <InputAdornment position=\"end\">\n                                        <Icon icon='subtitles' />\n                                    </InputAdornment>\n                                ),\n                                onChange: (d) => {\n                                    changeData(d.target)\n                                },\n                            }}\n                            value={data && data.customDescription ? data.customDescription : ''}\n                            placeholder={translate('$__customDescription', 1)}\n                        />\n                        <div className={classes.switch}>\n                            <Switch\n                                checked={data.private ? true : false}\n                                onChange={(d) => {\n                                    changeData({\n                                        name: 'private',\n                                        value: data.private ? false : true\n                                    })\n                                }}\n                                name=\"checkedA\"\n                                inputProps={{ 'aria-label': 'secondary checkbox' }}\n                            />\n                            {translate('$__private', 1)}\n                        </div>\n                    </React.Fragment>\n                }\n                <TextField\n                    label={translate('$__url', '*')}\n                    variant={customApp('fieldVariant')}\n                    ref={url}\n                    name=\"url\"\n                    InputProps={{\n                        autoComplete: 'new-password',\n                        multiline: true,\n                        endAdornment: (\n                            <InputAdornment position=\"end\">\n                                <Icon icon='http' />\n                            </InputAdornment>\n                        ),\n                        onChange: (d) => {\n                            changeData(d.target)\n                        },\n                        onBlur: (d) => {\n                            urlValidate(d.target.value)\n                        }\n                    }}\n                    value={data && data.url ? data.url : ''}\n                    placeholder={'http://www.domain.com/'}\n                    disabled={data._lock ? true : false}\n                />\n                {!data._lock && !feedLoading &&\n                    <IconButton text={translate(\"$__validUrl\", 1)} icon=\"check\" onClick={() => urlValidate(url.current.value)} />\n                }\n                {feedLoading &&\n                    <div className={classes.loader}>\n                        <CircularProgress />\n                    </div>\n                }\n                {data.feed && data.feed.length > 0 &&\n                    <ul className={classes.preview}>\n                        <div className={classes.previewTitle}>{translate('$__preview', 1)}</div>\n                        {data.feed.map((f, i) => (\n                            <li\n                                key={i}\n                            >\n                                {f && f.title &&\n                                    <div\n                                        dangerouslySetInnerHTML={{ __html: f.title }}\n                                        className={classes.feedTitle}\n                                    />\n                                }\n                                <div\n                                    dangerouslySetInnerHTML={{ __html: f.contentSnippet }}\n                                    className={classes.feedContent}\n                                />\n                                <div className={classes.feedFooter}>\n                                    <div className={classes.feedDate}>{Moment(f.pubDate).format('DD/MM/YYYY HH:MM')}</div>\n                                    <div className={classes.feedLink}>\n                                        <a href={f.link} target=\"_blank\">{translate('$__openLink', '*')}</a>\n                                    </div>\n                                </div>\n                            </li>\n                        ))}\n                    </ul>\n                }\n            </div>\n        </div>\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)","// ID_CREATED*************************\n\n//CORE\nimport React from \"react\"\n\n//REDUX\nimport {\n    connect\n} from \"react-redux\"\nimport {\n    bindActionCreators\n} from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\n\n//@MATERIAL\nimport {\n    withStyles\n} from \"@material-ui/core/styles\"\nimport styles from \"./sideModule.css.js\"\n\n//IMPORT GENERICAL MODULES\nimport Timeline from \"components/Timeline\"\n\n//IMPORT MODULES TO USER\nimport EditUser from \"components/User/edit\"\nimport UserAccess from \"components/User/access\"\nimport TwoFactor from \"components/User/TwoFactor\"\nimport UserSettings from \"components/User/Settings\"\nimport AccountSettings from \"components/Account/Settings\"\nimport UserMobile from \"components/User/Mobile\"\nimport MenuButton from \"./MenuButton\"\n\n//IMPORT MODULES TO CARDS\nimport CardDelete from \"components/Card/Delete\"\nimport CardEdit from \"components/Card/edit\"\nimport CardKPI from \"components/Card/kpi\"\nimport CardResume from \"components/Card/resume\"\nimport CardSettings from \"components/Card/settings\"\nimport Catenation from \"components/Catenation\"\nimport Checklist from \"components/Checklist\"\nimport ColumnEdit from \"components/Columns/edit\"\nimport Files from \"components/Files/list\"\nimport Icon from \"components/Icon\"\nimport Recurrence from \"components/Recurrence/list\"\nimport SendTo from \"components/SendTo/\"\nimport TimerLog from \"components/Timer/log\"\nimport UserDelete from \"components/User/Delete\"\nimport Users from \"components/User/in\"\n\n//IMPORT MODULES TO FEED\nimport FeedEdit from \"components/Feed/edit\"\nimport LinkEdit from \"components/Link/edit\"\n\n//FUNCTIONS\nimport {\n    getAppAccess,\n    appAlert,\n    customApp,\n    translate,\n} from \"functions/\"\n\nimport {\n    getUserAccess,\n    planMyAccountVerify,\n    updateCardData,\n    verifyTemplate,\n} from \"functions/cards\"\n\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\nfunction Component(props) {\n    const { sideModule, db, session } = reduxStore.getState()\n    const [reqSave, setReqSave] = React.useState(false)\n    const [mounted, setMounted] = React.useState(false)\n\n    React.useEffect(() => {\n        if (sideModule.id)\n            if (!mounted && sideModule.activeModule === 'timeline') {\n                setMounted(true)\n                setReqSave(false)\n            }\n\n        return () => { }\n\n    }, [sideModule])\n\n    if (!sideModule.data || !sideModule.data.type || db.dataType.filter(a => a.name === sideModule.data.type).length === 0)\n        return null\n\n\n    if (sideModule && !sideModule.id)\n        return null\n\n\n    const { classes } = props\n    const { data } = sideModule\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    let type = db.cards[data._id] ? 'cards' : 'users'\n\n    let AppAccess = getAppAccess()\n    let CardAccess = getUserAccess(sideModule.id)\n\n    let permission = false\n\n    if (data && data._planId && (!db.cards[data._planId] || !planMyAccountVerify(data._planId)))\n        permission = false\n\n    permission = (\n        sideModule &&\n        (\n            sideModule.id === 'new'\n            ||\n            (\n                (\n                    (\n                        data.type === 'user'\n                        || data.type === 'client'\n                    )\n                    &&\n                    AppAccess\n                    &&\n                    (AppAccess.user\n                        &&\n                        (\n                            AppAccess.userAdmin\n                            || AppAccess.userModerate\n                        )\n                    )\n                )\n                ||\n                (\n                    (\n                        data.type !== 'user'\n                        && data.type !== 'client'\n                        && data.type !== 'chatGroup'\n                    )\n                    &&\n                    (\n                        AppAccess\n                        &&\n                        (AppAccess.owner\n                            ||\n                            (\n                                AppAccess.plan\n                                && (\n                                    AppAccess.planAdmin\n                                    || AppAccess.planModerate\n                                )\n                            )\n                        )\n                    )\n                )\n                ||\n                (\n                    (data.type === 'chatGroup')\n                    && (\n                        !data.client\n                        ||\n                        (\n                            data.client\n                            && db.users[data.client]\n                        )\n                    )\n                    && (\n                        AppAccess\n                        &&\n                        (AppAccess.owner\n                            ||\n                            (\n                                AppAccess.plan\n                                && (\n                                    AppAccess.planAdmin\n                                    || AppAccess.planModerate\n                                )\n                            )\n                        )\n                    )\n                )\n            )\n        )\n    ) ? true : false\n\n\n\n    if (!permission && parseInt(CardAccess) >= 4)\n        permission = true\n\n    if (!permission && planMyAccountVerify(data._planId) && AppAccess && AppAccess.admin && AppAccess.plan && (AppAccess.planAdmin || AppAccess.planModerate))\n        permission = true\n\n    const MOD = [\n        //USER\n        // {\n        //     name: 'resumeUser',\n        //     icon: 'blur_on',\n        //     title: 'resume',\n        //     resume: true,\n        //     reqId: true,\n        //     module: ResumeUser,\n        //     closeOption: true,\n        //     permission: 2,\n        // },\n        {\n            name: 'userEdit',\n            icon: 'notes',\n            title: '$__userEdit',\n            reqId: false,\n            module: EditUser,\n            closeOption: false,\n            permission: 0,\n        },\n\n        //FEED\n        // {\n        //     name: 'resumeFeed',\n        //     icon: 'blur_on',\n        //     title: 'resume',\n        //     resume: true,\n        //     reqId: true,\n        //     module: ResumeFeed,\n        //     closeOption: true,\n        //     permission: 3,\n        // },\n        {\n            name: 'feedEdit',\n            icon: 'rss_feed',\n            title: '$__feedEdit',\n            reqId: false,\n            module: FeedEdit,\n            closeOption: false,\n            permission: 3,\n            template: true,\n        },\n        {\n            name: 'link',\n            icon: 'link',\n            title: '$__link',\n            reqId: false,\n            module: LinkEdit,\n            permission: 3,\n            closeOption: false,\n            hide: true,\n            template: true,\n        },\n        {\n            name: 'timeline',\n            icon: 'timeline',\n            title: '$__timeline',\n            reqId: true,\n            module: Timeline,\n            props: {\n                type: 'comment',\n                nodeId: sideModule.id,\n                db: 'cards',\n                loadTimeline: true,\n                disabledSend: String(CardAccess) === \"0\" ? true : false\n            },\n            closeOption: true,\n            permission: 0,\n            count: 'comment'\n        },\n        {\n            name: 'log',\n            icon: 'history',\n            title: '$__log',\n            reqId: true,\n            module: Timeline,\n            props: {\n                type: 'log',\n                nodeId: sideModule.id,\n                db: 'cards',\n                loadTimeline: true,\n                noSearch: true,\n                disabledSend: true\n            },\n            closeOption: true,\n            permission: 0,\n            count: 'log'\n        },\n        {\n            name: 'checklist',\n            icon: 'checklist',\n            title: '$__list',\n            reqId: true,\n            module: Checklist,\n            closeOption: true,\n            permission: 1,\n            props: {\n                nodeId: sideModule.data._id,\n                db: sideModule.db ? sideModule.db : 'cards',\n                permission: permission,\n                showProgress: true,\n            },\n            template: true,\n        },\n        ...(\n            data.type.indexOf(\"guideline\") > -1\n            || data.type.indexOf(\"objective\") > -1\n            || data.type.indexOf(\"goal\") > -1\n        ) ? [{\n            name: 'catenation',\n            icon: 'account_tree',\n            title: '$__catenation',\n            reqId: true,\n            module: Catenation,\n            closeOption: true,\n            permission: 2,\n            props: {\n                nodeId: sideModule.data._id,\n                db: sideModule.db ? sideModule.db : 'cards',\n            },\n            template: true,\n        }] : [],\n        {\n            name: 'recurrence',\n            icon: 'update',\n            title: '$__recurrence',\n            reqId: true,\n            module: Recurrence,\n            closeOption: true,\n            permission: 3,\n            props: {\n                nodeId: sideModule.data._id,\n                db: sideModule.db ? sideModule.db : 'cards',\n            },\n            template: true,\n        },\n        {\n            name: 'files',\n            icon: 'folder',\n            title: '$__files',\n            reqId: true,\n            module: Files,\n            closeOption: true,\n            permission: 3,\n            props: {\n                nodeId: sideModule.id,\n                db: sideModule.db\n            },\n        },\n        {\n            name: 'access',\n            icon: session._id === data._id ? 'vpn_key' : 'security',\n            title: session._id === data._id ? '$__changePassword' : '$__access',\n            reqId: true,\n            module: UserAccess,\n            closeOption: false,\n            permission: session._id === data._id ? 0 : 4,\n            // ownerLock: true,\n        },\n        ...(session._id === data._id) ?\n            [{\n                name: 'twoFactor',\n                icon: 'pin',\n                title: '$__twoFactorAuthenticator',\n                reqId: true,\n                module: TwoFactor,\n                closeOption: false,\n                permission: session._id === data._id ? 0 : 6,\n                ownerLock: true,\n            },\n            {\n                name: 'mobile',\n                icon: 'phone_iphone',\n                title: '$__mobile',\n                reqId: true,\n                module: UserMobile,\n                closeOption: false,\n                permission: session._id === data._id ? 0 : 6,\n                ownerLock: true,\n            }] : [],\n        {\n            name: 'resume',\n            icon: 'blur_on',\n            title: '$__resume',\n            resume: true,\n            reqId: true,\n            module: CardResume,\n            closeOption: true,\n            permission: 2,\n            template: true,\n        },\n\n        //CARD\n        {\n            name: 'cardEdit',\n            icon: 'subject',\n            title: '$__edition',\n            reqId: false,\n            module: CardEdit,\n            closeOption: false,\n            permission: 0,\n            buttonsCount: 3,\n            template: true,\n        },\n\n        //COLUMN\n        {\n            name: 'columnEdit',\n            icon: 'tune',\n            title: '$__edition',\n            reqId: false,\n            module: ColumnEdit,\n            closeOption: false,\n            permission: 0,\n            buttonsCount: 3,\n            template: true,\n        },\n\n        //USER\n        {\n            name: 'users',\n            icon: 'supervised_user_circle',\n            title: '$__usersAndDepartments',\n            reqId: true,\n            module: Users,\n            closeOption: true,\n            permission: 3,\n            template: true,\n        },\n        ...type === 'users' ?\n            [{\n                name: 'delete',\n                icon: 'delete_sweep',\n                title: '$__delete',\n                reqId: true,\n                module: UserDelete,\n                closeOption: true,\n            }]\n            : [{\n                name: 'delete',\n                icon: 'delete_sweep',\n                title: '$__delete',\n                reqId: true,\n                module: CardDelete,\n                closeOption: true,\n                permission: 5,\n                template: true,\n            }],\n        ...(\n            CardAccess >= 4\n            ||\n            (\n                CardAccess && CardAccess < 4 && data.kpi_type && data.kpi_type !== \"task\"\n            )\n            ||\n            (\n                AppAccess && AppAccess.plan && AppAccess.planAdmin\n            )\n        ) ?\n            [{\n                name: 'kpi',\n                icon: 'analytics',\n                title: '$__kpi',\n                reqId: true,\n                module: CardKPI,\n                closeOption: false,\n                permission: 3,\n                count: 'kpi'\n            }] : [],\n        {\n            name: 'timeLog',\n            icon: 'timer',\n            title: '$__timerLog',\n            reqId: true,\n            module: TimerLog,\n            closeOption: true,\n            permission: 1,\n            count: 'timer',\n        },\n        {\n            name: 'sendTo',\n            icon: 'share',\n            title: '$__sendTo',\n            reqId: true,\n            module: SendTo,\n            closeOption: true,\n            permission: 3,\n            template: true,\n        },\n        ...(data.type === 'client' || data.type === 'group' || data.type === 'unity') ? [{\n            name: 'settings',\n            icon: 'admin_panel_settings',\n            title: '$__settings',\n            reqId: true,\n            module: AccountSettings,\n            closeOption: false,\n            permission: 1,\n            template: true,\n        }] : [],\n        ...(data.type === 'user' && session._id === data._id) ? [{\n            name: 'settings',\n            icon: 'admin_panel_settings',\n            title: '$__settings',\n            reqId: true,\n            module: UserSettings,\n            closeOption: false,\n            permission: 1,\n            template: true,\n        }] : data.type !== 'user' ? [{\n            name: 'settings',\n            icon: 'settings',\n            title: '$__settings',\n            reqId: true,\n            module: CardSettings,\n            closeOption: false,\n            permission: 5,\n            template: true,\n        }] : [],\n    ]\n\n    const module = MOD.filter(fil => fil.name === sideModule.activeModule)[0]\n\n\n\n    if (!module || !module.module)\n        return null\n\n    const openModule = mod => {\n        if (reqSave) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    setReqSave(false)\n                    sideModule.activeModule = mod\n                    props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                        ...sideModule\n                    })\n                }\n            })\n        } else {\n            sideModule.activeModule = mod\n            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                ...sideModule\n            })\n        }\n    }\n\n    const close = (rq = false) => {\n        if (reqSave || rq) {\n            appAlert({\n                message: translate('$__confirmCloseWithUnsavedData', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n                    setReqSave(false)\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"CLEAR_MODULE\")\n            setReqSave(false)\n        }\n    }\n\n\n\n    const changeSideModuleWindow = () => {\n        let windowType = false\n\n        if (!windowType) {\n            windowType = 'popup'\n        } else if (windowType === 'popup') {\n            windowType = 'expanded'\n        } else if (windowType === 'expanded') {\n            windowType = 'fullScreen'\n        } else if (windowType === 'fullScreen') {\n            windowType = null\n        }\n\n        props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n            ...reduxStore.getState().session,\n            sideModuleWindow: windowType\n        });\n    }\n\n    const isTemplate = verifyTemplate(data._id)\n\n    const { modules } = sideModule.data.type ? db.dataType.filter(a => a.name === sideModule.data.type)[0] : []\n\n    return (\n        sideModule && sideModule.id ?\n            <div\n                style={{\n                    position: \"fixed\",\n                    top: 0,\n                    left: 0,\n                    right: 0,\n                    bottom: 0,\n                    zIndex: 3000,\n                    backgroundColor: \"rgba(0,0,0,0.7)\",\n                    backdropFilter: \"blur(3px)\",\n                }}\n                onClick={(e) => {\n                    e.stopPropagation()\n                    close()\n                }\n                }\n            >\n                <div\n                    className={session.sideModuleWindow && session.sideModuleWindow === 'popup'\n                        ? classes.modulePopup\n                        : session.sideModuleWindow && session.sideModuleWindow === 'expanded'\n                            ? classes.moduleExpanded\n                            : session.sideModuleWindow && session.sideModuleWindow === 'fullScreen'\n                                ? classes.moduleFullScreen\n                                : classes.module}\n                    id={`sideModule`}\n                    onClick={(e) => {\n                        e.stopPropagation()\n                    }}\n                >\n                    <div\n                        className={classes.menu}\n                        style={{\n                            background: customApp('menuColor'), //customApp\n                            borderRight: `solid 3px ${customApp('color')}`, //customApp\n                        }}\n                        id={`sideModule_menu`}\n                    >\n                        <div className={classes.menuButtons_resume}>\n                            {/* {modules.indexOf('resumeUser') > -1 && sideModule.id.length === 36 &&\n                                <MenuButton icon='blur_on' module='resumeUser' title={translate('$__resume')} size='26px' \n                                openModule={(a) => {\n                                                    openModule(a)\n                                                }}\n                                />\n                            } */}\n                            {/* {modules.indexOf('resume') > -1 && sideModule.id.length === 36 &&\n                                <MenuButton icon='blur_on' module='resume' title={translate('$__resume', 1)} size='26px' \n                                openModule={(a) => {\n                                                    openModule(a)\n                                                }}\n                                />\n                            } */}\n                        </div>\n                        {modules.map((a, i) => {\n                            let permission = true\n                            if (data && data._planId && (!db.cards[data._planId] || !planMyAccountVerify(data._planId)))\n                                permission = false\n                            let mod = MOD.filter(fil => fil.name.trim() === a.trim() && !fil.resume && !fil.hide)[0]\n                            if (\n                                mod\n                                && (\n                                    (\n                                        (data.type === 'user' || data.type === 'client')\n                                        &&\n                                        (\n                                            (\n\n                                                (\n                                                    AppAccess\n                                                    && AppAccess.user\n                                                    && (AppAccess.userAdmin\n                                                        || (\n                                                            AppAccess.userModerate\n                                                            && mod.permission <= 4\n                                                        ) || (\n                                                            AppAccess.userEdit\n                                                            && mod.permission <= 3\n                                                        )\n                                                    )\n                                                )\n                                                ||\n                                                (\n                                                    data._id === session._id\n                                                    && mod.permission <= 3\n                                                )\n                                            )\n                                        )\n\n                                    )\n                                    ||\n                                    (\n                                        (\n                                            data.type !== 'user'\n                                            && data.type !== 'client'\n                                            && data.type !== 'account'\n                                            && data.type !== 'unity'\n                                        )\n                                        &&\n                                        (\n                                            permission\n                                            && (\n                                                AppAccess\n                                                && AppAccess.plan\n                                                && (\n                                                    AppAccess.planAdmin\n                                                    || (\n                                                        AppAccess.planModerate\n                                                        && mod.permission <= 4\n                                                    )\n                                                )\n                                            )\n                                        )\n                                    )\n                                    ||\n                                    (\n                                        (\n                                            data.type !== 'user'\n                                            || data.type !== 'client'\n                                            || data.type !== 'account'\n                                        )\n                                        && (\n                                            String(CardAccess)\n                                            && parseInt(CardAccess) >= parseInt(mod.permission)\n                                        )\n                                    )\n                                )\n                            ) {\n                                if (mod.ownerLock\n                                    && AppAccess\n                                    && !AppAccess.owner\n                                    && data._access\n                                    && data._access.owner\n                                    && session._id !== data._id\n                                ) {\n                                    return null\n                                }\n                                if (\n                                    (\n                                        !isTemplate\n                                        ||\n                                        (\n                                            sideModule.data\n                                            && isTemplate\n                                            && mod.template\n                                        )\n                                    )\n                                    &&\n                                    (\n                                        (\n                                            mod\n                                            && !mod.reqId\n                                        )\n                                        ||\n                                        (\n                                            mod\n                                            &&\n                                            (\n                                                mod.reqId\n                                                || !mod.reqId\n                                            )\n                                            &&\n                                            sideModule.id.length === 36\n                                        )\n                                    )\n                                ) {\n                                    if (mod.name === 'recurrence'\n                                        && (\n                                            Object.keys(reduxStore.getState().db.cards)\n                                                .filter(fil => {\n                                                    if (\n                                                        !reduxStore.getState().db.cards[fil].deleted\n                                                        && !reduxStore.getState().db.cards[fil].checklist\n                                                        && reduxStore.getState().db.cards[fil]._recurrenceId\n                                                        && reduxStore.getState().db.cards[fil]._recurrenceId === sideModule.data._id\n                                                    )\n                                                        return true\n                                                }\n                                                ).length > 0\n                                        )\n                                    ) {\n                                        return (\n                                            <MenuButton\n                                                key={i}\n                                                icon={mod.icon}\n                                                module={mod.name}\n                                                title={translate(mod.title, 1)}\n                                                count={mod.count ? mod.count : null}\n                                                openModule={(a) => {\n                                                    openModule(a)\n                                                }}\n                                            />\n                                        )\n                                    } else if (mod.name !== 'recurrence') {\n                                        return (\n                                            <MenuButton\n                                                key={i}\n                                                icon={mod.icon}\n                                                module={mod.name}\n                                                title={translate(mod.title, 1)}\n                                                count={mod.count ? mod.count : null}\n                                                openModule={(a) => {\n                                                    openModule(a)\n                                                }}\n                                            />\n                                        )\n                                    }\n                                }\n                            }\n                        })}\n\n                        {/* <div style={{\n                            position: 'absolute',\n                            bottom: '0px',\n                            width: '100%',\n                            height: '50px'\n                        }} onClick={() => {\n                            // changeSideModuleWindow()\n                        }}></div> */}\n                    </div>\n                    <div\n                        id={`sideModule_header`}\n                    >\n                        <HeaderWithIcon\n                            title={sideModule && sideModule.data && sideModule.data.name || `${translate('$__create')} ${translate(`$__${sideModule.data.type}`)}`}\n                            icon={sideModule?.data?.icon || sideModule && sideModule.data && sideModule.data.type && db.dataType.filter(a => a.name === sideModule.data.type)[0].icon || \"view_comfy\"}\n                            style={{\n                                paddingLeft: '50px',\n                                width: `calc(100% - 0px)`,\n                                minHeight: '50px',\n                                marginTop: \"-4px\"\n                            }}\n                            color={customApp('menu')}\n                            {...permission && sideModule?.data?._id ? {\n                                editable: true,\n                                onChangeIcon: (ic) => {\n                                    updateCardData(\n                                        {\n                                            ...props,\n                                            data: { _id: sideModule.data._id }\n                                        }, {\n                                        icon: ic\n                                    })\n                                }\n                            } : {}}\n                        />\n                        {module.closeOption &&\n                            <SideModuleCloseAndSave\n                                close={() => close()}\n                            />\n                        }\n                    </div>\n                    <div className={classes.content}>\n                        <ErrorBoundary>\n                            <module.module\n                                {...module.props}\n                                permission={permission}\n                                onClose={(a) => {\n                                    close(a)\n                                }\n                                } reqSave={(a) => { setReqSave(a) }} />\n                        </ErrorBoundary>\n                    </div>\n                    <div\n                        className={classes.subTitle}\n                        id={`sideModule_subTitle`}\n                        style={{\n                            ...sideModule && sideModule.data && sideModule.data.private ? {\n                                background: \"gray\"\n                            } : {\n\n                            },\n                            display: \"flex\",\n                            justifyContent: \"space-between\"\n                        }}\n                    >\n                        {translate(module.title.toLowerCase(), 1)}\n                        {sideModule && sideModule.data && sideModule.data.private ?\n                            <div style={{\n                                display: \"flex\",\n                                alignItems: \"center\"\n                            }}>\n                                {translate(\"$__isPrivate\", \"*\")}<Icon icon={\"lock\"} color={\"#FFFFFF\"} size={20} style={{ marginLeft: 7 }} />\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                    </div>\n                </ div >\n\n            </div >\n            : null\n    )\n}\n\n\nconst mapStateToProps = (store) => {\n    return (\n        {\n            sideModuleWindow: store.session.sideModuleWindow,\n            sideModule: store.sideModule,\n            cards: store.db.cards\n        }\n    )\n}\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","//@MATERIAL \nimport Dialog from '@material-ui/core/Dialog';\nimport { withStyles } from \"@material-ui/core/styles\";\n\nconst Component = withStyles({\n    root: {\n        '& .MuiPaper-root': {\n            overflow: \"visible\"\n        },\n    },\n})(Dialog);\n\nexport default Component","//REDUX\r\nimport reduxStore from \"store/\";\r\n\r\n//FUNCTIONS\r\nimport api from \"api/\";\r\n\r\n\r\n\r\nexport const tagUpdate = (props, data) => {\r\n    let newTagResult = reduxStore.getState().db.tag\r\n    if (newTagResult.filter(t => t.value === data.value).length > 0) {\r\n        newTagResult.map((tag, i) => {\r\n            if (tag.value === data.value) {\r\n                newTagResult[i] = {\r\n                    ...newTagResult[i],\r\n                    ...data\r\n                }\r\n            }\r\n        })\r\n    } else {\r\n        newTagResult.push(data)\r\n    }\r\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n        ...reduxStore.getState().db,\r\n        tag: [\r\n            ...newTagResult\r\n        ]\r\n    });\r\n}\r\n\r\nexport const tagDelete = async (props, data) => {\r\n    const response = api.delete(`/tag/unique/${data._id}`, {\r\n        ...data\r\n    })\r\n    if (response)\r\n        localTagDelete(props, data)\r\n}\r\n\r\n\r\n\r\nexport const localTagDelete = (props, data) => {\r\n    let newTags = []\r\n    reduxStore.getState().db.tag.map(t => {\r\n        if (t.value !== data._id)\r\n            newTags.push(t)\r\n    })\r\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n        ...reduxStore.getState().db,\r\n        tag: newTags\r\n    });\r\n}\r\n\r\nexport const tagUnlink = async (props, data) => {\r\n    const response = api.put(`/tag/unlink/`, {\r\n        ...data\r\n    })\r\n    if (response)\r\n        localTagUnlink(props, data)\r\n}\r\n\r\nexport const tagLink = async (props, data) => {\r\n    const { session } = reduxStore.getState()\r\n    // console.log(session)\r\n\r\n    if (data.target === data._id)\r\n        data.target = session.account\r\n\r\n    const response = await api.put(`/tag/link/`, {\r\n        ...data\r\n    })\r\n    if (response)\r\n        return true\r\n    //     localTagDelete(props, data)\r\n}\r\n\r\n\r\nexport const localTagUnlink = (props, data) => {\r\n    let newTags = []\r\n    let { session, db } = reduxStore.getState()\r\n    db.tag.map(t => {\r\n        let newData = t\r\n        if (t.value === data._id)\r\n            newData = {\r\n                ...newData,\r\n                count: 0\r\n            }\r\n        newTags.push(newData)\r\n    })\r\n    let cards = {\r\n        ...db.cards\r\n    }\r\n    Object.keys(cards).filter(card =>\r\n        cards[card]._users\r\n        && cards[card]._users[session._id]\r\n        && cards[card]._tags\r\n        && cards[card]._tags.filter(tg => tg.value === data._id).length > 0\r\n    ).map(card => {\r\n        let newTags = []\r\n        cards[card]._tags.map(tg => {\r\n            if (tg.value !== data._id)\r\n                newTags.push(tg)\r\n        })\r\n        cards[card]._tags = newTags\r\n\r\n    })\r\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n        ...db,\r\n        tag: newTags,\r\n        cards: cards\r\n    });\r\n}","import {\r\n  defaultFont,\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst styles = (theme) => ({\r\n  ...defaultFont,\r\n  menu: {\r\n    position: 'relative',\r\n    borderRight: customApp('color'),\r\n  },\r\n  menuExpanded: {\r\n    position: 'relative',\r\n    borderRight: customApp('color'),\r\n  },\r\n  button: {\r\n    position: 'relative', float: 'left', width: '100%', padding: '7px'\r\n  },\r\n  buttonColor: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: 'calc(100% + 20px)',\r\n    padding: '20px 12px',\r\n    marginLeft: '-12px',\r\n    display: \"flex\",\r\n    justifyContent: \"center\",\r\n    backgroundColor: customApp('color')\r\n  },\r\n  buttonColorExpanded: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: 'calc(100% + 20px)',\r\n    padding: '12px 12px 12px 20px',\r\n    marginLeft: '-12px',\r\n    display: \"flex\",\r\n    backgroundColor: customApp('color')\r\n  },\r\n  separator: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    padding: '7px',\r\n    borderTop: `1px solid ${customApp('medium', 0.5)}`,\r\n    marginTop: '15px',\r\n    marginBottom: '0px',\r\n    height: '1px'\r\n  }\r\n});\r\n\r\nexport default styles;\r\n","//CORE\nimport React from \"react\"\nimport Nestable from \"react-nestable\";\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport history from \"store/history\"\nimport reduxStore from \"store/\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//COMPONENTS\nimport ColorPicker from \"components/ColorPicker\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Dialog from \"components/Dialog\"\nimport HeaderWithIcon from \"components/Header/card\"\nimport Icon from \"components/Icon\"\nimport MoreMenu from \"components/MoreMenu/\"\nimport TextField from \"components/TextField\"\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport { makeStyles } from \"@material-ui/core/styles\"\n\n//FUNCTIONS\nimport api from \"api\"\n\nimport {\n    tagDelete,\n    tagUnlink,\n    tagUpdate,\n    tagLink,\n} from \"functions/tags\";\n\nimport {\n    translate,\n    customApp,\n    getAppAccess,\n    removeSeats,\n    appAlert\n} from \"functions/\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/tagsMenu\"\nimport \"./styles.css\"\n\nfunction Component(props) {\n    const useStyles = makeStyles(styles)\n    const classes = useStyles()\n    const { db, session } = reduxStore.getState()\n    const { tag } = props\n    const [mounted, setMounted] = React.useState(false)\n    const [moreMenuShow, setMoreMenuShow] = React.useState(null)\n    const [moreMenuOpen, setMoreMenuOpen] = React.useState(false)\n    const [editor, setEditor] = React.useState(false)\n    const [showAll, setShowAll] = React.useState(false)\n    const [data, setData] = React.useState({})\n    const [saveLoading, setSaveLoading] = React.useState(false)\n    const [search, setSearch] = React.useState(null)\n    const [tags, setTags] = React.useState([])\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true)\n            mountTags()\n            if (props.onLoad)\n                props.onLoad()\n        }\n        return () => {\n            // return false\n        }\n    }, [])\n\n    React.useEffect(() => {\n        mountTags()\n        return () => {\n            // return false\n        }\n    }, [search, JSON.stringify(props.tag)])\n\n    let AppAccess = getAppAccess()\n\n    const mountTags = () => {\n        let newTags = []\n        tag.filter(a => {\n            let searchLabel = search ? removeSeats(search.toLowerCase().trim()) : ``\n            let tagLabel = removeSeats(a.label.toLowerCase().trim())\n            if (\n                !a.parent\n                &&\n                (\n                    !search\n                    ||\n                    (\n                        search\n                        && tagLabel.indexOf(searchLabel) > -1\n                    )\n                ))\n                return true\n        })\n            .sort((a, b) => {\n                if (removeSeats(a.label.toLowerCase().trim()) < removeSeats(b.label.toLowerCase().trim()))\n                    return -1\n                if (removeSeats(a.label.toLowerCase().trim()) > removeSeats(b.label.toLowerCase().trim()))\n                    return 1\n                return 0\n            }).map(ta => {\n                let a = ta\n                a._count = Object.keys(db.cards).filter(card => db.cards[card]._users && db.cards[card]._users[session._id] && db.cards[card]._tags && db.cards[card]._tags.filter(cta => cta.value === a.value).length > 0).length > parseInt(a._count) ? Object.keys(db.cards).filter(card => db.cards[card]._users && db.cards[card]._users[session._id] && db.cards[card]._tags && db.cards[card]._tags.filter(cta => cta.value === a.value).length > 0).length : parseInt(a._count)\n                a._countOthers = Object.keys(db.cards).filter(card => db.cards[card]._users && !db.cards[card]._users[session._id] && db.cards[card]._tags && db.cards[card]._tags.filter(cta => cta.value === a.value).length > 0).length > parseInt(a._countOthers) ? Object.keys(db.cards).filter(card => db.cards[card]._users && !db.cards[card]._users[session._id] && db.cards[card]._tags && db.cards[card]._tags.filter(cta => cta.value === a.value).length > 0).length : parseInt(a._countOthers)\n                if (\n                    newTags.filter(tag =>\n                        tag.id === a.label.substr(0, 1)\n                    ).length === 0\n                ) {\n                    let achi = []\n                    if (tag.filter(ca => ca.parent && ca.parent === a.value).length > 0) {\n                        tag.filter(ca => ca.parent && ca.parent === a.value).map(xx => {\n                            if (achi.filter(aa => aa.value === xx.value).length === 0)\n                                achi.push({\n                                    id: xx.value,\n                                    text: xx.label,\n                                    ...xx\n                                })\n                        })\n                    }\n                    newTags.push({\n                        id: a.label.substr(0, 1), text: a.label.substr(0, 1),\n                        children: [{\n                            id: a.value,\n                            text: a.label,\n                            ...a,\n                            children: achi\n                        }]\n                    })\n                } else {\n                    if (\n                        newTags.filter(t => t.id === a.label.substr(0, 1)).length > 0\n                        && newTags.filter(t => t.id === a.label.substr(0, 1))[0].children.filter(c => c.value === a.value).length === 0\n                    ) {\n                        let achi = []\n                        if (tag.filter(ca => ca.parent && ca.parent === a.value).length > 0) {\n                            tag.filter(ca => ca.parent && ca.parent === a.value).map(xx => {\n                                if (achi.filter(aa => aa.value === xx.value).length === 0)\n                                    achi.push({\n                                        id: xx.value,\n                                        text: xx.label,\n                                        ...xx\n                                    })\n                            })\n                        }\n                        newTags.filter(t => t.id === a.label.substr(0, 1))[0].children.push({\n                            id: a.value,\n                            text: a.label,\n                            ...a,\n                            children: achi\n                        })\n                    }\n                }\n            })\n        setTags(newTags)\n    }\n\n    const clearEditor = () => {\n        setData({})\n        setSaveLoading(false)\n        setEditor(false)\n        // setMounted(false)\n    }\n\n\n\n    const editTag = (e) => {\n        setEditor(true)\n        if (e) {\n            setData(e)\n        } else {\n            setData({})\n        }\n    }\n\n    const saveTag = async () => {\n        setSaveLoading(true)\n        if (data.value) {\n            try {\n                const response = await api.put(\"tag/update\", {\n                    _id: data.value,\n                    name: data.name ? data.name : data.label,\n                    color: data.newColor ? data.newColor : data.color ? data.color : null\n                })\n                if (response) {\n                    tagUpdate(props, { value: data.value, label: data.name ? data.name : data.label, color: data.newColor ? data.newColor : data.color }, true)\n                    setSaveLoading(false)\n                    clearEditor()\n                }\n            } catch (e) {\n                console.log(e)\n                setSaveLoading(false)\n            }\n        } else {\n            try {\n                const response = await api.post(\"tag/add\", {\n                    name: data.name,\n                    color: data.newColor ? data.newColor : data.color ? data.color : null\n                })\n                if (response && response.data) {\n                    setShowAll(true)\n                    tagUpdate(props, response.data, true)\n                    setSaveLoading(false)\n                    clearEditor()\n                }\n            } catch (e) {\n                console.log(e)\n                setSaveLoading(false)\n            }\n        }\n    }\n\n    const openTag = (e) => {\n        history.push(`tags#${e.value}`)\n    }\n\n    const deleteTag = async (e) => {\n        appAlert({\n            message: translate(\"$__confirmDeleteTag\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                tagDelete(props, { _id: e.value })\n            }\n        })\n    }\n\n    const unlinkTag = async (e) => {\n        appAlert({\n            message: translate(\"$__confirmUnlinkTag\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                tagUnlink(props, { _id: e.value })\n            }\n        })\n    }\n\n\n    return (\n        <div\n            onMouseLeave={() => {\n                if (!moreMenuOpen)\n                    setTimeout(() => {\n                        setMoreMenuShow(null)\n                    }, 1000)\n            }}>\n            <div className={classes.menu} >\n                <div\n                    style={{ marginTop: \"5px\" }}\n                >\n                    <HeaderWithIcon\n                        title={translate(\"$__tags\", 1)}\n                        icon={\"bookmarks\"}\n                        iconTitle={translate(\"$__tags\", 1)}\n                        color={customApp(\"colorText\")}\n                        fontSize={\"16px\"}\n                        moreButton\n                        options={[\n                            {\n                                name: \"$__addTag\",\n                                icon: \"add_box\",\n                                color: customApp(\"color\"),\n                                show: \"hover\",\n                                onClick: () => {\n                                    editTag()\n                                },\n                            },\n                            AppAccess && AppAccess.plan && AppAccess.planAdmin && !showAll &&\n                            {\n                                name: \"$__showAllTags\",\n                                icon: \"style\",\n                                color: customApp(\"color\"),\n                                show: \"hover\",\n                                onClick: () => {\n                                    setShowAll(true)\n                                },\n                            },\n                            showAll &&\n                            {\n                                name: \"$__onlyMyTags\",\n                                icon: \"loyalty\",\n                                color: customApp(\"color\"),\n                                show: \"hover\",\n                                onClick: () => {\n                                    setShowAll(false)\n                                },\n                            },\n                        ]}\n                        optionsProps={{\n                            transparent: true\n                        }}\n                    />\n                </div>\n                <div\n                    className={classes.separator}\n                ></div>\n                <div>\n                    <TextField\n                        label={translate(\"$__search\", 1)}\n                        variant={customApp(\"fieldVariant\")}\n                        name={\"name\"}\n                        InputLabelProps={{\n                            shrink: true,\n                        }}\n                        InputProps={{\n                            autoComplete: \"new-password\",\n                            endAdornment: search ? (\n                                <InputAdornment position=\"end\">\n                                    <Icon icon={'cancel'} color=\"green\" onClick={() => setSearch(null)} />\n                                </InputAdornment>\n                            ) : null,\n                            onChange: (d) => {\n                                setSearch(d.target.value)\n                            },\n                        }}\n                        placeholder={translate(\"$__nameOfTagSearch_placeholder\", 1)}\n                    />\n                </div>\n            </div>\n            <div\n                style={{\n                    position: \"absolute\",\n                    top: \"112px\",\n                    bottom: 0,\n                    overflow: \"auto\",\n                    padding: \"3px\",\n                    paddingTop: \"7px\",\n                    listStyle: \"none\",\n                    width: \"100%\"\n                }}\n            >\n                <Nestable\n                    collapse=\"ALL\"\n                    items={tags}\n                    maxDepth={3}\n                    renderItem={(ns) => {\n                        if (!ns.item.value) {\n                            return <div\n                                style={{\n                                    fontWeight: \"bold\",\n                                    color: customApp(\"color\"),\n                                    fontSize: \"12px\"\n                                }}>{ns.item.text}</div>\n                        } else {\n                            return <div\n                                style={{\n                                    width: \"100%\",\n                                    cursor: \"pointer\",\n                                    display: \"flex\"\n                                }}\n                                onMouseOver={() => {\n                                    if (AppAccess && AppAccess.plan && AppAccess.planAdmin)\n                                        setMoreMenuShow(ns.item.value)\n                                }}\n\n                            >\n                                <div\n                                    style={{\n                                        zIndex: 0,\n                                        maxWidth: \"90%\",\n                                        textOverflow: \"ellipsis\",\n                                        overflow: \"hidden\",\n                                        whiteSpace: \"nowrap\",\n                                        ...ns.item.color ? { borderLeft: `solid 6px ${ns.item.color}`, paddingLeft: \"7px\" } : {}\n                                    }}\n                                    onClick={\n                                        () => {\n                                            openTag(ns.item)\n                                        }\n                                    }\n                                >\n                                    {ns.item.text} {ns.item._count ? `(${ns.item._count})` : ``}\n                                </div>\n                                {moreMenuShow && ns.item.value === moreMenuShow &&\n                                    <div style={{ zIndex: 1 }}>\n                                        <MoreMenu\n                                            horizontalButton\n                                            transparent\n                                            size=\"14px\"\n                                            btColor={customApp(\"color\")}\n                                            onOpen={() => {\n                                                setMoreMenuOpen(true)\n                                            }}\n                                            onClose={() => {\n                                                setMoreMenuOpen(false)\n                                            }}\n                                            options={[\n                                                ...AppAccess && AppAccess.plan && (\n                                                    AppAccess.planAdmin\n                                                ) ? [{\n                                                    name: \"$__edit\",\n                                                    icon: \"edit\",\n                                                    onClick: () => {\n                                                        editTag(ns.item)\n                                                    },\n                                                }] : [],\n                                                (\n                                                    (parseInt(ns.item._count) === 0 && parseInt(ns.item._countOthers) === 0)\n                                                    || (parseInt(ns.item._count) > 0 && parseInt(ns.item._countOthers) === 0)\n                                                ) &&\n                                                {\n                                                    name: \"$__delete\",\n                                                    icon: \"delete_forever\",\n                                                    onClick: () => {\n                                                        deleteTag(ns.item)\n                                                    },\n                                                },\n                                                (\n                                                    (parseInt(ns.item._count) > 0 && parseInt(ns.item._countOthers) > 0)\n                                                ) &&\n                                                {\n                                                    name: \"$__unlinkMyActivities\",\n                                                    icon: \"label_off\",\n                                                    onClick: () => {\n                                                        unlinkTag(ns.item)\n                                                    },\n                                                },\n                                            ]}\n                                        />\n                                    </div>\n                                }\n                            </div>\n                        }\n                    }}\n                    onChange={(a) => {\n                        let newItems = a.items\n                        let target = newItems[a.targetPath[0]].children[a.targetPath[1]]\n                        tagLink(props, {\n                            _id: a.dragItem.id,\n                            target: target.id\n                        })\n                        setTags(newItems)\n                    }}\n                />\n            </div>\n            <Dialog\n                fullWidth={true}\n                // onClose={() => setEditor(false)} \n                aria-labelledby=\"simple-dialog-title\"\n                open={editor}\n                style={{ overflow: \"visible !important\" }}\n            >\n                <div style={{ position: \"relative\", marginLeft: \"10px\", marginTop: '5px', width: \"calc(100% - 10px)\" }}>\n                    <HeaderWithIcon\n                        title={data.value ? translate(\"$__editTag\", 1) : translate(\"$__newTag\", 1)}\n                        icon=\"label\"\n                        onCancel={() => { setEditor(false) }}\n                    />\n                </div>\n                <div style={{ color: \"#CCCCCC\", padding: \"15px\" }}>\n                    Etiquetas permitem que você adicione palavras-chave às atividades (Tarefas, Insights, Notícias), organizando-as e permitindo melhor navegação e praticidade no seu dia a dia.\n                </div>\n                <div style={{ padding: \"15px\" }}>\n                    <TextField\n                        error={(data && (!data.label || data.label.length === 0)) ? true : false}\n                        helperText={\"Campo de nome da etiqueta deve ter o compimento mínimo de 1 caractere\"}\n                        label={translate(\"$__name\", 1)}\n                        variant={customApp(\"fieldVariant\")}\n                        name={\"name\"}\n                        InputLabelProps={{\n                            shrink: true,\n                        }}\n                        InputProps={{\n                            autoComplete: \"new-password\",\n                            onChange: (d) => {\n                                setData({\n                                    ...data,\n                                    name: d.target.value\n                                })\n                            },\n                        }}\n                        defaultValue={data && data.label ? data.label : null}\n                        placeholder={translate(\"$__nameOfTag_placeholder\", 1)}\n                    />\n\n                </div>\n                <div style={{ display: \"flex\", padding: \"15px\", overflow: \"visible\" }}>\n                    <span style={{ marginRight: \"7px\" }}>{translate(\"$__tagColor\")}:</span>\n                    <ColorPicker\n                        disablePortal\n                        color={data.color}\n                        onChange={(c) => {\n                            setData({\n                                ...data,\n                                newColor: c\n                            })\n\n                        }\n                        }>\n                        {(data.color || data.newColor) ?\n                            <div\n                                className={'tag'}\n                                style={{\n                                    backgroundColor: data.newColor ? data.newColor : data.color,\n                                    width: \"22px\",\n                                    height: \"22px\",\n                                    borderRadius: \"50%\",\n                                    cursor: \"pointer\"\n                                }}\n                            >\n                            </div>\n                            :\n                            <div\n                                className={'tag'}\n                                style={{\n                                    fontWeight: \"bold\"\n                                }}\n                            >\n                                {translate(\"$__clickHereToAddColor\")}\n                            </div>\n                        }\n\n                    </ColorPicker>\n                </div>\n                <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\", padding: \"15px\" }}>\n                    <CustomButton\n                        shadow\n                        title={translate(\"$__cancel\")}\n                        text={translate(\"$__cancel\")}\n                        color=\"lightgrey\"\n                        icon={\"close\"}\n                        size={\"25px\"}\n                        onClick={() => {\n                            setEditor(false)\n                        }}\n                    />\n                    {\n                        data\n                        && (\n                            data.name\n                            ||\n                            data.newColor\n                        )\n                        &&\n                        <div style={{ marginLeft: \"15px\" }}>\n                            <CustomButton\n                                shadow\n                                title={translate(\"$__save\")}\n                                text={translate(\"$__save\")}\n                                icon={\"save\"}\n                                size={\"25px\"}\n                                load={saveLoading ? true : false}\n                                onClick={() => {\n                                    saveTag()\n                                }}\n                            />\n                        </div>\n                    }\n                </div>\n            </Dialog>\n        </div>\n    )\n}\n\nconst mapStateToProps = (store) => ({\n    tag: store.db.tag\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)","import React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\n\n//@MATERIAL\nimport Badge from \"@material-ui/core/Badge\"\n\nimport { countUnRead } from \"functions/chat\"\n\nfunction CountIcon(props) {\n    const count = countUnRead()\n    document.title = `${count && count.total > 0 ? `(${count.total}) ` : ``}MACHEN`\n\n    return (\n        <React.Fragment>\n            <Badge badgeContent={count && count.total ? count.total : 0} color=\"secondary\"\n                overlap=\"rectangular\"\n            >\n                {props.children}\n            </Badge>\n        </React.Fragment>\n    )\n}\n\nconst mapStateToProps = (store, props) => ({\n    timeline: store.timeline\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(CountIcon)","import {\r\n  primaryColor,\r\n  dangerColor,\r\n  successColor,\r\n  defaultFont,\r\n  whiteColor,\r\n  grayColor\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst customInputStyle = {\r\n  disabled: {\r\n    \"&:before\": {\r\n      borderColor: \"transparent !important\"\r\n    }\r\n  },\r\n  underline: {\r\n    \"&:hover:not($disabled):before,&:before\": {\r\n      borderColor: grayColor[4] + \"!important\",\r\n      borderWidth: \"1px !important\"\r\n    },\r\n    \"&:after\": {\r\n      borderColor: primaryColor[0]\r\n    },\r\n    \"& + p\": {\r\n      fontWeight: \"300\"\r\n    }\r\n  },\r\n  underlineError: {\r\n    \"&:after\": {\r\n      borderColor: dangerColor[0]\r\n    }\r\n  },\r\n  underlineSuccess: {\r\n    \"&:after\": {\r\n      borderColor: successColor[0]\r\n    }\r\n  },\r\n  labelRoot: {\r\n    ...defaultFont,\r\n    color: grayColor[3] + \" !important\",\r\n    fontWeight: \"400\",\r\n    fontSize: \"12px\",\r\n    lineHeight: \"1.42857\",\r\n    top: \"10px\",\r\n    letterSpacing: \"unset\",\r\n    \"& + $underline\": {\r\n      marginTop: \"0px\"\r\n    }\r\n  },\r\n  labelRootError: {\r\n    color: dangerColor[0] + \" !important\"\r\n  },\r\n  labelRootSuccess: {\r\n    color: successColor[0] + \" !important\"\r\n  },\r\n  formControl: {\r\n    margin: \"0 0 16px 0\",\r\n    paddingTop: \"27px\",\r\n    position: \"relative\",\r\n    verticalAlign: \"unset\",\r\n    \"& svg,& .fab,& .far,& .fal,& .fas,& .material-icons\": {\r\n      color: grayColor[14]\r\n    }\r\n  },\r\n  whiteUnderline: {\r\n    \"&:hover:not($disabled):before,&:before\": {\r\n      backgroundColor: whiteColor\r\n    },\r\n    \"&:after\": {\r\n      backgroundColor: whiteColor\r\n    }\r\n  },\r\n  input: {\r\n    color: grayColor[14],\r\n    height: \"unset\",\r\n    \"&,&::placeholder\": {\r\n      fontSize: \"12px\",\r\n      fontFamily: '\"Roboto\", \"Helvetica\", \"Arial\", sans-serif',\r\n      fontWeight: \"400\",\r\n      lineHeight: \"1.42857\",\r\n      opacity: \"1\"\r\n    },\r\n    \"&::placeholder\": {\r\n      color: grayColor[3]\r\n    }\r\n  },\r\n  whiteInput: {\r\n    \"&,&::placeholder\": {\r\n      color: whiteColor,\r\n      opacity: \"1\"\r\n    }\r\n  }\r\n};\r\n\r\nexport default customInputStyle;\r\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport classNames from \"classnames\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport FormControl from \"@material-ui/core/FormControl\";\nimport InputLabel from \"@material-ui/core/InputLabel\";\nimport FormHelperText from \"@material-ui/core/FormHelperText\";\nimport Input from \"@material-ui/core/Input\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/customInputStyle.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function CustomInput(props) {\n  const classes = useStyles();\n  const {\n    formControlProps,\n    labelText,\n    id,\n    labelProps,\n    inputProps,\n    error,\n    white,\n    inputRootCustomClasses,\n    success,\n    helperText\n  } = props;\n\n  const labelClasses = classNames({\n    [\" \" + classes.labelRootError]: error,\n    [\" \" + classes.labelRootSuccess]: success && !error\n  });\n  const underlineClasses = classNames({\n    [classes.underlineError]: error,\n    [classes.underlineSuccess]: success && !error,\n    [classes.underline]: true,\n    [classes.whiteUnderline]: white\n  });\n  const marginTop = classNames({\n    [inputRootCustomClasses]: inputRootCustomClasses !== undefined\n  });\n  const inputClasses = classNames({\n    [classes.input]: true,\n    [classes.whiteInput]: white\n  });\n  var formControlClasses;\n  if (formControlProps !== undefined) {\n    formControlClasses = classNames(\n      formControlProps.className,\n      classes.formControl\n    );\n  } else {\n    formControlClasses = classes.formControl;\n  }\n  var helpTextClasses = classNames({\n    [classes.labelRootError]: error,\n    [classes.labelRootSuccess]: success && !error\n  });\n  return (\n    <FormControl {...formControlProps} className={formControlClasses}>\n      {labelText !== undefined ? (\n        <InputLabel\n          className={classes.labelRoot + \" \" + labelClasses}\n          htmlFor={id}\n          {...labelProps}\n        >\n          {labelText}\n        </InputLabel>\n      ) : null}\n      <Input\n        classes={{\n          input: inputClasses,\n          root: marginTop,\n          disabled: classes.disabled,\n          underline: underlineClasses\n        }}\n        id={id}\n        {...inputProps}\n      />\n      {helperText !== undefined ? (\n        <FormHelperText id={id + \"-text\"} className={helpTextClasses}>\n          {helperText}\n        </FormHelperText>\n      ) : null}\n    </FormControl>\n  );\n}\n\nCustomInput.propTypes = {\n  labelText: PropTypes.node,\n  labelProps: PropTypes.object,\n  id: PropTypes.string,\n  inputProps: PropTypes.object,\n  formControlProps: PropTypes.object,\n  inputRootCustomClasses: PropTypes.string,\n  error: PropTypes.bool,\n  success: PropTypes.bool,\n  white: PropTypes.bool,\n  helperText: PropTypes.node\n};\n","import { grayColor } from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst cardFooterStyle = {\r\n  cardFooter: {\r\n    padding: \"0\",\r\n    paddingTop: \"10px\",\r\n    margin: \"0 15px 10px\",\r\n    borderRadius: \"0\",\r\n    justifyContent: \"space-between\",\r\n    alignItems: \"center\",\r\n    display: \"flex\",\r\n    backgroundColor: \"transparent\",\r\n    border: \"0\"\r\n  },\r\n  cardFooterProfile: {\r\n    marginTop: \"-15px\"\r\n  },\r\n  cardFooterPlain: {\r\n    paddingLeft: \"5px\",\r\n    paddingRight: \"5px\",\r\n    backgroundColor: \"transparent\"\r\n  },\r\n  cardFooterPricing: {\r\n    zIndex: \"2\"\r\n  },\r\n  cardFooterTestimonial: {\r\n    display: \"block\"\r\n  },\r\n  cardFooterStats: {\r\n    borderTop: \"1px solid\" + grayColor[8],\r\n    marginTop: \"20px\",\r\n    \"& svg\": {\r\n      position: \"relative\",\r\n      top: \"4px\",\r\n      marginRight: \"3px\",\r\n      marginLeft: \"3px\",\r\n      width: \"16px\",\r\n      height: \"16px\"\r\n    },\r\n    \"& .fab,& .fas,& .far,& .fal,& .material-icons\": {\r\n      position: \"relative\",\r\n      top: \"4px\",\r\n      marginRight: \"3px\",\r\n      marginLeft: \"3px\",\r\n      fontSize: \"12px\",\r\n      lineHeight: \"16px\"\r\n    }\r\n  },\r\n  cardFooterChart: {\r\n    borderTop: \"1px solid\" + grayColor[8]\r\n  }\r\n};\r\n\r\nexport default cardFooterStyle;\r\n","import React from \"react\";\nimport classNames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/cardFooterStyle.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function CardFooter(props) {\n  const classes = useStyles();\n  const {\n    className,\n    children,\n    plain,\n    profile,\n    pricing,\n    testimonial,\n    stats,\n    chart,\n    product,\n    ...rest\n  } = props;\n  const cardFooterClasses = classNames({\n    [classes.cardFooter]: true,\n    [classes.cardFooterPlain]: plain,\n    [classes.cardFooterProfile]: profile || testimonial,\n    [classes.cardFooterPricing]: pricing,\n    [classes.cardFooterTestimonial]: testimonial,\n    [classes.cardFooterStats]: stats,\n    [classes.cardFooterChart]: chart || product,\n    [className]: className !== undefined\n  });\n  return (\n    <div className={cardFooterClasses} {...rest}>\n      {children}\n    </div>\n  );\n}\n\nCardFooter.propTypes = {\n  className: PropTypes.string,\n  plain: PropTypes.bool,\n  profile: PropTypes.bool,\n  pricing: PropTypes.bool,\n  testimonial: PropTypes.bool,\n  stats: PropTypes.bool,\n  chart: PropTypes.bool,\n  product: PropTypes.bool,\n  children: PropTypes.node\n};\n","import {\r\n  container,\r\n  cardTitle,\r\n  whiteColor,\r\n  grayColor\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst loginPageStyle = theme => ({\r\n  container: {\r\n    ...container,\r\n    zIndex: \"4\",\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      paddingBottom: \"100px\"\r\n    }\r\n  },\r\n  cardTitle: {\r\n    ...cardTitle,\r\n    color: whiteColor\r\n  },\r\n  textCenter: {\r\n    textAlign: \"center\"\r\n  },\r\n  justifyContentCenter: {\r\n    justifyContent: \"center !important\"\r\n  },\r\n  customButtonClass: {\r\n    \"&,&:focus,&:hover\": {\r\n      color: whiteColor\r\n    },\r\n    marginLeft: \"5px\",\r\n    marginRight: \"5px\"\r\n  },\r\n  inputAdornment: {\r\n    marginRight: \"18px\"\r\n  },\r\n  inputAdornmentIcon: {\r\n    color: grayColor[6]\r\n  },\r\n  cardHidden: {\r\n    opacity: \"0\",\r\n    transform: \"translate3d(0, -60px, 0)\"\r\n  },\r\n  cardHeader: {\r\n    marginBottom: \"20px\"\r\n  },\r\n  socialLine: {\r\n    padding: \"0.9375rem 0\"\r\n  }\r\n});\r\n\r\nexport default loginPageStyle;\r\n","import React from \"react\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\nimport Email from \"@material-ui/icons/Email\";\n\n//REDUX\nimport history from \"store/history\";\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport GridContainer from \"components/Grid/GridContainer.js\";\nimport GridItem from \"components/Grid/GridItem.js\";\nimport CustomInput from \"components/CustomInput/CustomInput.js\";\nimport Button from \"components/CustomButtons/Button.js\";\nimport Card from \"components/Card/Card.js\";\nimport CardBody from \"components/Card/CardBody.js\";\nimport CardHeader from \"components/Card/CardHeader.js\";\nimport CardFooter from \"components/Card/CardFooter.js\";\nimport Password from \"components/Password\";\n\n// styles\nimport styles from \"assets/jss/material-dashboard-pro-react/views/loginPageStyle.js\";\n\n//FUNCTIONS\nimport api from \"api/\"\nimport { translate } from \"functions/\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function LoginPage(props) {\n  const query = new URLSearchParams(window.location.search);\n  const [user, setUser] = React.useState({ cPassword: null, password: null });\n  const classes = useStyles();\n\n  if (!query.get('token') || query.get('token').length !== 36) {\n    history.push('/')\n    // props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n    //   ...reduxStore.getState().db,\n    //   history: '/'\n    // });\n  }\n\n\n  const savePassword = async () => {\n    try {\n      const res = await api.post('/user/new-password', {\n        token: query.get('token'),\n        password: user.password,\n      })\n      if (res) {\n        localStorage.setItem('TOKEN', res.data.token)\n        if (props.callback) {\n          setTimeout(() => {\n            history.push('/login')\n            // props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            //   ...reduxStore.getState().db,\n            //   history: 'login'\n            // });\n          }, 3000)\n        }\n      }\n    } catch (err) {\n      props.callback({\n        fn: 'alert',\n        message: `${translate('$__invalidRequest', 1)} | ${translate('$__contactSupport', 1)}`,\n        variant: 'warning',\n        persist: false,\n        horizontal: 'center',\n        confirm: null\n      })\n    }\n  }\n\n  return (\n    <div className={classes.container}>\n      <GridContainer>\n        <GridItem xl={4} lg={4} md={4} sm={12} xs={12}>\n          <form>\n            <Card db=\"cards\" login>\n              <CardHeader\n                className={`${classes.cardHeader} ${classes.textCenter}`}\n                color=\"primary\"\n                style={{\n                  background: \"linear-gradient(60deg, rgba(15,18,35,1), rgba(2,33,88,1))\",\n                  boxShadow:\n                    \"0 4px 20px 0 rgba(15,18,35,0.14), 0 7px 10px -5px rgba(15,18,35,0.4)\"\n                }}\n              >\n                <h4 className={classes.cardTitle}>{translate('$__createPassword', 1)}</h4>\n              </CardHeader>\n              <CardBody>\n                <Password\n                  onConfirmed={(v) => {\n                    setUser({\n                      ...user,\n                      password: v\n                    })\n                  }} />\n              </CardBody>\n              <CardFooter className={classes.justifyContentCenter}>\n                {user && user.password &&\n                  <Button style={{ color: 'rgba(15,18,35,1)' }} simple size=\"lg\" block onClick={() => savePassword()}>\n                    {translate('$__save', '*')}\n                  </Button>\n                }\n              </CardFooter>\n            </Card>\n          </form>\n        </GridItem>\n      </GridContainer>\n    </div>\n  );\n}\n","//CORE\r\nimport React from 'react';\r\nimport styled from 'styled-components';\r\nimport { DragDropContext, Droppable, Draggable } from 'react-beautiful-dnd';\r\n\r\n//REDUX\r\nimport { connect } from 'react-redux'\r\nimport { bindActionCreators } from 'redux';\r\nimport * as reduxActions from 'store/actions';\r\nimport reduxStore from \"store/\";\r\n\r\n//COMPONENTS\r\nimport HeaderWithIcon from \"components/Header/withIcon.js\";\r\nimport IconButton from \"components/CustomButtons/IconButton.js\";\r\nimport Icons from \"components/Icons\";\r\nimport TextField from \"components/TextField\";\r\nimport GridContainer from \"components/Grid/GridContainer\";\r\nimport GridItem from \"components/Grid/GridItem\";\r\n\r\n//FUNCTIONS\r\nimport api from \"api/\";\r\nimport { translate } from \"functions/\";\r\n\r\nfunction Component(props) {\r\n    const [id, setId] = React.useState(null);\r\n    const [name, setName] = React.useState('');\r\n    const [icon, setIcon] = React.useState('');\r\n    const [editor, setEditor] = React.useState({});\r\n    const [board, setBoard] = React.useState({\r\n        open: false,\r\n        name: '',\r\n    })\r\n\r\n    const { db } = reduxStore.getState()\r\n    const { socket } = reduxStore.getState().functions\r\n\r\n    const onDragEnd = async result => {\r\n        const { destination, source, draggableId } = result\r\n\r\n        if (!destination) return false\r\n\r\n        if (destination.droppableId === source.droppableId && destination.id === source.index) return false\r\n\r\n        const itemOrderIds = Array.from(db.cards['boardModels'].boards[source.droppableId].columnOrder)\r\n        const board = source.droppableId\r\n        itemOrderIds.splice(source.index, 1)\r\n        itemOrderIds.splice(destination.index, 0, draggableId)\r\n\r\n        api.put('column/reorder', {\r\n            columns: itemOrderIds\r\n        })\r\n\r\n        let socketData = {\r\n            _parent: 'boardModels',\r\n            _board: board,\r\n            _order: itemOrderIds\r\n        }\r\n        socket.emit('column.REORDER', socketData)\r\n        return\r\n\r\n    }\r\n\r\n    const saveColumn = async (boardId) => {\r\n        let itemOrderIds = Array.from(db.cards['boardModels'].boards[boardId].columnOrder)\r\n        try {\r\n            let response\r\n            let columnData = {}\r\n            if (!id) {\r\n                response = await api.post('column/add', {\r\n                    board: boardId,\r\n                    name: name,\r\n                    icon: icon\r\n                })\r\n                columnData = {\r\n                    cards: [],\r\n                    name: name,\r\n                    _id: response.data.id,\r\n                    icon: icon,\r\n                }\r\n            } else {\r\n                response = await api.put('column/update', {\r\n                    _id: id,\r\n                    board: boardId,\r\n                    name: name,\r\n                    icon: icon\r\n                })\r\n                columnData = {\r\n                    name: name,\r\n                    _id: response.data.id,\r\n                    icon: icon,\r\n                }\r\n            }\r\n            if (response) {\r\n                if (!id)\r\n                    itemOrderIds.push(response.data.id)\r\n\r\n                let socketData = {\r\n                    _parent: 'boardModels',\r\n                    _columnId: response.data.id,\r\n                    _board: boardId,\r\n                    _cardColumn: 'boardModels',\r\n                    _columnData: columnData,\r\n                    _columnsOrder: itemOrderIds\r\n                }\r\n                socket.emit('column.UPD', socketData)\r\n\r\n                setEditor(false)\r\n                setName('')\r\n                setIcon('')\r\n                setId(null)\r\n            }\r\n        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    }\r\n    const deleteColumn = async (board, column) => {\r\n        const { socket } = reduxStore.getState().functions\r\n\r\n        try {\r\n            const response = await api.delete(`column/run/${column}__${board}`, {\r\n                board: board,\r\n                name: name,\r\n                icon: icon\r\n            })\r\n            if (response) {\r\n                let socketData = {\r\n                    _parent: 'boardModels',\r\n                    _board: board,\r\n                    _deleted: column\r\n                }\r\n                socket.emit('column.DELETE', socketData)\r\n            }\r\n        } catch (e) {\r\n        }\r\n    }\r\n\r\n    const saveBoard = async () => {\r\n        try {\r\n            const response = await api.post('boards/add', {\r\n                name: board.name\r\n            })\r\n\r\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                ...reduxStore.getState().db,\r\n                cards: {\r\n                    ...reduxStore.getState().db.cards,\r\n                    boardModels: {\r\n                        ...reduxStore.getState().db.cards.boardModels,\r\n                        boards: {\r\n                            ...reduxStore.getState().db.cards.boardModels.boards,\r\n                            ...response.data,\r\n                        }\r\n                    },\r\n                }\r\n            });\r\n            setBoard({\r\n                name: '',\r\n                open: false\r\n            })\r\n\r\n        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    }\r\n\r\n    return (\r\n        <GridContainer>\r\n            {db.cards\r\n                && db.cards['boardModels']\r\n                && db.cards['boardModels'].boards\r\n                && Object.keys(db.cards['boardModels'].boards).map(boardId => (\r\n                    <DragDropContext\r\n                        onDragEnd={onDragEnd}\r\n                        key={boardId}\r\n                    >\r\n                        <GridItem md={3} >\r\n                            <fieldset style={{\r\n                                width: '100%'\r\n                            }}>\r\n                                <legend>{db.cards['boardModels'].boards[boardId].name}</legend>\r\n                                <Droppable\r\n                                    droppableId={boardId} //ID OF BOARD\r\n                                    type=\"column\"\r\n                                    direction={'vertical'}\r\n                                >\r\n                                    {(provided, snapshot) => (\r\n                                        <Container\r\n                                            ref={provided.innerRef}\r\n                                            {...provided.droppableProps}\r\n                                            isDraggingOver={snapshot.isDraggingOver}\r\n                                        >\r\n                                            {!props.noList\r\n                                                && db.cards\r\n                                                && db.cards['boardModels']\r\n                                                && db.cards['boardModels'].boards\r\n                                                && db.cards['boardModels'].boards[boardId]\r\n                                                && db.cards['boardModels'].boards[boardId].columnOrder\r\n                                                && db.cards['boardModels'].boards[boardId].columnOrder.map((col, index) => (\r\n                                                    <Draggable draggableId={col} index={index} key={`${col}-${index}`}>\r\n                                                        {provided => (\r\n                                                            <ItemList\r\n                                                                {...provided}\r\n                                                                ref={provided.innerRef}\r\n                                                                {...provided.draggableProps}\r\n                                                                isDragging={snapshot.isDragging}\r\n                                                                {...provided.dragHandleProps}\r\n                                                            >\r\n                                                                {db.cards['boardModels'].boards[boardId].columns[col].name &&\r\n                                                                    <HeaderWithIcon\r\n                                                                        title={db.cards['boardModels'].boards[boardId].columns[col].name || ''}\r\n                                                                        icon={db.cards['boardModels'].boards[boardId].columns[col].icon || null}\r\n                                                                        iconTitle={'A'}\r\n                                                                        fontSize={'16px'}\r\n                                                                        customButtons={[\r\n                                                                            {\r\n                                                                                name: \"delete\",\r\n                                                                                icon: \"delete_forever\",\r\n                                                                                onClick: () => {\r\n                                                                                    deleteColumn(boardId, col)\r\n                                                                                },\r\n                                                                                show: 'hover'\r\n                                                                            },\r\n                                                                            {\r\n                                                                                name: \"edit\",\r\n                                                                                icon: \"edit\",\r\n                                                                                onClick: () => {\r\n                                                                                    setName(db.cards['boardModels'].boards[boardId].columns[col].name)\r\n                                                                                    setIcon(db.cards['boardModels'].boards[boardId].columns[col].icon || null)\r\n                                                                                    setId(col)\r\n                                                                                    setEditor({ [boardId]: { open: true } })\r\n                                                                                },\r\n                                                                                show: 'hover'\r\n                                                                            }\r\n                                                                        ]}\r\n                                                                    />\r\n                                                                }\r\n                                                            </ItemList>\r\n                                                        )}\r\n                                                    </Draggable>\r\n                                                ))}\r\n                                            {editor && editor[boardId] && editor[boardId].open ?\r\n                                                <React.Fragment>\r\n                                                    <ItemList>\r\n                                                        <div style={{ position: 'relative', float: 'left', width: '40px', height: 'auto', display: 'flex', justifyContent: 'center', alignItems: 'center' }}>\r\n                                                            <Icons callBack={(icon) => { setIcon(icon) }} />\r\n                                                        </div>\r\n                                                        <div style={{ position: 'relative', float: 'left', width: 'calc(100% - 40px)' }}>\r\n                                                            <TextField\r\n                                                                label={translate('$__nameOfColumn', 1)}\r\n                                                                variant={'outlined'}\r\n                                                                name=\"NewColumn\"\r\n                                                                InputLabelProps={{\r\n                                                                    shrink: true,\r\n                                                                }}\r\n                                                                InputProps={{\r\n                                                                    autoComplete: 'new-password',\r\n                                                                    onChange: (d) => {\r\n                                                                        setName(d.target.value)\r\n                                                                    },\r\n                                                                    onKeyPress: (d) => {\r\n                                                                        if (d.key === 'Enter' && d.target.value.length > 0)\r\n                                                                            saveColumn(boardId)\r\n                                                                    }\r\n                                                                }}\r\n                                                                value={name}\r\n                                                                placeholder={translate('$__name', 1)}\r\n                                                                styles={{ marginBotton: '0px !important' }}\r\n                                                                autoFocus\r\n                                                            />\r\n                                                        </div>\r\n                                                    </ItemList>\r\n                                                    <div style={{ display: 'inline-flex', alignItems: 'center', width: '100%', justifyContent: 'center' }}>\r\n                                                        <IconButton icon={'save'} text={translate(\"$__save\", \"*\")} onClick={() => { saveColumn(boardId) }} />\r\n                                                        <IconButton\r\n                                                            icon={translate(\"$__cancel\", \"*\")}\r\n                                                            iconColor='red'\r\n                                                            text={translate(\"$__cancel\", \"*\")}\r\n                                                            onClick={() => {\r\n                                                                setName('')\r\n                                                                setEditor({})\r\n                                                            }} />\r\n                                                    </div>\r\n                                                </React.Fragment>\r\n                                                :\r\n                                                <IconButton icon={'add_box'} text={translate(\"$__addColumn\", 1)} onClick={() => {\r\n                                                    setEditor({\r\n                                                        [boardId]: {\r\n                                                            open: true\r\n                                                        }\r\n                                                    })\r\n                                                }} />\r\n                                            }\r\n                                            {provided.placeholder}\r\n                                        </Container>\r\n                                    )}\r\n                                </Droppable>\r\n                            </fieldset>\r\n                        </GridItem>\r\n                    </DragDropContext>\r\n                ))}\r\n            <div>\r\n                {!board.open ?\r\n                    <IconButton icon={'add_box'} text={translate(\"$__addBoard\", 1)} onClick={() => { setBoard({ ...board, open: true }) }} />\r\n                    :\r\n                    <div style={{ position: 'relative', float: 'left', width: 'calc(100% - 40px)' }}>\r\n                        <TextField\r\n                            label={translate('$__boardName', 1)}\r\n                            variant={'outlined'}\r\n                            name=\"boardName\"\r\n                            InputLabelProps={{\r\n                                shrink: true,\r\n                            }}\r\n                            InputProps={{\r\n                                autoComplete: 'new-password',\r\n                                onChange: (d) => {\r\n                                    setBoard({ ...board, name: d.target.value })\r\n                                },\r\n                                onKeyPress: (d) => {\r\n                                    if (d.key === 'Enter' && d.target.value.length > 0)\r\n                                        saveBoard()\r\n                                }\r\n                            }}\r\n                            value={board && board.name}\r\n                            placeholder={translate('$__name', 1)}\r\n                            styles={{ marginBotton: '0px !important' }}\r\n                            autoFocus\r\n                        />\r\n                        <div style={{ display: 'inline-flex', alignItems: 'center', width: '100%', justifyContent: 'center' }}>\r\n                            <IconButton icon={'save'} text={translate(\"$__save\", \"*\")} onClick={() => { saveBoard() }} />\r\n                            <IconButton\r\n                                icon={'cancel'}\r\n                                iconColor='red'\r\n                                text={translate(\"$__cancel\", \"*\")}\r\n                                onClick={() => {\r\n                                    setName('')\r\n                                    setBoard({ open: false, name: '' })\r\n                                }} />\r\n                        </div>\r\n                    </div>\r\n                }\r\n            </div>\r\n        </GridContainer >\r\n    )\r\n}\r\n\r\nconst Container = styled.div`\r\n            background-color:none;\r\n\r\n            `\r\nconst ItemList = styled.div`\r\n            min-width:300px;\r\n            background-color: rgba(255,255,255,0.9);\r\n            padding: 7px;\r\n            margin-bottom:10px;\r\n            box-shadow: 0 0 7px rgba(0,0,0,0.2);\r\n            display:flex;\r\n            `\r\nconst mapStateToProps = store => ({\r\n    store\r\n});\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","import {\r\n    defaultFont,\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = theme => ({\r\n    root: {\r\n        ...defaultFont,\r\n        width: '100%',\r\n        marginBottom: theme.spacing(2),\r\n        padding: '7px',\r\n        height: 'calc(100vh - 220px)',\r\n        overflowX: 'auto',\r\n    },\r\n    header: {\r\n        position: 'relative',\r\n        float: 'left',\r\n        width: 'auto',\r\n        minWidth: '100%',\r\n        height: '50px',\r\n        display: 'flex',\r\n        alignItems: 'center',\r\n        backgroundColor: customApp('dark'),\r\n        color: customApp('light'),\r\n    },\r\n    column: {\r\n        padding: '7px 15px',\r\n        fontWeight: 'bold',\r\n        borderRight: `solid 1px ${customApp('light', 0.4)}`,\r\n        width: '300px',\r\n    },\r\n    column2: {\r\n        padding: '7px 15px',\r\n        fontWeight: 'bold',\r\n        borderRight: `solid 1px ${customApp('light', 0.4)}`,\r\n        // minWidth: '200px',\r\n        width: 'calc(100% - 300px)',\r\n    },\r\n    body: {\r\n        color: customApp('medium'),\r\n        position: 'relative',\r\n        clear: 'both',\r\n        display: 'flex',\r\n        alignItems: 'center',\r\n        borderBottom: `solid 1px ${customApp('medium', 0.2)}`,\r\n        '& ul': {\r\n            position: 'relative',\r\n            padding: '0px',\r\n            margin: '0px',\r\n            float: 'left',\r\n            minWidth: '100%',\r\n            '& li': {\r\n                minWidth: '100%',\r\n                width: 'fit-content',\r\n                display: 'flex',\r\n                listStyle: 'none',\r\n                padding: '15px 0px',\r\n                borderBottom: `1px solid ${customApp('medium', 0.2)}`\r\n            }\r\n        }\r\n    },\r\n    chip: {\r\n        margin: '3px'\r\n    }\r\n})\r\n\r\nexport default style;","import React from 'react';\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//@MATERIAL\nimport Paper from \"@material-ui/core/Paper\";\nimport TablePagination from '@material-ui/core/TablePagination';\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//COMPONENTS\nimport HeaderWithIcon from \"components/Header/withIcon\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport TextField from \"components/TextField\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Backoffice-languages.js\";\nimport { translate, customApp } from 'functions';\nimport api from \"api/\";\n\nfunction Component(props) {\n    const { classes } = props\n    const { languages, db } = reduxStore.getState()\n    const { socket } = reduxStore.getState().functions\n    const [onlyEmpty, setOnlyEmpty] = React.useState(false)\n    const [page, setPage] = React.useState(0)\n    const [limit, setLimit] = React.useState(25)\n    const [filter, setFilter] = React.useState(\"\")\n\n    //AQUI TEM QUE ATUALIZAR O DB LOCAL \n    const updateLanguage = async (id, alias, locale, text) => {\n        // console.log(id, alias, locale, text)\n        if (!id) {\n            socket.emit(\"data\", {\n                module: \"language\",\n                method: \"post\",\n                action: \"addLocale\"\n            }, {\n                alias,\n                locale,\n                text\n            })\n        } else {\n            socket.emit('language.UPD', {\n                alias,\n                locale,\n                text\n            })\n        }\n    }\n\n    const expanded = db.myTasksMenuExpanded ? true : false\n\n    return (\n        <div style={{ width: '100%' }}>\n            <div style={{\n                position: \"relative\",\n                float: 'left',\n                width: '100%',\n                left: '0px',\n                right: '0px',\n                padding: '15px',\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center'\n            }}>\n                {/* PAGINATION */}\n                {translate('$__page')} {page + 1} {translate('$__of')} {Math.ceil(Object.keys(languages).length / limit)}\n                <div style={{ display: 'flex', alignItems: 'center' }}>\n                    <TablePagination\n                        component=\"div\"\n                        count={Object.keys(languages).length}\n                        page={page}\n                        onChangePage={(event, newPage) => {\n                            setPage(newPage)\n                        }}\n                        rowsPerPage={limit}\n                        onChangeRowsPerPage={(event) => {\n                            setLimit(parseInt(event.target.value, 10))\n                        }}\n                        labelRowsPerPage={translate('$__cardsPerPage')}\n                    />\n                </div>\n            </div>\n            <div style={{ width: \"100%\", display: 'flex', alignItems: 'center' }}>\n                <TextField\n                    label={translate('$__search', 1)}\n                    variant={customApp('fieldVariant')}\n                    value={filter}\n                    onChange={(e) => {\n                        setFilter(e.target.value)\n                    }}\n                />\n                <IconButton\n                    text={translate(\"$__showOnlyEmpty\", '*')}\n                    icon={onlyEmpty ? \"subtitles_off\" : \"subtitles\"}\n                    iconColor={customApp('medium')}\n                    onClick={() => {\n                        setOnlyEmpty(!onlyEmpty);\n                    }}\n                />\n            </div>\n            <Paper className={classes.root}>\n                <div className={classes.header}>\n                    <div className={classes.column}>\n                        {translate(`alias`, 1)}\n                    </div>\n                    <div className={classes.column}>\n                        Portugues\n                    </div>\n                    <div className={classes.column}>\n                        Ingles\n                    </div>\n                </div>\n                <div className={classes.body}>\n                    <ul>\n                        {languages\n                            && Object.keys(languages)\n                            && Object.keys(languages).length > 0\n                            && Object.keys(languages)\n                                .filter(alias => {\n                                    if (\n                                        (\n                                            !filter\n                                            ||\n                                            (\n                                                filter\n                                                && (\n                                                    alias.indexOf(filter) > -1\n                                                    ||\n                                                    (\n                                                        languages[alias]\n                                                        && languages[alias].locales\n                                                        && Object.keys(languages[alias].locales).filter(a => languages[alias].locales[a].name.indexOf(filter) > -1).length > 0\n                                                    )\n                                                )\n                                            )\n                                        )\n                                        &&\n                                        (\n                                            (onlyEmpty\n                                                && languages[alias]\n                                                && (\n                                                    !languages[alias].locales\n                                                    || !languages[alias].locales['pt-BR']\n                                                    || !languages[alias].locales['pt-BR'].name\n                                                ))\n                                            ||\n                                            !onlyEmpty\n                                        )\n                                    )\n                                        return true\n                                }\n                                )\n                                .sort((a, b) => {\n                                    if (a < bindActionCreators) {\n                                        return -1\n                                    } else if (a > b) {\n                                        return 1\n                                    } else {\n                                        return 0\n                                    }\n                                })\n                                .map((alias, i) => {\n                                    if (i <= ((page + 1) * limit) && i >= page * limit)\n                                        return (<li key={alias.trim()}>\n                                            <div className={classes.column}>\n                                                {alias}\n                                            </div>\n                                            <div className={classes.column}>\n                                                <div style={{ position: 'relative' }}>\n                                                    <HeaderWithIcon\n                                                        key={`${alias}_pt-BR`}\n                                                        title={languages[alias].locales && languages[alias].locales['pt-BR'] && languages[alias].locales['pt-BR'].name && languages[alias].locales['pt-BR'].name}\n                                                        editable\n                                                        _id={languages[alias].locales && languages[alias].locales['pt-BR'] && languages[alias].locales['pt-BR'].id && languages[alias].locales['pt-BR'].id}\n                                                        onEdit={(text, id) => {\n                                                            console.log(text)\n                                                            // updateLanguage(id, alias, 'pt-BR', text)\n                                                        }\n                                                        }\n                                                        color={customApp('menu')}\n                                                        noAutoFocus={true}\n                                                        multiline\n                                                    />\n                                                </div>\n                                            </div>\n                                            <div className={classes.column}>\n                                                <div style={{ position: 'relative' }}>\n                                                    <HeaderWithIcon\n                                                        key={`${alias}_en-US`}\n                                                        title={languages[alias].locales && languages[alias].locales['en-US'] && languages[alias].locales['en-US'].name && languages[alias].locales['en-US'].name}\n                                                        editable\n                                                        _id={languages[alias].locales && languages[alias].locales['en-US'] && languages[alias].locales['en-US'].id && languages[alias].locales['en-US'].id}\n                                                        onEdit={(text, id) => {\n                                                            updateLanguage(id, alias, 'en-US', text)\n                                                        }\n                                                        }\n                                                        color={customApp('menu')}\n                                                        noAutoFocus={true}\n                                                        multiline\n                                                    />\n                                                </div>\n                                            </div>\n                                        </li>\n                                        )\n                                })}\n                    </ul>\n                </div>\n            </Paper >\n        </div>\n    );\n}\n\n//REACT\nconst mapStateToProps = (store) => ({\n    languages: store.languages\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","import React from \"react\";\r\n\r\nimport { decimal, formatNumber } from \"functions\"\r\n\r\nexport default class DecimalInput extends React.Component {\r\n    constructor(prop) {\r\n        super(prop);\r\n        this.state = { input: \"\" };\r\n        this.start = 0;\r\n    }\r\n\r\n    change = e => {\r\n        // this.start = e.target.selectionStart;\r\n        // let val = e.target.value;\r\n        // val = val.replace(/([^0-9.]+)/, \"\");\r\n        // val = val.replace(/^(0|\\.)/, \"\");\r\n        // const match = /(\\d{0,7})[^.]*((?:\\.\\d{0,2})?)/g.exec(val);\r\n        // const value = match[1] + match[2];\r\n        // e.target.value = value;\r\n        // this.setState({ input: value });\r\n        // if (val.length > 0) {\r\n        //     e.target.value = Number(value).toFixed(2);\r\n        //     e.target.setSelectionRange(this.start, this.start);\r\n        //     this.setState({ input: Number(value).toFixed(2) });\r\n        // }\r\n        // console.log(formatNumber(e.target.value))\r\n        this.setState({\r\n            input: decimal(e.target.value)\r\n        })\r\n    }\r\n\r\n    render() {\r\n        return (\r\n            <div>\r\n                <input\r\n                    type=\"text\"\r\n                    onBlur={this.blur}\r\n                    onChange={this.change}\r\n                    value={this.state.input}\r\n                    style={{ fontSize: \"22px\", padding: \"4px\" }}\r\n                    {...this.props}\r\n                />\r\n                <pre style={{ color: \"#999\", height: \"30px\" }}>{formatNumber(this.state.input)}</pre>\r\n            </div>\r\n        );\r\n    }\r\n}\r\n","import React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\nimport DecimalInput from \"./input\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//COMPONENTS\nimport Button from \"components/CustomButtons/Custom\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Backoffice-languages.js\"\n\n//FUNCTIONS\nimport { translate } from \"functions\"\nimport api from \"api/\"\nimport apims from \"apims\"\n\nfunction Component(props) {\n    const { classes } = props\n    const { languages, db } = reduxStore.getState()\n\n    const exportData = async () => {\n        const response = await api.post(\"exporting/allNodes\")\n    }\n\n    const testFiles = () => {\n        // socket.emit(\"data\", {\n        //     module: \"files\",\n        //     method: \"get\",\n        //     action: \"all\"\n        // }, {\n        //     nodeIds: [\"a2a00b96-b0ed-4031-9b22-157a9dab4bd6\", \"0c449e6e-5096-47ed-8aa7-7e3f8d0d72da\", \"a2a00b96-b0ed-4031-9b22-157a9dab4bd6\"]\n        // }, async (response) => {\n        //     console.log(response)\n        // })\n    }\n\n    const compactImages = async (node, instalThumb = false) => {\n        // socket.emit(\"data\", {\n        //     module: \"backoffice\",\n        //     method: \"post\",\n        //     action: \"compactImages\"\n        // }, {\n        //     node\n        // }, async (response) => {\n        //     Object.keys(response).map(async a => {\n        //         if (\n        //             (\n        //                 response[a].image\n        //                 && response[a].image.indexOf(\"machen.azureedge.net\") > -1\n        //             )\n        //             ||\n        //             (\n        //                 response[a].file\n        //                 && response[a].file.indexOf(\"machen.azureedge.net\") > -1\n        //             )\n        //         ) {\n        //             const blobFile = response[a].image ? response[a].image : response[a].file\n        //             const newImage = await urltoFile(blobFile, response[a].name, \"image/jpeg\")\n        //             let fileName = blobFile.replace(\"https://machen.azureedge.net/\", \"\").split(\".\")\n\n        //             //COMPACT IMAGE\n        //             const options = {\n        //                 maxSizeMB: 0.5,\n        //                 maxWidthOrHeight: 600,\n        //                 useWebWorker: true\n        //             }\n\n        //             try {\n        //                 const compressedFile = await imageCompression(newImage, options)\n        //                 if (newImage.size > compressedFile.size)\n        //                     await uploadThumb(fileName[0], fileName.length > 1 && fileName[fileName.length - 1] ? fileName[fileName.length - 1].toLowerCase() : null, compressedFile, instalThumb)\n        //             } catch (error) {\n        //                 console.log(error)\n        //             }\n        //         }\n        //         //COMPACT IMAGE\n        //     })\n        // })\n    }\n\n    const urltoFile = (url, filename, mimeType) => {\n        // return fetch(url)\n        //     .then(function (res) {\n        //         return res.arrayBuffer()\n        //     })\n        //     .then(function (buf) {\n        //         return new File([buf], filename, { type: mimeType })\n        //     })\n    }\n\n    // const feedRealocate = async () => {\n    //     await apims.get(`/Feed_Realocate`)\n    // }\n    // const readfeeds = async () => {\n    //     const response = await apims.post(`/Feed_List`)\n    //     if (response)\n    //         console.log(response.data)\n    // }\n    const expanded = db.myTasksMenuExpanded ? true : false\n\n    return (\n        <div style={expanded ? { width: \"calc(100% - 400x)\", marginLeft: \"388px\" } : { width: \"calc(100% - 138px)\", marginLeft: \"138px\" }}>\n            {/* <Button\n                style={{ position: \"relative\", float: \"left\", margin: \"3px\" }}\n                color={\"blue\"}\n                onClick={() => {\n                    testFiles()\n                }}\n            >\n                {translate(\"$__reqFiles\", \"*\")}\n            </Button> */}\n            {/* <Button\n                style={{ position: \"relative\", float: \"left\", margin: \"3px\" }}\n                color={\"blue\"}\n                onClick={() => {\n                    exportData()\n                }}\n            >\n                {translate(\"$__exportingData\", \"*\")}\n            </Button> */}\n            {/* <Button\n                style={{ position: \"relative\", float: \"left\", margin: \"3px\" }}\n                color={\"blue\"}\n                onClick={() => {\n                    compactImages(\"User\")\n                }}\n            >\n                {translate(\"$__compactUsersImages\", \"*\")}\n            </Button> */}\n            {/* <Button\n                style={{ position: \"relative\", float: \"left\", margin: \"3px\" }}\n                color={\"blue\"}\n                onClick={() => {\n                    feedRealocate(\"User\")\n                }}\n            >\n                {translate(\"$__feedRealocate\", \"*\")}\n            </Button>\n            <Button\n                style={{ position: \"relative\", float: \"left\", margin: \"3px\" }}\n                color={\"blue\"}\n                onClick={() => {\n                    readfeeds()\n                }}\n            >\n                {translate(\"$__Readfeeds\", \"*\")}\n            </Button> */}\n            {/* <Button\n                style={{ position: \"relative\", float: \"left\", margin: \"3px\" }}\n                color={\"blue\"}\n                onClick={() => {\n                    compactImages(\"File\", true)\n                }}\n            >\n                {translate(\"$__compactFilesImages\", \"*\")}\n            </Button>\n            <Button\n                style={{ position: \"relative\", float: \"left\", margin: \"3px\" }}\n                color={\"blue\"}\n                onClick={() => {\n                    compactImages(\"Card\", true)\n                }}\n            >\n                {translate(\"$__compactCardsImages\", \"*\")}\n            </Button> */}\n            <DecimalInput />\n        </div>\n    )\n}\n\n//REACT\nconst mapStateToProps = () => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component))","import React from 'react';\nimport PropTypes from 'prop-types';\n\n//@MATERIAL\nimport AppBar from '@material-ui/core/AppBar';\nimport Box from '@material-ui/core/Box';\nimport Tab from '@material-ui/core/Tab';\nimport Tabs from '@material-ui/core/Tabs';\nimport { makeStyles } from '@material-ui/core/styles';\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport BoardModels from \"components/BoardModels\";\nimport Button from \"components/CustomButtons/Custom\";\n\n//REDUX\nimport * as reduxActions from 'store/actions';\nimport history from \"store/history\";\nimport reduxStore from \"store/\";\nimport { bindActionCreators } from 'redux';\nimport { connect } from 'react-redux';\n\n//VIEWS\nimport Languages from \"views/BackOffice/languages\";\nimport Data from \"./data\";\n\n//FUNTIONS\nimport { customApp, translate } from \"functions/\";\n\n\nfunction TabPanel(props) {\n    const { children, value, index, ...other } = props;\n\n    return (\n        <div\n            role=\"tabpanel\"\n            hidden={value !== index}\n            id={`scrollable-strength-tabpanel-${index}`}\n            aria-labelledby={`scrollable-strength-tab-${index}`}\n            {...other}\n        >\n            {value === index && (\n                <Box p={3}>\n                    {children}\n                </Box>\n            )}\n        </div>\n    );\n}\n\nTabPanel.propTypes = {\n    children: PropTypes.node,\n    index: PropTypes.any.isRequired,\n    value: PropTypes.any.isRequired,\n};\n\nfunction a11yProps(index) {\n    return {\n        id: `scrollable-strength-tab-${index}`,\n        'aria-controls': `scrollable-strength-tabpanel-${index}`,\n    };\n}\n\nconst useStyles = makeStyles((theme) => ({\n    root: {\n        flexGrow: 1,\n        width: '100%',\n        backgroundColor: theme.palette.background.paper,\n    },\n}));\n\nfunction App(props) {\n    const classes = useStyles();\n    const { db } = reduxStore.getState()\n    const [value, setValue] = React.useState(0);\n    const [mounted, setMounted] = React.useState(false)\n    const [version, setVersion] = React.useState(\"\")\n\n    React.useEffect(() => {\n        if (!mounted) {\n            let hashs = window.location.hash.split('/')\n            hashs[0] = hashs[0].replace('#', '')\n            if (String(hashs[0])) {\n                setValue(Math.ceil(hashs[0]));\n            }\n            setMounted(true)\n        }\n    })\n\n    const handleChange = (event, newValue) => {\n        setValue(newValue);\n        history.push(`#${newValue}`)\n    };\n\n\n\n    const sendSocket = (fn) => {\n        const { socket } = reduxStore.getState().functions\n        socket.emit('global', {\n            fn: fn\n        })\n    }\n    const expanded = db.myTasksMenuExpanded ? true : false\n\n    return (\n        <div>\n            <AppBar position=\"static\" color=\"default\">\n                <Tabs\n                    value={value}\n                    onChange={handleChange}\n                    variant=\"scrollable\"\n                    scrollButtons=\"on\"\n                    indicatorColor=\"primary\"\n                    textColor=\"primary\"\n                    aria-label=\"\"\n                >\n                    <Tab label=\"Data\" icon={<Icon color={customApp(value === 0 ? 'medium' : 'color'), 1}>Data</Icon>} {...a11yProps(0)} />\n                    <Tab label=\"Languages\" icon={<Icon color={customApp(value === 1 ? 'medium' : 'color'), 1}>translate</Icon>} {...a11yProps(1)} />\n                    <Tab label=\"Versions\" icon={<Icon color={customApp(value === 2 ? 'medium' : 'color'), 1}>app_registration</Icon>} {...a11yProps(2)} />\n                    {/* <Tab label=\"Board Models\" hash=\"boards\" icon={<Icon color={customApp(value === 3 ? 'medium' : 'color'), 1}>view_column</Icon>} {...a11yProps(0)} />\n                    <Tab label=\"Accounts\" icon={<Icon color={customApp(value === 4 ? 'medium' : 'color'), 1}>contacts</Icon>} {...a11yProps(1)} />\n                    <Tab label=\"Users\" icon={<Icon color={customApp(value === 5 ? 'medium' : 'color'), 1}>supervisor_account</Icon>} {...a11yProps(2)} />\n                    <Tab label=\"Support\" icon={<Icon color={customApp(value === 6 ? 'medium' : 'color'), 1}>support</Icon>} {...a11yProps(3)} />\n                    <Tab label=\"Finance\" icon={<Icon color={customApp(value === 7 ? 'medium' : 'color'), 1}>account_balance</Icon>} {...a11yProps(4)} /> */}\n                </Tabs>\n            </AppBar>\n            <TabPanel value={value} index={0}>\n                <div>\n                    <Data />\n                </div>\n            </TabPanel>\n            <TabPanel value={value} index={1}>\n                <div>\n                    <Languages />\n                </div>\n            </TabPanel>\n            <TabPanel value={value} index={2}>\n                <div>\n                    <input type=\"text\" value={version}\n                        onChange={e => {\n                            setVersion(e.target.value)\n                        }} />\n                    <Button\n                        style={{ position: 'relative', float: 'left', margin: '3px' }}\n                        color={'primary'}\n                        onClick={() => {\n                            sendSocket('version')\n                        }}\n                    >\n                        {translate('$__send', '*')}\n                    </Button>\n                    <Button\n                        style={{ position: 'relative', float: 'left', margin: '3px' }}\n                        color={'primary'}\n                        onClick={() => {\n                            sendSocket('logout')\n                        }}\n                    >\n                        {translate('$__logout', '*')}\n                    </Button>\n                    <Button\n                        style={{ position: 'relative', float: 'left', margin: '3px' }}\n                        color={'primary'}\n                        onClick={() => {\n                            sendSocket('reload')\n                        }}\n                    >\n                        {translate('$__reload', '*')}\n                    </Button>\n                </div>\n            </TabPanel>\n            <TabPanel value={value} index={3}>\n                <div>\n                    <BoardModels />\n                </div>\n            </TabPanel>\n            <TabPanel value={value} index={4}>\n                {translate('$__accounts', 1)}\n            </TabPanel>\n            <TabPanel value={value} index={5}>\n                {translate('$__users', 1)}\n            </TabPanel>\n            <TabPanel value={value} index={6}>\n                {translate('$__support', 1)}\n            </TabPanel>\n            <TabPanel value={value} index={7}>\n                {translate('$__finance', 1)}\n            </TabPanel>\n        </div>\n    );\n}\n\nconst mapStateToProps = (store) => ({\n    history: store.db.history\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(App);","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\n\n//COMPONENTS\nimport LinearProgress from \"components/Progress/linear\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card-KPI.js\"\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n} from \"functions/\"\n\nfunction Component(props) {\n    // console.log('loading', Object.keys(props.loaders).filter(l => props.loaders[l] === \"loading\").length)\n    return (\n        <React.Fragment>\n            {props.loaders\n                && Object.keys(props.loaders).length > 0\n                && Object.keys(props.loaders).filter(l => props.loaders[l] === \"loading\").length > 0\n                &&\n                <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"center\", width: \"100%\" }}>\n                    <span style={{ color: customApp('menu'), fontSize: \"12px\", paddingRight: \"15px\", whiteSpace: \"nowrap\" }}>{translate('$__loadingData')}</span>\n                    <LinearProgress />\n                </div>\n            }\n        </React.Fragment>\n    )\n}\nconst mapStateToProps = (store) => ({\n    loaders: store.sessionLoads.cards.load\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","import {\r\n  defaultFont,\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport textField from \"./TextField.js\"\r\n\r\nimport { customApp } from \"functions/\";\r\n\r\nconst headerStyle = () => ({\r\n  ...textField,\r\n  appBar: {\r\n    boxShadow: \"none\",\r\n    borderBottom: \"0\",\r\n    marginBottom: \"0\",\r\n    position: \"fixed\",\r\n    width: \"100%\",\r\n    zIndex: \"100\",\r\n    color: '#FFFFFF',\r\n    border: \"0\",\r\n    minHeight: \"0px\",\r\n    display: \"flex\",\r\n    height: \"50px\",\r\n    justifyContent: \"center\",\r\n    userSelect: 'none',\r\n  },\r\n  container: {\r\n    //minHeight: \"30px\"\r\n  },\r\n  separator: {\r\n    position: \"absolute\",\r\n    left: \"0px\",\r\n    right: \"0px\",\r\n    bottom: \"-2px\",\r\n    height: \"2px\",\r\n    backgroundColor: customApp('line')\r\n  },\r\n  search: {\r\n    position: \"absolute\",\r\n    left: \"62px\",\r\n    right: \"0px\",\r\n    //paddingLeft: '70px',\r\n    bottom: \"-35px\",\r\n    height: \"33px\",\r\n    boxShadow: \"0 3px 3px rgba(0,0,0,0.33)\",\r\n    display: \"block\",\r\n    padding: \"0 15px\",\r\n    zIndex: 1,\r\n    backgroundColor: customApp('menu'),\r\n    \"& .selectedCard\": {\r\n      position: 'relative',\r\n      float: 'left',\r\n      width: '250px',\r\n      height: '33px',\r\n      display: 'flex !important',\r\n      alignItems: 'center'\r\n    }\r\n  },\r\n  searchMobile: {\r\n    position: \"absolute\",\r\n    left: \"0px\",\r\n    right: \"0px\",\r\n    paddingLeft: '15px',\r\n    bottom: \"-35px\",\r\n    height: \"33px\",\r\n    boxShadow: \"0 3px 3px rgba(0,0,0,0.33)\",\r\n    display: \"block\",\r\n    padding: \"0 15px\",\r\n    backgroundColor: customApp('menu'),\r\n    \"& .selectedCard\": {\r\n      position: 'relative',\r\n      float: 'left',\r\n      width: '250px',\r\n      height: '33px',\r\n      display: 'flex !important',\r\n      alignItems: 'center'\r\n    }\r\n  },\r\n  flex: {\r\n    flex: 1\r\n  },\r\n  title: {\r\n    ...defaultFont,\r\n    lineHeight: \"30px\",\r\n    fontSize: \"18px\",\r\n    borderRadius: \"3px\",\r\n    textTransform: \"none\",\r\n    color: \"inherit\",\r\n    paddingTop: \"0.625rem\",\r\n    paddingBottom: \"0.625rem\",\r\n    margin: \"0 !important\",\r\n    letterSpacing: \"unset\",\r\n    \"&:hover,&:focus\": {\r\n      background: \"transparent\"\r\n    }\r\n  },\r\n  logo: {\r\n    position: \"fixed\",\r\n    padding: \"7px 0px\",\r\n    margin: \"0\",\r\n    display: \"flex\",\r\n    zIndex: \"4\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\"\r\n  },\r\n  logoMini: {\r\n    transition: \"all 300ms linear\",\r\n    opacity: 1,\r\n    textAlign: \"center\",\r\n    width: \"40px\",\r\n    maxHeight: \"40px\",\r\n    marginLeft: \"10px\",\r\n    marginRight: \"8px\",\r\n    color: \"inherit\",\r\n  },\r\n  logoImg: {\r\n    width: \"100%\",\r\n  },\r\n  logoNormal: {\r\n    ...defaultFont,\r\n    margin: \"auto\",\r\n    transition: \"all 300ms linear\",\r\n    opacity: \"1\",\r\n    transform: \"translate3d(0px, 0, 0)\",\r\n    textTransform: \"uppercase\",\r\n    fontSize: \"18px\",\r\n    whiteSpace: \"nowrap\",\r\n    fontWeight: \"400\",\r\n    overflow: \"hidden\",\r\n    color: `${customApp('light')} !important`,\r\n    \"&,&:hover,&:focus\": {\r\n      color: \"inherit\"\r\n    }\r\n  },\r\n  page: {\r\n    position: 'relative',\r\n    color: customApp('line'), fontSize: '16px',\r\n    textTransform: 'uppercase',\r\n    cursor: 'pointer',\r\n    '& a': {\r\n      color: '#FFFFFF'\r\n    }\r\n  },\r\n  pageLink: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    color: customApp('light'),\r\n    margin: '7px',\r\n    fontSize: '14px',\r\n    cursor: 'pointer',\r\n    userSelect: 'none',\r\n    '&:hover': {\r\n      fontWeight: 'bold'\r\n    },\r\n    '& a': {\r\n      color: '#FFFFFF'\r\n    }\r\n  },\r\n  pageLinkActive: {\r\n    color: customApp('line'),\r\n    margin: '7px',\r\n    fontSize: '14px',\r\n    cursor: 'pointer',\r\n    userSelect: 'none',\r\n    fontWeight: 'bold',\r\n  },\r\n  activeArrow: {\r\n    position: 'absolute',\r\n    left: 'calc(50% - 11px)',\r\n    bottom: '-23px',\r\n    transform: 'rotate(-90deg)'\r\n  }\r\n});\r\n\r\nexport default headerStyle;\r\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport Routes from \"routes\";\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Autocomplete from \"components/AutoComplete/multiple\";\nimport Avatar from \"@material-ui/core/Avatar\";\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\nimport Icon from \"components/Icon\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport Tooltip from \"@material-ui/core/Tooltip\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//IMAGES\nimport defaultAvatar from \"assets/img/fundo-sonne.png\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/filter.js\";\n\n//FUNCTIONS\nimport {\n    customApp,\n    translate,\n    getAppAccess\n} from \"functions/\";\n\n//VARIABLES\nimport { initialState } from \"store/search-initialState\";\n\nconst useStyles = makeStyles(styles);\nfunction FilterComponent(props) {\n    const classes = useStyles();\n    const { session, search, db } = reduxStore.getState();\n    const [viewSearch, setviewSearch] = React.useState(false);\n\n    let AppAccess = getAppAccess()\n\n    let fields = []\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace('#', '')\n    if (hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n\n    const locationPathName = window.location.pathname.split('/')\n    const pathName = `/${locationPathName[1]}`\n\n    let CardAccess = 1\n    if (hashs[0]) {\n        let data = db.cards[hashs[0]] || {}\n        CardAccess = data && data._users && Object.keys(data._users).length > 0 ? data._users[Object.keys(data._users).find(a => a.indexOf(session._id) > -1)] : 0\n        if (CardAccess && CardAccess.access)\n            CardAccess = CardAccess.access\n    }\n\n\n    if (hashs[1] && Routes.filter(a => a.path === pathName).length > 0 && Routes.filter(a => a.path === pathName)[0].tabs && Routes.filter(a => a.path === pathName)[0].tabs.length > 0) {\n        let tabs = Routes.filter(a => a.path === pathName)[0].tabs && Routes.filter(a => a.path === pathName)[0].tabs\n        tabs.map(a => {\n            if (a.path === hashs[1])\n                fields = a.searchFields\n        })\n    } else if (Routes.filter(a => a.path === pathName).length > 0 && Routes.filter(a => a.path === pathName)[0].searchFields) {\n        fields = Routes.filter(a => a.path === pathName)[0].searchFields\n    }\n\n    if (JSON.stringify(initialState) === JSON.stringify(search)) {\n        return (<React.Fragment></React.Fragment>)\n    }\n\n    //Filters\n\n    // let cardsFilter = { }\n    // let userFilter = []\n    // let chatFilter = []\n    // let timelineFilter = []\n    // let fileFiltes = []\n\n    // Object.keys(db.cards).filter(card =>\n    // (\n    //     (\n    //         (\n    //             AppAccess.owner\n    //             || AppAccess.planAdmin\n    //             || AppAccess.planModerate\n    //             || AppAccess.planRead\n    //         )\n    //         ||\n    //         (\n    //             session._id\n    //             && db.cards[card]._users\n    //             && db.cards[card]._users[Object.keys(db.cards[card]._users).find(a => a.indexOf(session._id) > -1)]\n    //         )\n    //     )\n    //     &&\n    //     (\n    //         search\n    //         && search.text\n    //         //&& removeSeats(db.cards[card].name).toLowerCase().indexOf(removeSeats(search.text).toLowerCase()) > -1\n    //     )\n\n    // )\n    // ).map(card => {\n    //     if (\n    //         (\n    //             search\n    //             && search.text\n    //             && removeSeats(db.cards[card].name).toLowerCase().indexOf(removeSeats(search.text).toLowerCase()) > -1\n    //         )\n    //     )\n    //         cardsFilter = {\n    //             ...cardsFilter,\n    //             [card]: db.cards[card]\n    //         }\n    // })\n\n    // console.log(cardsFilter)\n\n    return (\n        <div style={{\n            // position: 'relative',\n            // width: '100%',\n        }}>\n            <GridContainer>\n                <GridItem\n                    xs={12}\n                    sm={9}\n                    md={9}\n                    lg={9}\n                    xl={9}\n                >\n                    <span style={{\n                        color: customApp('medium'),\n                        fontWeight: 'bold',\n                        fontSize: '18px',\n                        display: 'flex',\n                        alignItems: 'center'\n                    }}>\n                        <Icon size=\"18px\">search</Icon>\n                        {translate('$__appliedFilters')}\n                    </span>\n                </GridItem>\n                <GridItem\n                    xs={12}\n                    sm={3}\n                    md={3}\n                    lg={3}\n                    xl={3}\n                >\n                    <div style={{\n                        display: \"flex\",\n                        justifyContent: 'flex-end'\n                    }}>\n                        <IconButton reverse icon={'clear_all'} text={translate(\"$__clearFilter\", \"*\")}\n                            onClick={() => {\n                                props.reduxFunction(\"ASYNC\", \"SEARCH_CLEAR\")\n                            }} />\n                    </div>\n                </GridItem>\n                {fields && fields.indexOf('text') > -1 && search.text &&\n                    <GridItem\n                        xs={6}\n                        sm={4}\n                        md={2}\n                        lg={2}\n                        xl={2}\n                    >\n                        <div className={classes.textField} style={{ width: \"100%\" }}>\n                            {translate('$__text')}: {search.text}\n                        </div>\n                    </GridItem>\n                }\n\n                {/* FILTER BY TAGS */}\n\n                {/* FILTER BY STATUS */}\n                {fields && fields.indexOf('status') > -1 && JSON.stringify(search.cards.status) !== JSON.stringify(initialState.cards.status) &&\n                    <GridItem\n                        xs={6}\n                        sm={4}\n                        md={2}\n                        lg={2}\n                        xl={2}\n                    >\n                        <div style={{ color: customApp('color'), fontSize: '16px' }}>\n                            <div\n                                style={{\n                                    position: 'relative',\n                                    float: 'left',\n                                }}>\n                                {translate('$__status')}\n                            </div>\n                            {Object.keys(search.cards.status).map((a, i) => {\n                                if (search.cards.status[a] && a !== 'all')\n                                    return (\n                                        <Tooltip\n                                            title={translate(db.status.filter(fil => fil.value === a)[0].label, 1)}\n                                            key={i}\n                                        >\n                                            <div\n                                                style={{\n                                                    position: 'relative',\n                                                    float: 'left',\n                                                    width: '11px',\n                                                    height: '11px',\n                                                    borderRadius: '50%',\n                                                    backgroundColor: db.status.filter(fil => fil.value === a)[0].color,\n                                                    margin: '7px 3px',\n                                                }}></div>\n                                        </Tooltip>\n                                    )\n                            })}\n                        </div>\n                    </GridItem>\n                }\n\n                {/* FILTER BY PRIORITY */}\n                {fields && fields.indexOf('priority') > -1 && JSON.stringify(search.cards.priority) !== JSON.stringify(initialState.cards.priority) &&\n                    <GridItem\n                        xs={6}\n                        sm={4}\n                        md={2}\n                        lg={2}\n                        xl={2}\n                    >\n                        <div style={{ color: customApp('color'), fontSize: '16px' }}>\n                            <div\n                                style={{\n                                    position: 'relative',\n                                    float: 'left',\n                                }}>\n                                {translate('$__priority')}\n                            </div>\n                            {Object.keys(search.cards.priority).map((a, i) => {\n                                if (search.cards.priority[a] && a !== 'all') {\n                                    return (\n                                        <Tooltip\n                                            title={translate(db.priority.filter(fil => String(fil.value) === String(a))[0].label, 1)}\n                                            key={i}\n                                        >\n                                            <div\n                                                style={{\n                                                    position: 'relative',\n                                                    float: 'left',\n                                                    width: '11px',\n                                                    height: '11px',\n                                                    borderRadius: '50%',\n                                                    backgroundColor: db.priority.filter(fil => String(fil.value) === String(a))[0].color,\n                                                    margin: '7px 3px',\n                                                }}></div>\n                                        </Tooltip>\n                                    )\n                                }\n                            })}\n                        </div>\n                    </GridItem>\n                }\n\n                {/* FILTER BY USER */}\n                {fields && fields.indexOf('users') > -1 && JSON.stringify(search.users) !== JSON.stringify(initialState.users) &&\n                    <GridItem\n                        xs={6}\n                        sm={4}\n                        md={2}\n                        lg={2}\n                        xl={2}\n                    >\n                        <div style={{ color: customApp('color'), fontSize: '16px' }}>\n                            {translate('$__users')}\n                            <AvatarGroup max={6}>\n                                {Object.keys(reduxStore.getState().search.users.selected).length > 0 && Object.keys(reduxStore.getState().search.users.selected).map((a, i) => (\n                                    a !== 'unassigned' && reduxStore.getState().search.users.selected[a] ?\n                                        <Tooltip\n                                            title={db.users[a].name}\n                                            key={i}\n                                        >\n                                            <Avatar style={{ width: '30px', height: '30px' }} alt={db.users[a].name} src={db.users[a].image || null} >\n                                                {db.users[a].name.substr(0, 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                        : a === 'unassigned' && reduxStore.getState().search.users.selected[a] &&\n                                        <Tooltip\n                                            title={translate('$__unassigned', 1)}\n                                            key={i}\n                                        >\n                                            <Avatar style={{ width: '30px', height: '30px' }} alt={translate('$__unassigned', 1)} src={defaultAvatar} >\n                                                {translate('$__unassigned', 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                ))}\n                            </AvatarGroup>\n                        </div>\n                    </GridItem>\n                }\n                {fields && fields.indexOf('units') > -1 && JSON.stringify(search.units) !== JSON.stringify(initialState.units) &&\n                    Object.keys(db.users).filter(a => db.users[a].type !== 'user').length > 0 && fields.indexOf('units') > -1 &&\n                    /* FILTER BY CLIENT */\n                    <GridItem\n                        xs={6}\n                        sm={4}\n                        md={2}\n                        lg={2}\n                        xl={2}\n                    >\n                        <div style={{ color: customApp('color'), fontSize: '16px' }}>\n                            {translate('$__units')}\n                            <AvatarGroup max={6}>\n                                {Object.keys(reduxStore.getState().search.units.selected).length > 0 && Object.keys(reduxStore.getState().search.units.selected).map((a, i) => (\n                                    a !== 'unassigned' && reduxStore.getState().search.units.selected[a] ?\n                                        <Tooltip\n                                            title={db.users[a].name}\n                                            key={i}\n                                        >\n                                            <Avatar style={{ width: '30px', height: '30px' }} alt={db.users[a].name} src={db.users[a].image || null} >\n                                                {db.users[a].name.substr(0, 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                        : a === 'unassigned' && reduxStore.getState().search.units.selected[a] &&\n                                        <Tooltip\n                                            title={translate('$__unassigned', 1)}\n                                            key={i}\n                                        >\n                                            <Avatar style={{ width: '30px', height: '30px' }} alt={translate('$__unassigned', 1)} src={defaultAvatar} >\n                                                {translate('$__unassigned', 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                ))}\n                            </AvatarGroup>\n                        </div>\n                    </GridItem>\n                }\n\n                {\n                    reduxStore.getState().search.plans && reduxStore.getState().search.plans.selected && Object.keys(reduxStore.getState().search.plans.selected).length > 0 && Object.keys(db.cards).filter(a => db.cards[a].type === 'plan').length > 0 && fields && fields.indexOf('plans') > -1 &&\n                    /* FILTER BY PLANS */\n                    <GridItem\n                        xs={6}\n                        sm={4}\n                        md={2}\n                        lg={2}\n                        xl={2}\n                    >\n                        <div style={{ color: customApp('color'), fontSize: '16px' }}>\n                            {translate('$__plans')}\n                            <AvatarGroup max={6}>\n                                {Object.keys(reduxStore.getState().search.plans.selected).length > 0 && Object.keys(reduxStore.getState().search.plans.selected).map((a, i) => (\n                                    a !== 'unassigned' && reduxStore.getState().search.plans.selected[a] ?\n                                        <Tooltip\n                                            title={db.cards[a].name}\n                                            key={i}\n                                        >\n                                            <Avatar style={{ width: '30px', height: '30px' }} alt={db.cards[a].name} src={db.cards[a].image || null} >\n                                                {db.cards[a].name.substr(0, 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                        : a === 'unassigned' && reduxStore.getState().search.plans.selected[a] &&\n                                        <Tooltip\n                                            title={translate('$__unassigned', 1)}\n                                            key={i}\n                                        >\n                                            <Avatar style={{ width: '30px', height: '30px' }} alt={translate('$__unassigned', 1)} src={defaultAvatar} >\n                                                {translate('$__unassigned', 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                ))}\n                            </AvatarGroup>\n                        </div>\n                    </GridItem>\n                }\n                {/* FINAL FILTER PARAMETERS */}\n                <GridItem\n                    xs={12}\n                    sm={12}\n                    md={12}\n                    lg={12}\n                    xl={12}\n                >\n                    {\n                        //Cards\n                    }\n                </GridItem>\n            </GridContainer >\n        </div>\n    );\n}\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(FilterComponent)","//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = theme => ({\r\n    card: {\r\n        width: 'calc(20% - 20px)',\r\n        minWidth: '250px',\r\n        maxWidth: '400px',\r\n        margin: '10px',\r\n        placeSelf: 'flex-end',\r\n    }\r\n})\r\n\r\nexport default style;","import React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\n\n//COMPONENTS\nimport Card from \"components/Card\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\n\n//@MATERIAL\nimport TablePagination from '@material-ui/core/TablePagination';\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/InsightBoards.js\";\n\n//FUNCTIONS\n\nimport {\n    loadCardsV2\n} from \"functions/loadData\"\n\nfunction InsightsBC(props) {\n    const { db, search, session } = reduxStore.getState()\n    const [page, setPage] = React.useState(0)\n    const [limit, setLimit] = React.useState(21)\n    const [loading, setLoading] = React.useState(false)\n    const [end, setEnd] = React.useState(false)\n\n    React.useEffect(() => {\n        loadInsights(page, limit)\n        return () => {\n            // return false\n        }\n    }, [])\n\n    React.useEffect(() => {\n        if (!loading && !end)\n            loadInsights(page, limit)\n    }, [page, limit])\n\n    const loadInsights = async (page, limit) => {\n        setLoading(true)\n        let res = await loadCardsV2(props, {\n            cardLoad: 'insights',\n            limit: limit,\n            skip: page * limit,\n            ignoreLoader: true\n        })\n        if (res) {\n            setLoading(false)\n            if (res.total < limit)\n                setEnd(true)\n        }\n    }\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    let radarCards = {}\n\n    radarCards = Object.keys(db.cards)\n        .filter(a =>\n            db.cards[a].type === 'insight'\n            && !db.cards[a].deleted\n            && db.cards[a]._users\n            && db.cards[a]._users[session._id]\n        )\n        .sort((a, b) => {\n            if (db.cards[a].created_at > db.cards[b].created_at)\n                return -1\n            return 0\n        })\n        .map(a => db.cards[a])\n\n    radarCards = radarCards.filter(a =>\n    ((a.description && a.description.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n        || (a.name && a.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n    )).map(a => a)\n\n    if (search.tags.length > 0)\n        radarCards = radarCards.filter(fil =>\n            fil._tags && fil._tags.length > 0 && fil._tags.filter(tag => {\n                let result = false\n                search.tags.map(tagFilter => {\n                    if (tagFilter.value === tag.value)\n                        result = true\n                })\n                return result\n            }\n            ).length > 0\n        ).map(res => res)\n\n    const scrollFunction = (e) => {\n        var scrollDiv = document.getElementById(`insightList`);\n        if (scrollDiv.scrollTop + window.innerHeight + 150 > scrollDiv.scrollHeight)\n            setPage(page + 1)\n    }\n\n    return (\n        <div\n            id={\"insightList\"}\n            style={!props.horizontal ? {\n                position: 'absolute',\n                top: 0,\n                bottom: 0,\n                left: 0,\n                right: 0,\n                display: \"flex\",\n                overflowY: \"auto\",\n\n            } : { position: 'relative', justifyContent: 'space-between', margin: 'auto', width: '100%' }}\n            onScroll={!props.horizontal ? (e) => {\n                scrollFunction(e)\n            } : null}\n        >\n            <GridContainer\n                style={{\n                    ...props.horizontal ? {\n                        overflowX: \"auto\",\n                        flexFlow: \"row\",\n                        display: \"-webkit-inline-box\"\n                    } : {}\n                }}\n            >\n                {Object.keys(radarCards)\n                    .filter((i, ii) => (!props.max || (props.max && ii < props.max)))\n                    .map((card, i) => {\n                        return (\n                            <GridItem\n                                key={radarCards[card]._id}\n                                xs={12}\n                                sm={6}\n                                md={4}\n                                lg={3}\n                                xl={2}\n                            >\n                                <Card db=\"cards\" data={radarCards[card]} expanded Avatar Resume showConnectedIn LoadParent />\n                            </GridItem>\n                        )\n                    })}\n            </GridContainer>\n        </div>\n    )\n}\n\nconst mapStateToProps = (store, ownProps) => {\n    return {\n        cards: store.db.cards,\n        search: store.search\n    };\n};\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(InsightsBC));","//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = theme => ({\r\n    feed: {\r\n        backgroundColor: 'rgba(255,255,255,1)',\r\n        margin: 'auto',\r\n        // padding: '7px 7px 0px 7px',\r\n        boxShadow: '0 0 7px 3px rgba(0,0,0,0.05)',\r\n        width: \"-webkit-fill-available\",\r\n        marginBottom: \"15px\",\r\n        // height: \"calc(100% - 17px)\",\r\n        borderTopRightRadius: 22,\r\n        // overflow: \"hidden !important\"\r\n    },\r\n    infos: {\r\n        padding: '7px',\r\n        cursor: \"pointer\"\r\n    },\r\n    feedRotate: {\r\n        width: 'calc(20% - 20px)',\r\n        minWidth: '250px',\r\n        maxWidth: '400px',\r\n        backgroundColor: 'rgba(255,255,255,1)',\r\n        padding: '7px 7px 20px 7px',\r\n        boxShadow: '0 0 7px 3px rgba(0,0,0,0.05)',\r\n        placeSelf: 'flex-end',\r\n        cursor: 'pointer'\r\n    },\r\n    image: {\r\n        width: '100%',\r\n        paddingTop: `calc((9 / 16) * 100%)`,\r\n        backgroundPosition: 'center',\r\n        backgroundRepeat: \"no-repeat\"\r\n    },\r\n    linkTitle: {\r\n        marginTop: '7px',\r\n        width: '100%',\r\n        height: 'auto',\r\n        fontWeight: 'bold',\r\n        minHeight: \"65px\"\r\n    },\r\n    linkContent: {\r\n        width: '100%',\r\n        marginTop: '7px',\r\n        height: '87px',\r\n        textOverflow: 'ellipsis',\r\n        overflow: 'hidden'\r\n    },\r\n    feedFooter: {\r\n        marginTop: '7px',\r\n        width: '100%',\r\n        textAlign: 'right',\r\n        justifyContent: 'space-between',\r\n        borderTop: '1px solid rgba(0,0,0,0.05)',\r\n        paddingTop: '3px',\r\n        display: 'flex',\r\n        marginBottom: '7px'\r\n    },\r\n    feedDate: {\r\n        position: 'relative',\r\n        left: '0px',\r\n        fontSize: '12px',\r\n        float: 'left'\r\n    },\r\n    feedLink: {\r\n        position: 'relative',\r\n        left: '0px',\r\n        fontSize: '12px',\r\n        float: 'right',\r\n        display: 'flex'\r\n    }\r\n})\r\n\r\nexport default style;","//CORE\nimport React from 'react'\nimport Moment from \"moment-timezone\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport Skeleton from \"@material-ui/lab/Skeleton\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/BrightAndConnected-card.js\";\nimport { translate } from 'functions';\n\n\n\nfunction Component(props) {\n    const { data, classes } = props;\n\n    return (\n        <div className={classes.feed}\n        >\n            <Skeleton variant=\"rect\" animation=\"wave\"\n                style={\n                    {\n                        borderRadius: 0,\n                        paddingTop: \"calc((9 / 16) * 100%)\",\n                        width: \"100%\",\n                        borderTopRightRadius: 22,\n                    }\n                }\n            />\n            <div className={classes.infos}>\n                <div className={classes.linkTitle}>\n                    <Skeleton variant=\"rect\" animation=\"wave\"\n                        style={\n                            {\n                                width: \"100%\",\n                                height: \"12px\",\n                                marginBottom: 10\n                            }\n                        }\n                    />\n                    <Skeleton variant=\"rect\" animation=\"wave\"\n                        style={\n                            {\n                                width: \"100%\",\n                                height: \"12px\",\n                                marginBottom: 10\n                            }\n                        }\n                    />\n                    <Skeleton variant=\"rect\" animation=\"wave\"\n                        style={\n                            {\n                                width: \"100%\",\n                                height: \"12px\",\n                                marginBottom: 10\n                            }\n                        }\n                    />\n                </div>\n                <div\n                    className={classes.linkContent}\n                >\n                    <Skeleton variant=\"rect\"\n                        style={\n                            {\n                                marginTop: 15,\n                                borderRadius: 7,\n                                width: \"100%\",\n                                height: 8,\n                                marginBottom: 12\n                            }\n                        }\n                    />\n                    <Skeleton variant=\"rect\"\n                        style={\n                            {\n                                borderRadius: 7,\n                                width: \"100%\",\n                                height: 8,\n                                marginBottom: 12\n                            }\n                        }\n                    />\n                    <Skeleton variant=\"rect\"\n                        style={\n                            {\n                                borderRadius: 7,\n                                width: \"100%\",\n                                height: 8,\n                                marginBottom: 12\n                            }\n                        }\n                    />\n                    <Skeleton variant=\"rect\"\n                        style={\n                            {\n                                borderRadius: 7,\n                                width: \"100%\",\n                                height: 8,\n                                marginBottom: 12\n                            }\n                        }\n                    />\n                </div>\n                <div className={classes.feedFooter}>\n                    <div\n                        className={classes.feedDate}\n                        style={{\n                            width: \"50%\",\n                            height: \"20px\",\n                            display: \"flex\",\n                            alignItems: \"center\",\n                        }}\n                    >\n                        <div style={{\n                            width: \"100%\",\n                            height: \"8px\"\n                        }}>\n                            <Skeleton variant=\"rect\"\n                                style={\n                                    {\n                                        borderRadius: 7,\n                                        width: \"100%\",\n                                        height: 8,\n                                    }\n                                }\n                            />\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n    )\n}\n\nconst mapStateToProps = store => ({\n    store\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","import React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\n\n//COMPONENTS\nimport Card from \"components/Card\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\nimport SkeletonCard from \"components/BrightAndConnected/skeletonCard\";\n\n//@MATERIAL\nimport TablePagination from '@material-ui/core/TablePagination';\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp\n} from \"functions/\"\n\nimport {\n    loadCardsV2\n} from \"functions/loadData\"\n\nfunction Radar(props) {\n    const { db, search, session } = reduxStore.getState()\n    const [page, setPage] = React.useState(0)\n    const [limit, setLimit] = React.useState(18)\n    const [loading, setLoading] = React.useState(false)\n    const [end, setEnd] = React.useState(false)\n    const [total, setTotal] = React.useState(0)\n\n    React.useEffect(() => {\n        loadLinks(page, limit)\n        return () => {\n\n        }\n    }, [])\n\n    React.useEffect(() => {\n        // console.log(38)\n        if (!loading && !end)\n            loadLinks(page, limit)\n    }, [page, limit])\n\n    const loadLinks = async (page, limit) => {\n        setLoading(true)\n        let res = await loadCardsV2(props, {\n            cardLoad: 'links',\n            limit: limit,\n            skip: page * limit,\n            ignoreLoader: true\n        })\n        if (res) {\n            setLoading(false)\n            setTotal(parseInt(res.total))\n            if (res.total < limit)\n                setEnd(true)\n        }\n    }\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    let radarCards = {}\n\n    radarCards = Object.keys(db.cards)\n        .filter(a =>\n            db.cards[a].type === 'link'\n            && db.cards[a]._users\n            && db.cards[a]._users[session._id]\n            && !db.cards[a].deleted\n        )\n        .sort((a, b) => {\n            if (db.cards[a].created_at > db.cards[b].created_at)\n                return -1\n            return 0\n        })\n        .map(a => db.cards[a])\n\n    radarCards = radarCards.filter(a =>\n    ((a.description && a.description.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n        || (a.name && a.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n    )).map(a => a)\n\n    if (search.tags.length > 0)\n        radarCards = radarCards.filter(fil =>\n            fil._tags && fil._tags.length > 0 && fil._tags.filter(tag => {\n                let result = false\n                search.tags.map(tagFilter => {\n                    if (tagFilter.value === tag.value)\n                        result = true\n                })\n                return result\n            }\n            ).length > 0\n        ).map(res => res)\n\n    const scrollFunction = (e) => {\n        var scrollDiv = document.getElementById(`linkList`);\n        if (scrollDiv.scrollTop + window.innerHeight + 150 > scrollDiv.scrollHeight)\n            setPage(page + 1)\n    }\n\n    const RenderSkeleton = () => {\n        let rows = []\n        for (var i = 0; i < limit; i++) {\n            rows.push(<GridItem\n                xs={12}\n                sm={6}\n                md={4}\n                lg={3}\n                xl={2}\n                key={`sk_${i}`}\n            >\n                <SkeletonCard />\n            </GridItem>)\n        }\n        return <React.Fragment>{rows}</React.Fragment>\n    }\n\n    return (\n        <div\n            id={\"linkList\"}\n            style={!props.horizontal ? {\n                position: 'absolute',\n                top: 0,\n                bottom: 0,\n                left: 0,\n                right: 0,\n                display: \"flex\",\n                overflowY: \"auto\",\n\n            } : {\n                position: 'relative',\n                justifyContent: 'space-between',\n                margin: 'auto',\n                width: '100%'\n            }}\n            onScroll={!props.horizontal ? (e) => {\n                scrollFunction(e)\n            } : null}\n        >\n            <GridContainer\n                style={{\n                    ...props.horizontal ? {\n                        overflowX: \"auto\",\n                        flexFlow: \"row\",\n                        display: \"-webkit-inline-box\"\n                    } : {}\n                }}\n            >\n                <div>\n\n                </div>\n\n                {Object.keys(radarCards)\n                    .filter((r, ri) => (!props.max || (props.max && ri < props.max)))\n                    .map((card, i) => {\n                        return (\n                            <GridItem\n                                key={radarCards[card]._id}\n                                xs={12}\n                                sm={6}\n                                md={4}\n                                lg={3}\n                                xl={2}\n                            >\n                                <Card db=\"cards\" data={radarCards[card]} expanded Avatar Resume showConnectedIn LoadParent />\n                            </GridItem>\n                        )\n                    })}\n                {loading ?\n                    <RenderSkeleton />\n                    : <React.Fragment></React.Fragment>}\n            </GridContainer>\n        </div>\n    )\n}\n\nconst mapStateToProps = (store, props) => {\n    return {\n        cards: store.db.cards,\n        search: store.search\n    };\n};\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(Radar);","//CORE\nimport React from 'react'\nimport Moment from \"moment-timezone\"\nimport utf8 from \"utf8\"\nimport isValidUTF8 from \"utf-8-validate\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n\n//COMPONENTS\nimport CardTags from \"components/Tags/Card\"\nimport CustomButton from \"components/Buttons/custom\"\nimport HtmlTooltip from \"components/Tooltip/html\"\nimport Icon from \"components/Icon\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/BrightAndConnected-card.js\"\nimport { translate, customApp } from 'functions'\n\nimport BrightAndConnectedIco from \"assets/icons/BrigthAndConnected\"\n\n\nfunction Component(props) {\n    const { data, classes } = props\n    const [image, setImage] = React.useState(data.img)\n    const [backSize, setBackSize] = React.useState({\n        backgroundSize: \"contain\",\n    })\n\n    const sendToInsight = () => {\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...reduxStore.getState().sideModule,\n            id: 'new',\n            activeModule: 'cardEdit',\n            db: 'cards',\n            data: {\n                _id: 'new',\n                type: 'link',\n                name: data.title,\n                description: data.contentSnippet,\n                pubDate: data.isoDate ? data.isoDate : data.pubDate,\n                image: data.img,\n                url: data.link,\n            }\n        })\n    }\n\n    const onImgLoad = ({ target: img }) => {\n        if (img && img.width && img.height) {\n            if (img.width > img.height) {\n                if (img.width / img.height > 1.75) {\n                    setBackSize({\n                        backgroundSize: \"contain\"\n                    })\n\n                } else {\n                    setBackSize({\n                        backgroundSize: \"cover\"\n                    })\n                }\n            } else {\n                setBackSize({\n                    backgroundSize: \"cover\"\n                })\n            }\n        }\n    }\n\n    return (\n        <div className={classes.feed}\n            onClick={props.clickChannel ? () => props.clickChannel() : null}\n            style={{\n                ...props.clickChannel ? { cursor: \"pointer\" } : {},\n                position: 'relative'\n            }}\n        >\n            <div style={{ display: \"none\" }}>\n                <img src={image} onError={() => {\n                    setImage(null)\n                }}\n                    onLoad={onImgLoad}\n                />\n            </div>\n            <div\n                className={classes.image}\n                style={\n                    {\n                        position: \"relative\",\n                        display: 'flex',\n                        alignItems: 'center',\n                        justifyContent: 'center',\n                        cursor: 'pointer',\n                        ...image ?\n                            {\n                                backgroundImage: `url(\"${image}\")`,\n                                ...backSize,\n                            } : {\n                                background: customApp('AvatarBackground'),\n                            },\n                    }\n                }\n                onClick={() => {\n                    if (!props.clickChannel)\n                        window.open(data.link, \"_blank\")\n                }}\n            >\n                {!image &&\n                    <div style={{ marginTop: \"calc(-48% - 10px)\", display: 'flex', justifyContent: 'center', alignItems: 'center' }}>\n                        <Icon icon={BrightAndConnectedIco} size=\"39px\" color={customApp(\"textColor\")} />\n                    </div>\n                }\n                {!props.clickChannel &&\n                    <div\n                        style={{\n                            position: \"absolute\",\n                            top: 7,\n                            right: 7\n                        }}\n                    >\n                        <CustomButton\n                            title={translate(`$__sendToRadar`, '*')}\n                            color={customApp('menu')}\n                            icon={'settings_input_antenna'}\n                            onClick={() => { sendToInsight() }}\n                            size={'25px'}\n                        />\n                    </div>\n                }\n                <div\n                    style={{\n                        position: \"absolute\",\n                        bottom: 0,\n                        left: 0,\n                        backgroundColor: \"rgba(0,0,0,0.5)\",\n                        padding: \"3px 7px\",\n                        color: \"white\",\n                        fontSize: 11\n                    }}\n                >\n                    {Moment(data.isoDate ? data.isoDate : data.pubDate).format('DD/MM/YYYY HH:MM')}\n                </div>\n            </div>\n\n            <HtmlTooltip\n                // arrow\n                title={(\n                    <React.Fragment>\n                        {!props.clickChannel &&\n                            <a href={data.link} target=\"_blank\" rel=\"noopener noreferrer\" style={{ fontSize: \"14px\", fontWeight: \"bold\" }}>\n                                {translate(\"$__clickHereToReadNews\", 1)}\n                            </a>\n                        }\n                    </React.Fragment>\n                )\n                } >\n                <div className={classes.infos}\n                    onClick={() => {\n                        if (!props.clickChannel)\n                            window.open(data.link, \"_blank\")\n                    }}\n                >\n                    <div className={classes.linkTitle}>\n                        <div\n                            dangerouslySetInnerHTML={{ __html: data && data.title && isValidUTF8(data.title) ? data.title : data.title ? utf8(data.title) : `` }}>\n                        </div>\n                    </div>\n                    <div\n                        dangerouslySetInnerHTML={{ __html: data.contentSnippet && isValidUTF8(data.contentSnippet) ? data.contentSnippet : data.contentSnippet ? utf8(data.contentSnippet) : `` }}\n                        className={classes.linkContent}\n                    />\n\n                    <div className={classes.feedFooter}>\n                        <div className={classes.feedLink} >\n                            {!props.clickChannel &&\n                                <a href={data.link} target=\"_blank\" rel=\"noopener noreferrer\" style={{ fontSize: \"14px\", fontWeight: \"bold\" }}>\n                                    {translate(\"$__readMore\", 1)}\n                                </a>\n                            }\n                        </div>\n                    </div>\n                </div>\n            </HtmlTooltip>\n            <div style={{ top: -30 }}>\n                <CardTags\n                    options={props._tags}\n                // expanded={}\n                />\n            </div>\n        </div>\n    )\n}\n\nconst mapStateToProps = store => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React from 'react'\nimport Moment from \"moment-timezone\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/BrightAndConnected-card.js\";\nimport { translate, customApp } from 'functions';\n\nimport BrightAndConnectedIco from \"assets/icons/BrigthAndConnected\";\n\nfunction Component(props) {\n    const { data, classes } = props;\n\n    return (\n        <div className={classes.feed}\n            onClick={props.clickChannel ? () => props.clickChannel() : null}\n        >\n            <div className={classes.image}\n                style={\n                    {\n                        background: customApp('AvatarBackground'),\n                        display: 'flex',\n                        alignItems: 'center',\n                        justifyContent: 'center'\n                    }\n                }\n            >\n                <div style={{ marginTop: \"calc(-48% + 0px)\", display: 'flex', justifyContent: 'center', alignItems: 'center' }}>\n                    <Icon icon={BrightAndConnectedIco} size=\"47px\" color=\"rgba(250,250,250,0.77)\" />\n\n                    {/* <img src={BrightAndConnectedIco} style={{ width: '25%' }} /> */}\n                </div>\n            </div>\n            <div className={classes.infos}>\n                <div className={classes.linkTitle}>\n                    {translate('$__attention')}\n                </div>\n                <div\n                    className={classes.linkContent}\n                >\n                    {translate('$__weHaveNotFoundYetLink')}\n                </div>\n                <div className={classes.feedFooter}>\n                    <div className={classes.feedDate}>\n                        {Moment(data.created_at && data.created_at.low ? data.created_at.low : data.created_at).format('DD/MM/YYYY HH:MM')}\n                    </div>\n                </div>\n            </div>\n        </div>\n    )\n}\n\nexport default withStyles(styles)(Component)","//CORE\nimport React from \"react\"\nimport CryptoJS from \"crypto-js\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport history from \"store/history\"\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport Badge from \"components/Icon/Badge\"\nimport Card from \"./card\"\nimport HeaderWithIcon from \"components/Header/card\"\n\n//DEPENDENCIES\nimport FeedFakeCard from \"./FeedFakeCard\"\n\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/BrightAndConnected-card.js\"\n\n//FUNCTIONS\nimport api from \"api/\"\nimport {\n    translate,\n    customApp,\n    getAppAccess,\n    appAlert\n} from \"functions/\"\n\nfunction Component(props) {\n    const { db, session } = reduxStore.getState()\n    let data = props.data\n\n    let AppAccess = getAppAccess()\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    if (!data)\n        return null\n\n    const setTitle = async (title) => {\n        let id = hashs[0] && hashs[0].length === 36 ? data._parent[hashs[0]].idRel : data._parent[session.account].idRel\n        if (\n            data._parent\n            && Object.keys(data._parent).length === 1\n            && Object.keys(data._parent).filter(caid => reduxStore.getState().db.cards[caid]).length === 0\n            && data._parent[Object.keys(data._parent)[0]].idRel\n        ) {\n            id = data._parent[Object.keys(data._parent)[0]].idRel\n        }\n        const response = await api.put(\"/rel/update\", {\n            _id: id,\n            customTitle: title\n        })\n        let feeds = reduxStore.getState().db.feeds\n\n        if (\n            data._parent\n            && Object.keys(data._parent).length === 1\n            && Object.keys(data._parent).filter(caid => reduxStore.getState().db.cards[caid]).length === 0\n            && data._parent[Object.keys(data._parent)[0]].idRel\n        ) {\n            feeds[data._id] = {\n                ...feeds[data._id],\n                _parent: {\n                    ...feeds[data._id]._parent,\n                    [Object.keys(data._parent)[0]]: {\n                        ...feeds[data._id]._parent[Object.keys(data._parent)[0]],\n                        customTitle: title,\n                    }\n                }\n            }\n        } else {\n            feeds[data._id] = {\n                ...feeds[data._id],\n                _parent: {\n                    ...feeds[data._id]._parent,\n                    [hashs[0]]: {\n                        ...feeds[data._id]._parent[hashs[0]],\n                        customTitle: title,\n                    }\n                }\n            }\n        }\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...db,\n            feeds: feeds\n        })\n        if (props.onChange)\n            props.onChange()\n    }\n    const deleteChannel = async (pid) => {\n        appAlert({\n            message: translate(\"$__confirmDeleteThis\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                confirmDeleteChannel(pid)\n            }\n        })\n    }\n    const confirmDeleteChannel = async (pid) => {\n        let deleteId = pid ? pid : hashs[0]\n        const response = await api.delete(`feed/unfollow/${deleteId}__${data._id}`)\n\n        let feeds = {\n            ...reduxStore.getState().db.feeds\n        }\n        if (feeds[data._id] && feeds[data._id]._parent && feeds[data._id]._parent[deleteId]) {\n            delete feeds[data._id]._parent[deleteId]\n        }\n\n\n        if (pid && feeds[data._id]) {\n            delete feeds[data._id]\n        }\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...db,\n            feeds: {\n                ...feeds\n            }\n        })\n\n        if (props.onChange)\n            setTimeout(() => {\n                props.onChange()\n            }, 400)\n    }\n\n    const changeVisible = async (parent, visible = false) => {\n        const response = await api.put(`feed/visible/`, {\n            feedId: data._id,\n            visible: data && data.hide ? false : true,\n        })\n        // if (reduxStore.getState().db.cards[parent]) {\n        let feed = data\n        feed = {\n            ...feed,\n            hide: data && data.hide ? false : true,\n        }\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...db,\n            feeds: {\n                ...db.feeds,\n                [data._id]: {\n                    ...db.feeds[data._id],\n                    ...feed\n                }\n            }\n        })\n        // }\n    }\n\n\n    const ConnectedIn = () => {\n        if (props.data._parent) {\n\n            let options = []\n\n            Object.keys(props.data._parent).map(pid => {\n                if (reduxStore.getState().db.cards[pid] && reduxStore.getState().db.cards[pid]._users && reduxStore.getState().db.cards[pid]._users[session._id]) {\n                    let parent = reduxStore.getState().db.cards[pid]\n                    options = [...options, {\n                        name: parent.name,\n                        icon: \"view_comfy\",\n                        render: (\n                            <React.Fragment>\n                                <div style={{ marginRight: \"10px\", width: \"100%\", display: \"flex\", color: customApp(\"color\") }}>\n                                    <div style={{ width: \"33px\" }}>\n                                        <Badge\n                                            overlap=\"rectangular\"\n                                            icon={parent.type && db && db.dataType ? db.dataType.filter(a => a.name === parent.type)[0].icon : \"topic\"}\n                                            title={`$__${parent.type}`}\n                                            size=\"22px\"\n                                            color={customApp(\"menu\")}\n                                        />\n                                    </div>\n                                    <div style={{ width: \"calc(100% - 7px)\", display: \"flex\", whiteSpace: \"nowrap\", textOverflow: \"ellipsis\", overflow: \"hidden\" }}>\n                                        {parent.name}\n                                    </div>\n                                </div>\n                            </React.Fragment>\n                        ),\n                        onClick: () => {\n                            history.push(`sp#${pid}/bright-and-connected`)\n                        }\n                    }\n                    ]\n                } else if (Object.keys(props.data._parent).length === 1) {\n                    options = [...options, {\n                        name: translate(\"$__globalAccount\"),\n                        icon: \"rss_feed\",\n                        render: (\n                            <React.Fragment>\n                                <div style={{ marginRight: \"10px\", width: \"100%\", display: \"flex\" }}>\n                                    <div style={{ width: \"33px\" }}>\n                                        <Badge\n                                            overlap=\"rectangular\"\n                                            icon={\"rss_feed\"}\n                                            title={translate(`$__globalAccount`)}\n                                            size=\"22px\"\n                                            color={customApp(\"menu\")}\n                                        />\n                                    </div>\n                                    <div style={{ width: \"calc(100% - 7px)\", display: \"flex\", whiteSpace: \"nowrap\", textOverflow: \"ellipsis\", overflow: \"hidden\" }}>\n                                        {translate(`$__globalAccount}`)}\n                                    </div>\n                                    <div style={{ width: \"16px\" }}>\n                                        <Badge\n                                            overlap=\"rectangular\"\n                                            icon={\"delete_forever\"}\n                                            title={translate(\"$__delete\")}\n                                            size=\"22px\"\n                                            color={\"red\"}\n                                            onClick={() => {\n                                                deleteChannel(pid)\n                                            }}\n                                        />\n                                    </div>\n                                </div>\n                            </React.Fragment>\n                        ),\n                        onClick: () => {\n                            deleteChannel(pid)\n                        }\n                    }\n                    ]\n                }\n            })\n            return options\n        }\n    }\n\n    if (data._parent)\n        Object.keys(data._parent).map(a => {\n            if (hashs[0] && hashs[0].length === 36 && hashs[0] === a) {\n                data.customTitle = data._parent[a].customTitle\n            } else if (Object.keys(data._parent).length > 0) {\n                data.customTitle = data._parent[Object.keys(data._parent)[0]].customTitle\n            }\n        })\n\n    return (\n        <div\n            style={{\n                position: \"relative\",\n                height: 'auto',\n                cursor: 'pointer',\n                width: \"100%\"\n            }}\n        >\n\n            <HeaderWithIcon\n                title={data.customTitle ? data.customTitle : data.name}\n                icon={'chrome_reader_mode'}\n                fontSize='20px'\n                onEdit={(text, id) => setTitle(text)}\n                color={customApp(\"color\")}\n                editable={\n                    (\n                        (\n\n                            hashs[0] && hashs[0].length === 36 && AppAccess && AppAccess.plan\n                            && (\n                                AppAccess.planAdmin\n                                || AppAccess.planModerate\n                            )\n                        )\n                        ||\n                        (\n                            data._parent\n                            && Object.keys(data._parent).length === 1\n                            && Object.keys(data._parent).filter(caid => reduxStore.getState().db.cards[caid]).length === 0\n                        )\n                    )\n                        ? true\n                        : false\n                }\n                moreButton={true}\n                {...(hashs[0]\n                    && hashs[0] === 'tab'\n                    && AppAccess && AppAccess.plan\n                    && (\n                        AppAccess.planAdmin\n                        || AppAccess.planModerate\n                    )\n                )\n                    ?\n                    {\n                        ...data._parent && Object.keys(data._parent).length > 0 && {\n                            options: [\n                                ...[{\n                                    name: data.hide ? translate(\"$__folowRSS\") : translate(\"$__hideRSS\"),\n                                    icon: data.hide ? \"visibility\" : \"visibility_off\",\n                                    // render: (\n                                    //     <React.Fragment>\n                                    //         <div style={{ marginRight: \"10px\", width: \"100%\", display: \"flex\" }}>\n                                    //             <div style={{ width: \"33px\" }}>\n                                    //                 <Badge\n                                    //                     icon={parent.type && db && db.dataType ? db.dataType.filter(a => a.name === parent.type)[0].icon : \"topic\"}\n                                    //                     title={`$__${parent.type}`}\n                                    //                     size=\"22px\"\n                                    //                     color={customApp(\"menu\")}\n                                    //                 />\n                                    //             </div>\n                                    //             <div style={{ width: \"calc(100% - 7px)\", display: \"flex\", whiteSpace: \"nowrap\", textOverflow: \"ellipsis\", overflow: \"hidden\" }}>\n                                    //                 {parent.name}\n                                    //             </div>\n                                    //         </div>\n                                    //     </React.Fragment>\n                                    // ),\n                                    onClick: () => {\n                                        changeVisible()\n                                    }\n                                },\n\n                                ],\n                                ...AppAccess && AppAccess.feed && (\n                                    AppAccess.feedAdmin\n                                    || AppAccess.feedModerate\n                                ) ?\n                                    [{\n                                        name: translate(\"$__edit\"),\n                                        icon: 'settings_suggest',\n                                        onClick: () => {\n                                            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                ...reduxStore.getState().sideModule,\n                                                db: 'feeds',\n                                                id: data._id,\n                                                module: \"feedEdit\",\n                                                activeModule: \"feedEdit\",\n                                                data: {\n                                                    ...data,\n                                                    _lock: true,\n                                                    _admin: props.admin ? true : false\n                                                },\n                                            })\n                                        }\n                                    }] : [],\n                                ...ConnectedIn()\n                            ]\n                        }\n                    } : (AppAccess && AppAccess.plan\n                        && (\n                            AppAccess.planAdmin\n                            || AppAccess.planModerate\n                        )) ? {\n                        options: [\n                            {\n                                name: translate(\"$__deleteRSS\"),\n                                icon: \"delete_forever\",\n                                onClick: () => {\n                                    deleteChannel()\n                                }\n                            }\n                        ]\n                    } : {}}\n            />\n            <div\n                style={{\n                    padding: '0',\n                    display: 'flex',\n                    marginBottom: '15px',\n                    flexFlow: 'wrap',\n                    marginTop: '15px',\n                }}\n            >\n                {data.feed && Object.keys(data.feed).length > 0 ?\n                    Object.keys(data.feed).sort((a, b) => {\n                        if (data.feed[a].isoDate && data.feed[b].isoDate && data.feed[a].isoDate < data.feed[b].isoDate)\n                            return 1\n                        return -1\n                    }).map((lk, ii) => {\n                        let link = data.feed[lk]\n                        let id = CryptoJS.MD5(link.link)\n                        if (data)\n                            if (ii === 0)\n                                return (\n                                    <Card\n                                        key={id}\n                                        data={link}\n                                        _tags={data._tags}\n                                        clickChannel={() => {\n                                            history.push(`${window.location.pathname}${window.location.hash}/${data._id}`)\n                                        }}\n                                    />\n                                )\n                    })\n                    :\n                    <FeedFakeCard\n                        data={data}\n                        clickChannel={() => {\n                            history.push(`${window.location.pathname}${window.location.hash}/${data._id}`)\n                        }}\n                    />\n                }\n            </div>\n        </div >\n    )\n}\nconst mapStateToProps = store => ({\n    store\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport Card from \"./card\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport IconButton from \"components/CustomButtons/IconButton.js\"\nimport SkeletonCard from \"./skeletonCard\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/BrightAndConnected-card.js\"\n\n//FUNCTIONS\nimport api from \"api/\"\nimport {\n    translate,\n    appAlert\n} from \"functions/\"\nimport apims from \"apims\"\n\n\nfunction ListLinks(props) {\n    const { data } = props\n    const { db } = reduxStore.getState()\n    const [page, setPage] = React.useState(0)\n    const [total, setTotal] = React.useState(0)\n    const [limit, setLimit] = React.useState(21)\n    const [hashs, setHashs] = React.useState([])\n    const [links, setLinks] = React.useState([])\n    const [max, setMax] = React.useState(0)\n    const [loading, setLoading] = React.useState(true)\n    const [mounted, setMounted] = React.useState(false)\n\n    React.useEffect(() => {\n        let Nhashs = window.location.hash.split(\"/\")\n        Nhashs[0] = Nhashs[0].replace(\"#\", \"\")\n        if (JSON.stringify(Nhashs) !== JSON.stringify(hashs)) {\n            setHashs(Nhashs)\n        }\n        setLoading(true)\n        // loadLinks(page, limit)\n        if (props.max) {\n            setMax(props.max)\n            setLimit(props.max)\n        }\n\n        return () => {\n\n        }\n    }, [])\n\n    React.useEffect(() => {\n        if (hashs.length > 0 && !mounted) {\n            loadLinks(page, limit)\n            if (hashs[2] && hashs[2].length !== 36) {\n                setLoading(true)\n            }\n            setMounted(true)\n        }\n    }, [hashs])\n\n    React.useEffect(() => {\n        if (total > Object.keys(links).length) {\n            setLoading(true)\n            loadLinks(page, limit)\n        }\n    }, [page, limit])\n\n    React.useEffect(() => {\n        setLoading(false)\n    }, [links])\n\n    const loadLinks = async (p, l) => {\n        if ((total === 0 || total > Object.keys(links).length)) {\n            setLoading(true)\n\n            const response = await apims.post(\"/Feed_Links\", {\n                ids: hashs[2] && hashs[2].length ? hashs[2] : null,\n                skip: p * l,\n                limit: l\n            })\n\n\n            let loadFeeds = Array.from(links)\n            if (response && response.data && response.data.links) {\n                response.data.links.map(lk => {\n                    if (loadFeeds.filter(fil => fil.link === lk.link).length === 0)\n                        loadFeeds.push(lk)\n                })\n            }\n            if (response.data && response.data.total && total === 0) {\n                setTotal(response.data.total)\n            }\n            setLinks(loadFeeds)\n        }\n    }\n\n    const setTitle = async (title) => {\n        const response = await api.put(\"/rel/update\", {\n            _id: data.idRel,\n            customTitle: title\n        })\n        let feeds = db.cards[hashs[0].replace(\"#\", \"\")]._feeds\n        feeds[data._id] = {\n            ...feeds[data._id],\n            customTitle: title,\n        }\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...db,\n            cards: {\n                ...db.cards,\n                [hashs[0].replace(\"#\", \"\")]: {\n                    ...db.cards[hashs[0].replace(\"#\", \"\")],\n                    _feeds: feeds,\n                }\n            }\n        });\n    }\n    const deleteChannel = async (parent) => {\n        window.history.back()\n        let idPlan = parent.replace(\"#\", \"\")\n        const response = await api.delete(`feed/unfollow/${idPlan}__${data._id}`)\n        let feeds = db.cards[idPlan]._feeds\n        delete feeds[data._id]\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...db,\n            cards: {\n                ...db.cards,\n                [idPlan]: {\n                    ...db.cards[idPlan],\n                    _feeds: feeds,\n                }\n            }\n        });\n    }\n\n    const scrollFunction = (e) => {\n        var scrollDiv = document.getElementById(`linkList`);\n        if (!loading && scrollDiv.scrollTop + window.innerHeight + 400 > scrollDiv.scrollHeight && !props.horizontal)\n            setPage(page + 1)\n    }\n\n    const RenderSkeleton = () => {\n        let rows = []\n        for (var i = 0; i < limit; i++) {\n            rows.push(<GridItem\n                xs={12}\n                sm={6}\n                md={4}\n                lg={3}\n                xl={2}\n                key={`sk_${i}`}\n            >\n                <SkeletonCard />\n            </GridItem>)\n        }\n        return <React.Fragment>{rows}</React.Fragment>\n    }\n\n    return (\n        <div>\n            {data && (data.customTitle || data.name) &&\n                <div style={{\n                    position: \"absolute\",\n                    top: 0,\n                    left: 0,\n                    right: 0,\n                    height: 33\n                }}>\n                    <div style={{ position: \"relative\", width: \"100%\", float: \"left\", marginBottom: \"15px\", display: \"flex\" }}>\n                        <IconButton icon=\"undo\" text={translate(\"$__back\", \"*\")} onClick={() => window.history.back()} />\n                        {hashs[0] && hashs[1] === \"bright-and-connected\" && hashs[2] &&\n                            <IconButton icon=\"delete_sweep\" text={translate(\"$__removeChannel\", \"*\")}\n                                onClick={\n                                    () => {\n                                        appAlert({\n                                            message: translate(\"$__confirmRemoveChannel\", 1),\n                                            variant: \"warning\",\n                                            persist: false,\n                                            horizontal: \"right\",\n                                            confirm: () => {\n                                                deleteChannel(hashs[0])\n                                            }\n                                        })\n                                    }\n                                }\n                            />\n                        }\n                    </div>\n                    <HeaderWithIcon\n                        title={`${data.customTitle ? data.customTitle : data.name}`}\n                        icon={\"chrome_reader_mode\"}\n                        fontSize=\"20px\"\n                        onEdit={(text, id) => setTitle(text)}\n                        editable\n                    />\n                </div>\n            }\n\n            <div style={{\n                ...!props.horizontal ? {\n                    position: \"absolute\",\n                    top: data && (data.customTitle || data.name) ? 50 : 0,\n                    left: 0,\n                    right: 0,\n                    bottom: 0,\n                } : {\n                    position: \"relative\",\n                    width: \"100%\",\n                },\n                padding: \"0px 15px\",\n                overflow: \"auto\"\n            }}\n                id={\"linkList\"}\n                onScroll={(e) => {\n                    scrollFunction(e)\n                }}\n            >\n                <GridContainer\n                    style={{\n                        ...props.horizontal ? {\n                            overflowX: \"auto\",\n                            flexFlow: \"row\",\n                            display: \"-webkit-inline-box\"\n                        } : {}\n                    }}\n                >\n                    {total > 0 && links.filter((l, li) => !props.max || props.max && (li < props.max)).sort((a, b) => {\n                        if (a.isoDate && b.isoDate && a.isoDate < b.isoDate)\n                            return 1\n                        if (a.isoDate && b.isoDate && a.isoDate > b.isoDate)\n                            return -1\n                        return 0\n                    }).map(lk => {\n                        return (\n                            <GridItem\n                                key={lk._id}\n                                xs={12}\n                                sm={6}\n                                md={4}\n                                lg={3}\n                                xl={2}\n                            >\n                                <Card db=\"cards\" data={lk} />\n                            </GridItem>\n                        )\n                    })}\n                    {loading ?\n                        <RenderSkeleton />\n                        : <React.Fragment></React.Fragment>}\n                </GridContainer>\n            </div>\n        </div >\n    )\n}\nconst mapStateToProps = store => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ListLinks)\n","//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = theme => ({\r\n\r\n})\r\n\r\nexport default style;","import React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport Channel from \"components/BrightAndConnected/channel\"\nimport ListLinks from \"components/BrightAndConnected/listLinks\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport LinearProgress from \"components/Progress/linear\"\n\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/BrightAndConnected.js\"\n\n//FUNCTIONS\nimport { loadFeeds } from \"functions/feeds\"\n\nfunction Component(props) {\n    const { search, session } = reduxStore.getState()\n    const [loading, setLoading] = React.useState(true)\n    const [feeds, setFeeds] = React.useState({})\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    React.useEffect(() => {\n        iniFeeds()\n    }, [props.store.feeds])\n\n    React.useEffect(() => {\n        ini()\n    }, [])\n\n    const ini = async () => {\n        setLoading(true)\n        if (hashs[1] === 'hideFeeds'\n            //  && Object.keys(reduxStore.getState().db.feeds).filter(a => reduxStore.getState().db.feeds[a].hide).length === 0\n        ) {\n            const loadData = await loadFeeds({ ...props, fnIdentification: 'Views/BrightAndConnected/Feeds -- iniFeeds()' }, { showHidden: true })\n            if (loadData) {\n                iniFeeds()\n            }\n        } else if (Object.keys(reduxStore.getState().db.feeds).filter(a => !reduxStore.getState().db.feeds[a].hide).length === 0) {\n            const loadData = await loadFeeds({ ...props, fnIdentification: 'Views/BrightAndConnected/Feeds -- iniFeeds()' })\n            if (loadData)\n                iniFeeds()\n        } else {\n            iniFeeds()\n        }\n    }\n\n    const iniFeeds = () => {\n        let aFeeds = {}\n\n        if (Object.keys(reduxStore.getState().db.feeds).length > 0)\n            aFeeds = {\n                ...aFeeds,\n                ...reduxStore.getState().db.feeds,\n            }\n\n        let nfeeds = {}\n        Object.keys(aFeeds).filter(a =>\n            (\n                aFeeds[a] && aFeeds[a].name && aFeeds[a].name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n            || (aFeeds[a].customTitle && aFeeds[a].customTitle.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n            || (aFeeds[a].customDescription && aFeeds[a].customDescription.toLowerCase().indexOf(search.text.toLowerCase()) > -1\n            )\n        ).map(a => {\n            if (Object.keys(search.plans.selected).length > 0 && Object.keys(search.plans.selected).map(sp => search.plans.selected[sp] && aFeeds[a]._parent[sp]).length > 0) {\n                nfeeds = {\n                    ...nfeeds,\n                    [a]: aFeeds[a]\n                }\n            } else if (Object.keys(search.plans.selected).length === 0) {\n                nfeeds = {\n                    ...nfeeds,\n                    [a]: aFeeds[a]\n                }\n            }\n        })\n        setFeeds(nfeeds)\n        setLoading(false)\n    }\n\n    let collapsed = true\n\n\n    if (loading)\n        return (\n            <div style={{ position: \"absolute\", top: '0px', bottom: 0, left: 0, right: 0 }}>\n                <LinearProgress />\n            </div>\n        )\n\n    if (hashs[2] && hashs[2].length === 36)\n        return (\n            <div>\n                <ListLinks follow />\n            </div>\n        )\n\n\n\n    return (\n        <div style={{\n            width: '100%',\n            width: 'calc(100% - 20px)',\n            position: 'relative',\n            display: 'flex'\n        }}>\n            <GridContainer>\n                {feeds\n                    && Object.keys(feeds).length > 0\n                    && Object.keys(feeds)\n                        .filter(a => {\n                            if (\n                                hashs[0].length === 36\n                                && reduxStore.getState().db.cards[hashs[0]]\n                                && feeds[a]._parent\n                                && Object.keys(feeds[a]._parent).length > 0\n                                && feeds[a]._parent[hashs[0]]\n                            ) {\n                                return true\n                            }\n                            if (hashs[0] === 'tab') {\n                                let hide = false\n                                if (feeds[a].hide) {\n                                    hide = true\n                                }\n                                if (!props.showHidden && !hide)\n                                    return true\n                                if (props.showHidden && hide)\n                                    return true\n                            }\n                        })\n                        .sort((a, b) => {\n                            let nameA = feeds[a].customTitle ? feeds[a].customTitle.toLowerCase().trim() : feeds[a].name.toLowerCase().trim()\n                            let nameB = feeds[b].customTitle ? feeds[b].customTitle.toLowerCase().trim() : feeds[b].name.toLowerCase().trim()\n\n                            if (hashs[0] && hashs[0].length !== 36) {\n                                if (session && session.account && feeds[a]._parent && feeds[a]._parent[session.account] && feeds[a]._parent[session.account].customTitle)\n                                    nameA = feeds[a]._parent[session.account].customTitle.toLowerCase().trim()\n\n                                if (session && session.account && feeds[b]._parent && feeds[b]._parent[session.account] && feeds[b]._parent[session.account].customTitle)\n                                    nameB = feeds[b]._parent[session.account].customTitle.toLowerCase().trim()\n                            }\n\n                            if (nameA < nameB) {\n                                return -1\n                            } else if (nameA > nameB) {\n                                return 1\n                            } else {\n                                return 0\n                            }\n                        }\n                        ).map((f, i) => {\n                            let feed = feeds[f]\n                            return (\n                                <GridItem\n                                    xs={12}\n                                    sm={6}\n                                    md={4}\n                                    lg={3}\n                                    xl={2}\n                                    key={f}\n                                >\n                                    <Channel data={feed} follow onChange={() => { iniFeeds() }} />\n                                </GridItem>\n                            )\n                        })\n                }\n\n            </GridContainer>\n        </div>\n    )\n}\n\nconst mapStateToProps = (store, ownProps) => {\n    return {\n        store: {\n            feeds: store.db.feeds\n        }\n    }\n}\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component))","import { customApp } from \"functions/\";\r\n\r\nexport default {\r\n    control: {\r\n        backgroundColor: \"#fff\",\r\n        fontSize: 14,\r\n        fontFamily: \"Roboto\",\r\n        fontWeight: \"normal\",\r\n        lineHeight: \"17px\",\r\n    },\r\n\r\n    \"&multiLine\": {\r\n        control: {\r\n            fontFamily: \"Roboto\",\r\n        },\r\n        highlighter: {\r\n            padding: 9,\r\n            border: \"1px solid transparent\",\r\n            boxSizing: \"border-box\",\r\n            overflow: \"hidden\",\r\n            maxHeight: 150,\r\n        },\r\n        input: {\r\n            padding: 9,\r\n            border: \"1px solid silver\",\r\n            overflow: \"auto\",\r\n            maxHeight: 150,\r\n            borderColor: \"transparent\",\r\n        },\r\n    },\r\n\r\n    \"&singleLine\": {\r\n        display: \"inline-block\",\r\n        width: 180,\r\n        lineHeight: \"17px\",\r\n        highlighter: {\r\n            lineHeight: \"17px\",\r\n            padding: 1,\r\n            border: \"2px inset transparent\",\r\n        },\r\n        input: {\r\n            border: \"none\",\r\n            lineHeight: \"17px\",\r\n            padding: 1,\r\n            border: \"2px inset\",\r\n        },\r\n    },\r\n\r\n    suggestions: {\r\n        position: \"absolute\",\r\n        bottom: \"100%\",\r\n        top: \"none\",\r\n        left: \"33px\",\r\n        maxHeight: \"217px !important\",\r\n        overflow: \"auto !important\",\r\n        list: {\r\n            position: \"absolute\",\r\n            width: \"300px\",\r\n            backgroundColor: \"white\",\r\n            border: \"1px solid rgba(0,0,0,0.15)\",\r\n            borderRadius: \"7px 7px\",\r\n            boxShadow: \"0 0 3px 5px rgba(0,0,0,0.09)\",\r\n            fontSize: 14,\r\n            maxHeight: \"217px\",\r\n            overflow: \"auto\"\r\n        },\r\n        item: {\r\n            padding: \"5px 15px\",\r\n            borderBottom: \"1px solid rgba(0,0,0,0.15)\",\r\n            \"&focused\": {\r\n                backgroundColor: customApp(\"color\"),\r\n            },\r\n        },\r\n    },\r\n}","import {\r\n  infoColor,\r\n  primaryColor,\r\n  successColor,\r\n  dangerColor,\r\n  warningColor,\r\n  whiteColor,\r\n  blackColor,\r\n  grayColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport {\r\n  defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport { customApp } from \"functions/\";;\r\nconst timelineStyle = theme => ({\r\n  root: {\r\n    position: 'absolute',\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n  },\r\n  rootRelative: {\r\n    position: 'relative',\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n  },\r\n  content: {\r\n    position: 'absolute',\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    overflowY: 'auto',\r\n    backgroundColor: 'rgba(249,249,249,1)'\r\n  },\r\n  timeline: {\r\n    listStyle: \"none\",\r\n    padding: 0,\r\n    position: \"absolute\",\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    display: 'flex',\r\n    width: '100%',\r\n    '& .file-drop-target': {\r\n      width: '100%',\r\n      display: 'flex',\r\n      position: 'absolute',\r\n      bottom: 0,\r\n      left: 0,\r\n      right: 0,\r\n      height: 'auto'\r\n    }\r\n  },\r\n  scrollEnd: {\r\n    marginTop: '160px',\r\n    position: 'relative',\r\n    width: '100%',\r\n    height: 0,\r\n    marginBottom: '-100px'\r\n  },\r\n  timelineSimple: {\r\n    position: 'relative',\r\n    // overflowX: 'auto',\r\n    overflow: \"hidden\",\r\n    // marginTop: 0,\r\n    padding: 0,\r\n    width: '-webkit-fill-available',\r\n    \"&:before\": {\r\n      left: \"15px\"\r\n    },\r\n  },\r\n  item: {\r\n    marginBottom: \"5px\",\r\n    position: \"relative\",\r\n    width: 'calc(100% - 15px)',\r\n    \"&:before,&:after\": {\r\n      content: '\" \"',\r\n      display: \"table\"\r\n    },\r\n    \"&:after\": {\r\n      clear: \"both\"\r\n    }\r\n  },\r\n  timelineBadge: {\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      left: \"30px !important\"\r\n    },\r\n    color: whiteColor,\r\n    width: \"30px\",\r\n    height: \"30px\",\r\n    lineHeight: \"25px\",\r\n    fontSize: \"12px\",\r\n    textAlign: \"center\",\r\n    position: \"absolute\",\r\n    bottom: \"23px\",\r\n    left: \"50%\",\r\n    marginLeft: \"-24px\",\r\n    zIndex: \"1\",\r\n    borderTopRightRadius: \"50%\",\r\n    borderTopLeftRadius: \"50%\",\r\n    borderBottomRightRadius: \"50%\",\r\n    borderBottomLeftRadius: \"50%\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\"\r\n\r\n  },\r\n  timelineSimpleBadge: {\r\n    left: \"30px\"\r\n  },\r\n  custom: {\r\n    backgroundColor: customApp('color'),\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.4)\"\r\n  },\r\n  info: {\r\n    backgroundColor: infoColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(infoColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  success: {\r\n    backgroundColor: successColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(successColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  danger: {\r\n    backgroundColor: dangerColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(dangerColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  warning: {\r\n    backgroundColor: warningColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(warningColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  primary: {\r\n    backgroundColor: primaryColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(primaryColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  badgeIcon: {\r\n    width: \"14px\",\r\n    height: \"14px\"\r\n  },\r\n  timelinePanel: {\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      float: \"right !important\",\r\n      width: \"calc(100% - 60px) !important\",\r\n      \"&:before\": {\r\n        borderLeftWidth: \"0 !important\",\r\n        borderRightWidth: \"15px !important\",\r\n        left: \"-20px !important\",\r\n        right: \"auto !important\"\r\n      },\r\n      \"&:after\": {\r\n        borderLeftWidth: \"0 !important\",\r\n        borderRightWidth: \"14px !important\",\r\n        left: \"-19px !important\",\r\n        right: \"auto !important\"\r\n      }\r\n    },\r\n    width: \"45%\",\r\n    float: \"left\",\r\n    padding: \"7px\",\r\n    marginBottom: \"5px\",\r\n    position: \"relative\",\r\n    boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n    borderRadius: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n    background: whiteColor,\r\n    \"&:before\": {\r\n      position: \"absolute\",\r\n      bottom: \"16px\",\r\n      right: \"-15px\",\r\n      display: \"inline-block\",\r\n      borderTop: \"15px solid transparent\",\r\n      borderLeft: \"15px solid \" + grayColor[10],\r\n      borderRight: \"0 solid \" + grayColor[10],\r\n      borderBottom: \"15px solid transparent\",\r\n      content: '\" \"'\r\n    },\r\n    \"&:after\": {\r\n      position: \"absolute\",\r\n      bottom: \"16px\",\r\n      right: \"-14px\",\r\n      display: \"inline-block\",\r\n      borderTop: \"14px solid transparent\",\r\n      borderLeft: \"14px solid \" + whiteColor,\r\n      borderRight: \"0 solid \" + whiteColor,\r\n      borderBottom: \"14px solid transparent\",\r\n      content: '\" \"'\r\n    }\r\n  },\r\n  timelineSimplePanel: {\r\n    width: \"calc(100% - 60px)\"\r\n  },\r\n  timelinePanelInverted: {\r\n    [theme.breakpoints.up(\"sm\")]: {\r\n      float: \"right\",\r\n      backgroundColor: whiteColor,\r\n      \"&:before\": {\r\n        borderLeftWidth: 0,\r\n        borderRightWidth: \"15px\",\r\n        left: \"-15px\",\r\n        right: \"auto\"\r\n      },\r\n      \"&:after\": {\r\n        borderLeftWidth: 0,\r\n        borderRightWidth: \"14px\",\r\n        left: \"-14px\",\r\n        right: \"auto\"\r\n      }\r\n    }\r\n  },\r\n  timelineHeading: {\r\n    marginBottom: 0\r\n  },\r\n  timelineBody: {\r\n    fontSize: \"12px\",\r\n    lineHeight: \"21px\"\r\n  },\r\n  timelineFooter: {\r\n    zIndex: \"1\",\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    width: '100%',\r\n    display: \"inline-flex\",\r\n    justifyContent: \"space-between\"\r\n  },\r\n  footerUser: {\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    fontSize: '12px',\r\n    fontWeight: 'bold',\r\n    color: customApp('medium')\r\n  },\r\n  footerLine: {\r\n    position: 'relative',\r\n    marginTop: \"10px\",\r\n    marginBottom: \"5px\"\r\n  },\r\n  dropFile: {\r\n    display: 'none',\r\n  },\r\n  onDropFile: {\r\n    position: 'absolute',\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    zIndex: '5',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    justifyContent: 'center',\r\n    color: '#FFFFFF',\r\n    backgroundColor: 'rgba(0,0,0,0.77)',\r\n    zIndex: 11,\r\n  },\r\n  editor: {\r\n    position: 'absolute',\r\n    bottom: 0,\r\n    // minHeight: '50px',\r\n    height: 'auto',\r\n    width: 'calc(100% - 0px)',\r\n    // zIndex: 10,\r\n  },\r\n  editorRelative: {\r\n    position: 'relative',\r\n    bottom: 0,\r\n    minHeight: '50px',\r\n    height: 'auto',\r\n    width: 'calc(100% - 0px)',\r\n    zIndex: 10,\r\n  },\r\n  files: {\r\n    display: 'inline-table',\r\n    position: 'relative',\r\n    backgroundColor: 'rgba(250,250,250,0.9)',\r\n    width: '100%',\r\n    // padding: '15px'\r\n  },\r\n  textEditor: {\r\n    // zIndex: 100\r\n  },\r\n  textEditorIcon: {\r\n    cursor: 'pointer',\r\n    color: customApp('color'),\r\n  },\r\n  progressBar: {\r\n    backgroundColor: `${customApp('color', '0.1')} !important`,\r\n    '& .MuiLinearProgress-indeterminate': {\r\n      backgroundColor: `${customApp('color')} !important`\r\n    },\r\n    '& .MuiLinearProgress-bar': {\r\n      backgroundColor: `${customApp('color')} !important`\r\n    },\r\n  },\r\n  actionButton: {\r\n    alignItems: 'center',\r\n    cursor: 'pointer',\r\n    float: 'left',\r\n    height: '20px',\r\n    position: 'relative',\r\n    textAlign: 'center',\r\n    width: '30px',\r\n  },\r\n  sendingMessage: {\r\n    width: '100%'\r\n  },\r\n  valuePositive: {\r\n    positive: 'relative',\r\n    float: 'left',\r\n    color: 'blue',\r\n  },\r\n  valueNegative: {\r\n    positive: 'relative',\r\n    float: 'left',\r\n    color: 'red',\r\n  },\r\n  lastValue: {\r\n    positive: 'relative',\r\n    float: 'right',\r\n    color: 'grey',\r\n  },\r\n  timeInfo: {\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    color: 'grey',\r\n    width: '100%',\r\n    position: 'relative',\r\n    float: 'left',\r\n    marginBottom: '7px',\r\n    '& .text': {\r\n      marginLeft: '7px',\r\n    }\r\n  },\r\n  urlPreview: {\r\n    position: 'absolute',\r\n    width: '100%',\r\n    top: '-90px',\r\n    maxHeight: '120px',\r\n    background: 'linear-gradient(60deg, rgba(250,250,250,1), rgba(250,250,250,0.9))',\r\n    padding: '7px',\r\n    display: 'flex',\r\n    overflow: 'auto',\r\n    alignItems: 'center',\r\n    '& img': {\r\n      maxWidth: '20%',\r\n      height: 'auto',\r\n      position: 'relative',\r\n      float: 'left',\r\n      marginTop: 0,\r\n      marginRight: '7px'\r\n    },\r\n    '& .data': {\r\n      position: 'relative',\r\n      float: 'left',\r\n      width: '75%',\r\n      '& .title': {\r\n        fontSize: '16px',\r\n        fontWeight: 'bold',\r\n      },\r\n      '& .siteName': {\r\n        fontSize: '14px',\r\n        fontWeight: 'bold',\r\n        color: '#909090'\r\n      },\r\n      '& .contentSnippet': {\r\n        fontSize: '12px',\r\n        color: '#909090'\r\n      }\r\n    }\r\n  },\r\n  mentionInput: {\r\n    ...defaultFont,\r\n    '& textarea': {\r\n      ...defaultFont,\r\n      padding: '7px',\r\n      borderRadius: '7px',\r\n      fontSize: '16px',\r\n      width: 'calc(100% - 14px)',\r\n      minHeight: '38px',\r\n      border: 'solid 1px rgba(0,0,0,0.1)'\r\n    },\r\n    '& .sugestions': {\r\n      top: 'none !important',\r\n      bottom: '40px',\r\n      border: 'solid 10px red'\r\n    },\r\n    '& textarea::placeholder': {\r\n      color: 'rgba(0,0,0,0.2)',\r\n    }\r\n  },\r\n  mentionWrapper: {\r\n    width: '100%',\r\n    background: 'transparent',\r\n    fontSize: '0.9rem',\r\n    color: ' #a9b5c4',\r\n    '&&.mentionWrapper__control': {\r\n      borderRadius: '25px',\r\n      border: '1px solid #3a546f',\r\n      minHeight: '45px',\r\n      '&& .mentionWrapper__highlighter': {\r\n        padding: '0.7rem 1rem',\r\n      },\r\n      '&& .mentionWrapper__input': {\r\n        padding: '0.7rem 1rem',\r\n        outline: 0,\r\n        border: 0,\r\n        resize: 'none',\r\n        outline: 'none',\r\n        fontSize: '0.9rem',\r\n        color: '#7288a3',\r\n        borderColor: ' #3a546f',\r\n        overflow: 'hidden',\r\n        '&& :: placeholder': {\r\n          color: '#7288a3',\r\n        }\r\n      }\r\n    },\r\n  },\r\n})\r\n\r\nexport default timelineStyle;\r\n","import React from \"react\";\nimport { FileDrop } from \"react-file-drop\";\nimport { MentionsInput, Mention } from \"react-mentions\";\nimport { v4 as uuid } from \"uuid\";\nimport Picker from \"emoji-picker-react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport CustomIconButton from \"components/CustomButtons/icon\";\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\";\nimport LinearProgress from \"@material-ui/core/LinearProgress\";\nimport Skeleton from \"@material-ui/lab/Skeleton\";\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport mentionInputStyle from \"assets/jss/material-dashboard-pro-react/components/Mentions-InputNew\";\nimport styles from \"assets/jss/material-dashboard-pro-react/components/timelineNewSending.js\";\n\n//FUNCTIONS\nimport { cardsAccess } from \"functions/users\";\nimport { translate, customApp, getAppAccess } from \"functions/\";\nimport { upload } from \"functions/upload.js\";\nimport { timelineComment } from \"functions/chat.js\"\n\n//IMAGES\nimport defaultAvatar from \"assets/img/fundo-sonne.png\"\n\nconst Timeline = (props) => {\n    const { db, session, chat } = reduxStore.getState()\n    const { classes } = props\n    const { socket } = reduxStore.getState().functions\n    const [mounted, setMounted] = React.useState(false);\n    const [message, setMessage] = React.useState(\"\")\n    const [sending, setSending] = React.useState(false);\n    const [fileDropDrag, setFileDropDrag] = React.useState(false);\n    const [fileList, setFileList] = React.useState([]);\n    const [fileSend, setFileSend] = React.useState([]);\n    const [urlPreview, setUrlPreview] = React.useState(null)\n    const [urlPreviewLoad, setUrlPreviewLoad] = React.useState(false)\n    const [urlErrors, setUrlErros] = React.useState([])\n    const [onEmojiPicker, setOnEmojiPicker] = React.useState(false)\n\n    const refFileDrop = React.createRef()\n    const editorInput = React.createRef()\n\n    let AppAccess = getAppAccess()\n\n    let CardAccess = 0\n\n    if (session._id\n        && db.cards[props.nodeId]\n        && db.users\n        && db.users[Object.keys(db.users).find(a => a.indexOf(session._id) > -1)])\n        CardAccess = db.users[Object.keys(db.users).find(a => a.indexOf(session._id) > -1)]\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n\n    React.useEffect(() => {\n        if (!mounted)\n            setMounted(true)\n    })\n\n    const mentionedUsers = () => {\n        let newText\n        newText = message\n        let usersMentioned = []\n        if (newText) {\n            const test1 = newText.split(\"@[\")\n            if (test1.length > 0)\n                test1.map(a => {\n                    if (a) {\n                        let toReplace = `@[${a.split(\")\")[0]})`\n                        let id = a.split(\"](\")[1]\n                        if (id) {\n                            id = id.split(\")\")[0]\n                            if (id && id.length === 36) {\n                                usersMentioned.push(id)\n                            }\n                        }\n                    }\n                })\n        }\n        return usersMentioned\n    }\n\n    const sendMessage = async () => {\n        setOnEmojiPicker(false)\n        setSending(true)\n\n        let notifyUsers = []\n        let mentions = mentionedUsers();\n\n        // if (db.cards[props.nodeId]\n        //     && db.cards[props.nodeId].type !== \"chatGroup\"\n        //     && db.users\n        //     && Object.keys(db.users).length > 0\n        // )\n        //     Object.keys(db.users).filter(a => a !== session._id && mentions.indexOf(a) === -1).map(a => {\n        //         notifyUsers.push(a)\n        //     })\n\n        // console.log(,)\n        console.log(props)\n        let dataMessage = {\n            _id: uuid(),\n            idRel: props.nodeId,\n            replyData: props.replyData ? props.replyData : {},\n            reply: props.replyData ? props.replyData._id : null,\n            message: message,\n            type: \"comment\",\n            mentions: mentionedUsers(),\n            notifyUsers: notifyUsers,\n            filesCount: fileList.length > 0 ? fileList.length : 0,\n            _parent: props.nodeId,\n            _client: db.cards[props.nodeId] && db.cards[props.nodeId].client ? db.cards[props.nodeId].client : null,\n        }\n\n        if (urlPreview)\n            dataMessage = { ...dataMessage, urlPreview: JSON.stringify(urlPreview) }\n\n        timelineComment(props, {\n            ...dataMessage,\n            user: {\n                ...db.users[session._id]\n            },\n            files: {}\n        })\n\n        // api.post(\"timeline/add\", dataMessage)\n\n        socket.emit(\"data\", {\n            module: \"timeline\",\n            method: \"post\",\n            action: \"add\"\n        },\n            dataMessage,\n            (response) => {\n                console.log(response)\n                if (response._id) {\n                    if (fileList.length > 0) {\n                        sendFiles(response);\n                    } else {\n                        if (props.onSending)\n                            props.onSending()\n                        let comment = {\n                            ...response,\n                            _parent: props.nodeId,\n                            _client: db.cards[props.nodeId] && db.cards[props.nodeId].client ? db.cards[props.nodeId].client : null\n                        }\n                        if (urlPreview)\n                            comment = { ...comment, urlPreview: JSON.stringify(urlPreview) }\n\n                        mentions.map(async a => {\n                            if (db.cards[props.nodeId]\n                                && (\n                                    !db.users\n                                    || (\n                                        db.users\n                                        && !db.users[a]\n                                    )\n                                )\n                            )\n                                await cardsAccess(props, a, 2, props.nodeId, true)\n                        })\n\n                        setFileSend([]);\n                        setFileList([]);\n                        setUrlErros([]);\n                        setMessage(\"\");\n                        setUrlPreview(null)\n                        setSending(false)\n                        if (props.onSending) {\n                            props.onSending()\n                        }\n                    }\n                }\n            })\n        setMessage(\"\");\n        setUrlPreview(null)\n    }\n\n    const sendFiles = async (comment) => {\n        let files = Array.from(fileList)\n        await Promise.all(\n            files.map(async (f, i) => {\n                setFileSend([...fileSend, f])\n                const fileUpload = await upload(comment._id, f, true)\n                return fileUpload\n            })\n        ).then(a => {\n            if (props.onSending)\n                props.onSending()\n            comment.files = a\n            comment._parent = props.nodeId\n            socket.emit(\"timeline.COMMENT\", {\n                node: props.nodeId,\n                comment,\n                db: props.db ? props.db : \"cards\"\n            }, (data) => {\n            })\n            setFileSend([]);\n            setFileList([]);\n            setMessage(\"\");\n            setUrlPreview(null)\n            setSending(false)\n            if (props.onSending) {\n                props.onSending()\n            }\n        })\n    }\n\n    const onDropFile = async event => {\n        setFileList([...fileList, ...Object.keys(event).map(file =>\n            event[file]\n        )])\n        setFileDropDrag(false)\n    }\n\n    const deleteFile = i => {\n        let files = Array.from(fileList)\n        files.splice(i, 1)\n        setFileList(files)\n    }\n\n    const verifyText = async (f) => {\n        setMessage(f)\n        if (f\n            && (\n                f.indexOf(\"http://\") > -1\n                ||\n                f.indexOf(\"https://\") > -1\n            )\n        ) {\n            let url = \"\"\n            let text = []\n            if (f.indexOf(\" \") > -1) {\n                text = f.split(\" \")\n            } else if (f.indexOf(\"\\n\") > -1) {\n                text = f.split(\"\\n\")\n            } else {\n                text.push(f)\n            }\n            var pattern = new RegExp(\"^(https?:\\\\/\\\\/)?\" + // protocol\n                \"((([a-z\\\\d]([a-z\\\\d-]*[a-z\\\\d])*)\\\\.)+[a-z]{2,}|\" + // domain name\n                \"((\\\\d{1,3}\\\\.){3}\\\\d{1,3}))\" + // OR ip (v4) address\n                \"(\\\\:\\\\d+)?(\\\\/[-a-z\\\\d%_.~+]*)*\" + // port and path\n                \"(\\\\?[;&a-z\\\\d%_.~+=-]*)?\" + // query string\n                \"(\\\\#[-a-z\\\\d_]*)?$\", \"i\"); // fragment locator\n\n            await text.map(a => {\n                if (\n                    (\n                        a.indexOf(\"http://\") > -1\n                        ||\n                        a.indexOf(\"https://\") > -1\n                    )\n                    &&\n                    !!pattern.test(a)) {\n                    url = a\n                }\n            })\n            if (\n                (\n                    !urlPreview\n                    && url\n                    && urlErrors.indexOf(url) === -1\n                )\n                ||\n                (\n                    url\n                    && urlPreview\n                    && urlErrors.indexOf(url) === -1\n                    && urlPreview.link !== url\n                )\n            ) {\n                setUrlPreviewLoad(true)\n                try {\n                    socket.emit(\"data\", {\n                        module: \"link\",\n                        method: \"post\",\n                        action: \"exist\",\n                    }, {\n                        idRel: hashs[0],\n                        url\n                    }, (result) => {\n                        setUrlPreview(result)\n                        setUrlPreviewLoad(false)\n                    })\n                } catch (e) {\n                    setUrlPreviewLoad(false)\n                    let urlErrorsArray = urlErrors\n                    urlErrorsArray.push(url)\n                    setUrlErros(urlErrorsArray)\n                    console.log(e)\n                }\n            }\n        }\n    }\n\n    const onEmojiClick = (event, emojiObject) => {\n        setMessage(`${message} ${emojiObject.emoji}`)\n    };\n\n    let usersSuggestion = []\n\n    if (db.cards[props.nodeId] && db.users)\n        Object.keys(db.users).map(a => {\n            if (a\n                && a !== null\n                && a !== undefined\n                && a !== session._id\n                && db.users[a].name\n                && db.users[a]\n                && !db.users[a].deleted\n            ) {\n                let id = db.users[a]._id\n                let display = db.users[a].name ? db.users[a].name : db.users[a].name.split(\" \").length > 0 ? db.users[a].name.split(\" \")[0] : db.users[a].name\n                if (id && Object.keys(usersSuggestion).filter(a => usersSuggestion[a].id === id).length === 0)\n                    usersSuggestion.push({ id: id, display: display })\n            }\n        })\n\n    if (\n        (\n\n            (\n                AppAccess\n                && (\n                    AppAccess.owner\n                    || AppAccess.planAdmin\n                    || AppAccess.planModerate\n                )\n            ) ||\n            (\n                CardAccess\n                && CardAccess.access\n                && parseInt(CardAccess.access) > 3\n            )\n        )\n    ) {\n        Object.keys(db.users)\n            .filter(fil => {\n                if (\n                    !db.users[fil].deleted\n                    && db.users[fil].type !== \"client\"\n                    && db.users[fil].type !== \"group\"\n                    && db.users[fil].type !== \"account\"\n                    && !db.users[fil]._parent\n                )\n                    return true\n                return false\n            })\n            .map(a => {\n                if (a\n                    && a !== null\n                    && a !== undefined\n                    && a !== session._id\n                    && Object.keys(usersSuggestion).filter(fs => {\n                        if (usersSuggestion[fs].id === a)\n                            return true\n                    }).length === 0\n                ) {\n                    usersSuggestion.push({ id: a, display: props.nodeId && db.cards[props.nodeId] && db.users && db.users[a] && db.users[a].name ? db.users[a].name : db.users[a].displayName ? db.users[a].displayName : db.users[a].name })\n                }\n            })\n    }\n\n    return (\n        <FileDrop\n            ref={refFileDrop}\n            className={props.relative ? classes.rootRelative : classes.root}\n            onDragOver={\n                () => {\n                    !props.disabledSend &&\n                        setFileDropDrag(true)\n                }\n            }\n            onClick={() => {\n                if (editorInput && editorInput.current)\n                    editorInput.current.focus()\n            }}\n            onDrop={onDropFile}\n            accept={\".png, .jpg, .jpeg, .bpm, .svg, .gif, .pdf, .mp4, .3gp, .ts, .mkv, .avi, .mov, .mts,  m2ts, .mxf, .aac,  aiff, .caf, .ogg, .mp3, .wav, .doc, .docx, .xls, .xlsx, .ppt, .pptx, .txt, .zip, .rar\"}\n        >\n            <React.Fragment>\n                <div className={props.relative ? classes.editorRelative : classes.editor} style={props.editorStyle ? props.editorStyle : {}}\n                    onClick={() => {\n                        if (editorInput && editorInput.current)\n                            editorInput.current.focus()\n                    }}\n                >\n                    <div className={classes.files}>\n                        {fileList && fileList.length > 0 && fileList.map((file, i) => {\n                            let ext = file.name.split(\".\")\n                            let img = `attachment`\n                            if (props.store.db.fileExtensions.filter(a => a.ext.indexOf(ext[ext.length - 1].toLowerCase()) > -1).length > 0)\n                                img = props.store.db.fileExtensions.filter(a => a.ext.indexOf(ext[ext.length - 1].toLowerCase()) > -1)[0].icon || URL.createObjectURL(file)\n                            return (\n                                <div key={i} style={{ position: \"relative\", float: \"left\", width: \"100%\", display: \"flex\", alignItems: \"center\", marginBottom: \"5px\" }}>\n                                    <div\n                                        style={{\n                                            position: \"relative\",\n                                            float: \"left\",\n                                            width: \"50px\",\n                                            height: \"50px\",\n                                            marginRight: \"7px\",\n                                            overflow: \"hidden\"\n                                        }}\n                                    >\n                                        {typeof img === \"string\" && img.indexOf(\"blob:\") === -1 && img.indexOf(\"svg\") === -1 ?\n                                            <Icon icon={img} size=\"50px\" />\n                                            :\n                                            <img src={img} style={{ width: \"100%\", height: \"100%\" }} />\n                                        }\n                                    </div>\n                                    {fileSend.length > 0 && fileSend[i] && fileSend[i].name === file.name ?\n                                        <Icon icon=\"cloud_done\" color=\"green\" />\n                                        : !sending ? <Icon icon=\"delete_forever\" color=\"red\" onClick={() => deleteFile(i)} /> : <React.Fragment></React.Fragment>\n                                    }\n                                    {file.name}\n                                </div>\n                            )\n                        })}\n                    </div>\n                    <div className={classes.textEditor}>\n                        {urlPreviewLoad && !urlPreview &&\n                            <div className={classes.urlPreview} style={{ width: \"100%\", height: \"150px\" }}>\n                                <div style={{ display: \"flex\" }}>\n                                    <div style={{ marginLeft: \"7px\", width: \"200px\", height: \"110px\", maxWidth: \"50%\" }}>\n                                        <Skeleton variant=\"rect\" style={{ width: \"200px\", height: \"110px\", maxWidth: \"100%\" }} />\n                                    </div>\n                                    <div style={{ marginLeft: \"7px\", width: \"100%\", height: \"25px\" }}>\n                                        <Skeleton variant=\"text\" height={25} style={{ marginBottom: \"7px\" }} />\n                                        <Skeleton variant=\"text\" height={10} />\n                                        <Skeleton variant=\"text\" height={10} />\n                                        <Skeleton variant=\"text\" height={10} />\n                                        <Skeleton variant=\"text\" height={10} />\n                                        <Skeleton variant=\"text\" height={10} />\n                                        <Skeleton variant=\"text\" height={10} />\n                                    </div>\n                                </div>\n                            </div>\n                        }\n                        {urlPreview &&\n                            <div className={classes.urlPreview}>\n                                <img\n                                    src={`${urlPreview.img ? urlPreview.img : defaultAvatar}`}\n                                    onError={(e) => {\n                                        e.target.src = defaultAvatar\n                                    }}\n                                    alt={urlPreview.title}\n                                />\n                                <div className={\"data\"}>\n                                    <div className={\"title\"}>{urlPreview.title}</div>\n                                    {urlPreview.site && <div className=\"siteName\">{urlPreview.site}</div>}\n                                    {urlPreview.contentSnippet && <div className={\"contentSnippet\"}>{urlPreview.contentSnippet}</div>}\n                                </div>\n                                <CustomIconButton\n                                    title={translate(\"$__removeLink\", 1)}\n                                    icon=\"delete_forever\"\n                                    color=\"red\"\n                                    onClick={() => setUrlPreview(null)}\n                                />\n                            </div>\n                        }\n                        {sending ?\n                            <div className={classes.sendingMessage}>{translate(\"$__sending\", 1)}\n                                <LinearProgress className={classes.progressBar} /></div>\n                            :\n                            <div\n                                style={{\n                                    position: \"relative\",\n                                    height: \"auto\",\n                                    backgroundColor: \"#ffffff\",\n                                    border: \"solid 1px rgba(0,0,0,0.05)\",\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                    zIndex: 1\n                                }}>\n                                <MentionsInput\n                                    ref={editorInput}\n                                    value={message}\n                                    onChange={(e) => {\n                                        verifyText(e.target.value)\n                                    }}\n                                    onPaste={(e) => {\n                                        onDropFile(e.clipboardData.files)\n                                    }}\n                                    placeholder={props.placeholder ? props.placeholder : translate(\"$__writeMessage\")}\n                                    style={{\n                                        ...mentionInputStyle,\n                                        position: \"relative\",\n                                        width: \"calc(100% - 130px)\",\n                                        paddingRight: \"7px\",\n                                        background: \"none\",\n                                        border: \"none\",\n                                        overflow: \"auto !important\"\n                                    }}\n                                    onKeyDown={(event) => {\n                                        if (event.keyCode == 13) {\n                                            if (event.shiftKey) {\n                                                event.stopPropagation();\n                                            } else if (message.trim()) {\n                                                sendMessage()\n                                            }\n                                        }\n                                    }\n                                    }\n                                    placement=\"top\"\n                                    forceSuggestionsAboveCursor={true}\n                                    autosize={{ minRows: 1, maxRows: 6 }}\n                                >\n                                    <Mention\n                                        trigger=\"@\"\n                                        data={usersSuggestion}\n                                        renderSuggestion={(suggestion, search, highlightedDisplay) => {\n                                            if (suggestion && suggestion.id)\n                                                return (\n                                                    <div style={{ display: \"flex\", alignItems: \"center\" }}>\n                                                        <Avatar style={{\n                                                            width: \"25px\", height: \"25px\", marginRight: \"7px\"\n                                                        }} alt={highlightedDisplay}\n                                                            src={db.users[suggestion.id]\n                                                                && db.users[suggestion.id].image\n                                                                ? db.users[suggestion.id].image\n                                                                : db.users[suggestion.id]\n                                                                    && db.users[suggestion.id].image\n                                                                    ? db.users[suggestion.id].image\n                                                                    : null} />\n                                                        {highlightedDisplay}\n                                                    </div>\n                                                )\n                                        }\n                                        }\n                                    />\n                                </MentionsInput>\n\n                                <div\n                                    style={{\n                                        position: \"absolute\",\n                                        right: \"0px\",\n                                        bottom: \"0px\",\n                                        cursor: \"pointer\",\n                                        display: \"flex\",\n                                        alignItems: \"center\"\n                                    }}\n                                >\n                                    <CustomIconButton\n                                        title={translate(\"$__emojis\", 1)}\n                                        icon={onEmojiPicker ? `highlight_off` : `sentiment_very_satisfied`}\n                                        color={customApp(\"medium\")}\n                                        onClick={() => {\n                                            setOnEmojiPicker(!onEmojiPicker)\n                                        }}\n                                    />\n                                    {!sending &&\n                                        <div className={classes.actionButton}>\n                                            <input\n                                                className={\"input-text-timeline\"}\n                                                style={{\n                                                    position: \"absolute\",\n                                                    marginRight: \"3em\",\n                                                    height: \"24px\",\n                                                    fontSize: \"0\",\n                                                    left: \"0px\",\n                                                    width: \"24px\",\n                                                    cursor: \"pointer\",\n                                                    border: \"none\",\n                                                    opacity: \"0\",\n                                                }} onChange={e =>\n                                                    onDropFile(e.target.files)\n                                                }\n                                                multiple\n                                                type=\"file\"\n                                                accept={\".png, .jpg, .jpeg, .bpm, .svg, .gif, .pdf, .mp4, .3gp, .ts, .mkv, .avi, .mov, .mts,  m2ts, .mxf, .aac,  aiff, .caf, .ogg, .mp3, .wav, .doc, .docx, .xls, .xlsx, .ppt, .pptx\"} />\n                                            <Icon\n                                                icon=\"attachment\"\n                                                color={customApp(\"medium\")}\n                                                size={\"22px\"}\n                                            />\n                                        </div>\n                                    }\n                                    {(!sending && (message || fileList.length > 0)) &&\n                                        <CustomIconButton\n                                            title={translate(\"$__pressENTERtoSendorClickHere\", 1)}\n                                            icon=\"send\"\n                                            color={customApp(\"menu\")}\n                                            onClick={() => sendMessage()}\n                                        />\n                                    }\n                                    {props.closeOption &&\n                                        <Icon title={translate(\"$__pressCRTL+ENTERtoSend\", 1)} icon=\"close\" color={customApp(\"color\")} onClick={() => props.onClose()} />\n                                    }\n                                    {onEmojiPicker &&\n                                        <div style={{\n                                            position: \"absolute\",\n                                            bottom: \"44px\",\n                                            right: \"40px\",\n                                        }}>\n\n                                            <Picker\n                                                onEmojiClick={onEmojiClick}\n                                                groupVisibility={{\n                                                    recently_used: false\n                                                }}\n                                            />\n                                        </div>\n                                    }\n                                </div>\n                            </div>\n                        }\n                    </div>\n                </div>\n                <div className={fileDropDrag ? classes.onDropFile : classes.dropFile}\n                    onDragLeave={() => {\n                        !props.disabledSend &&\n                            setFileDropDrag(false)\n                    }\n                    }\n                >\n                    {translate(\"$__dropTheFileToAttach\", \"*\")}\n                </div>\n            </React.Fragment>\n        </FileDrop>\n    );\n}\n//REACT\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Timeline));","import React from \"react\"\nimport moment from \"moment-timezone\"\nimport ReactAudioPlayer from \"react-audio-player\"\n\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport UserBadge from \"components/Badge/user\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport { withStyles } from \"@material-ui/core/styles\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/timelineStyle.js\"\n\n//FUNCTIONS\nimport {\n    nl2br,\n    translate,\n    customApp,\n    Highlighted,\n    appAlert\n} from \"functions/\"\n\nimport {\n    interact,\n    deleteMessage\n} from \"functions/chat\"\n\n//IMAGES\nimport SVGIcon from \"assets/icons/svg.png\"\n\nconst Timeline = (props) => {\n    const { classes } = props;\n    const { db, session, functions, usersStatus } = reduxStore.getState();\n    const { socket } = functions;\n    const [hideImage, setHideImage] = React.useState(false)\n    const [overOptions, setOverOptions] = React.useState(false)\n    const [cancelReason, setCancelReason] = React.useState(null)\n    const [goCancel, setGoCancel] = React.useState(null)\n\n    let timer = null\n    let cardId\n    if (storie && storie._parent && db.cards[storie._parent]) {\n        cardId = storie._parent\n    } else if (storie && storie.idRel && db.cards[storie.idRel]) {\n        cardId = storie.idRel\n    }\n\n    const mentionedUsers = (text) => {\n        let cardId\n        if (storie && storie._parent && db.cards[storie._parent]) {\n            cardId = storie._parent\n        } else if (storie && storie.idRel && db.cards[storie.idRel]) {\n            cardId = storie.idRel\n        }\n\n        let newText\n        newText = text\n        if (text) {\n            const test1 = text.split(\"@[\")\n            if (test1.length > 0)\n                test1.map(a => {\n                    if (a) {\n                        let toReplace = `@[${a.split(\")\")[0]})`\n                        let id = a.split(\"](\")[1]\n                        if (id) {\n                            id = id.split(\")\")[0]\n                            if (\n                                id\n                                && id.length === 36\n                                && db.cards[cardId]\n                                && db.cards[cardId]._users\n                                && db.cards[cardId]._users[id]\n                            ) {\n                                let userName = db.cards[cardId]._users\n                                    && db.cards[cardId]._users[id]\n                                    && db.cards[cardId]._users[id].name\n                                    ? db.cards[cardId]._users[id].name\n                                    : db.cards[cardId]._users\n                                        && db.cards[cardId]._users[id]\n                                        && db.cards[cardId]._users[id].name\n                                        ? db.cards[cardId]._users[id].name\n                                        : a.split(\"](\")[0]\n                                newText = newText.replace(toReplace, `<span style=\"color:${customApp(\"menu\")}\"><b>${userName}</b></span>`)\n                            } else if (\n                                id\n                                && id.length === 36\n                                && db.users[id]\n                            ) {\n                                let userName = db.users[id] && db.users[id].name\n                                    ? db.users[id].name : db.users[id].name\n                                        ? db.users[id].name\n                                        : translate(\"$__hideUser\", \"*\")\n                                newText = newText.replace(toReplace, `<span style=\"color:${customApp(\"menu\")}\"><b>${userName}</b></span>`)\n                            }\n                        }\n                    }\n                    return true\n                })\n        }\n        return newText\n    }\n\n    const overOptionsHandle = (mouse = false) => {\n        setOverOptions(true)\n        if (mouse)\n            clearTimeout(timer)\n    }\n    const closeOptionsHandle = (time = 0) => {\n        timer = setTimeout(() => {\n            setOverOptions(false)\n        }, time)\n    }\n\n    const reactThis = (react) => {\n        let data = {\n            react: react,\n            user: session._id,\n            db: props.db,\n            nodeId: props.storie.idRel ? props.storie.idRel : props.storie._parent ? props.storie._parent : props.nodeId ? props.nodeId : null,\n            message: props.storie._id\n        }\n\n        interact(props, data)\n        socket.emit(\"data\", {\n            module: \"timeline\",\n            method: \"post\",\n            action: \"interact\"\n        }, data)\n    }\n\n    let storie = props.storie\n    if (!storie)\n        return null\n\n    let time = \"\"\n    if (storie.type === \"timer\" && String(storie.ini) && String(storie.fin))\n        time = storie.fin - storie.ini\n\n    let urlPreview = null\n\n    if (storie.urlPreview)\n        urlPreview = JSON.parse(storie.urlPreview)\n\n    let message = mentionedUsers(storie.message)\n\n    let reaction\n    if (storie._reactions && Object.keys(storie._reactions).length > 0)\n        Object.keys(storie._reactions).map(re => {\n            if (Object.keys(storie._reactions[re]).length > 0)\n                Object.keys(storie._reactions[re]).map(us => {\n                    if (us === session._id)\n                        reaction = re\n                })\n        })\n\n    let my = false\n    if (props.storie && props.storie.user && props.storie.user._id === session._id)\n        my = true\n\n\n    const cancelConfirm = () => {\n        appAlert({\n            message: translate('$__confirmCancel', 1),\n            variant: 'warning',\n            persist: false,\n            horizontal: 'right',\n            confirm: () => {\n                deleteMessage(props, {\n                    id: storie._id,\n                    idRel: storie.idRel,\n                    deletedReason: cancelReason,\n                    client: db.cards[storie.idRel] && db.cards[storie.idRel].client ? db.cards[storie.idRel].client : db.cards[storie.idRel] && db.cards[storie.idRel]._planId && db.cards[db.cards[storie.idRel]._planId] && db.cards[db.cards[storie.idRel]._planId].client ? db.cards[db.cards[storie.idRel]._planId].client : null\n                })\n                setGoCancel(false)\n                setCancelReason(null)\n            }\n        })\n\n    }\n\n    const renderMessage = () => {\n        if (storie.type === \"comment\" && storie.message && !storie.urlPreview) {\n            return (\n                <div style={{ wordBreak: \"break-word\" }}>\n                    {Highlighted(message, props.searchText)}\n                </div>\n            )\n        } else if (storie.type === \"comment\" && storie.message && storie.urlPreview) {\n            let messageWithUrl = message.replace(urlPreview.link, `<a href=\"${urlPreview.link}\" target=\"_blank\">${urlPreview.link}</a>`)\n            return (\n                <div>\n                    <div style={{\n                        position: \"relative\",\n                        width: \"100%\"\n                    }}>\n                        <div className={classes.urlPreview} >\n                            {!hideImage && urlPreview.img &&\n                                <img\n                                    src={`${urlPreview.img}`}\n                                    onError={(e) => {\n                                        setHideImage(true)\n                                    }}\n                                    alt={urlPreview.title || urlPreview.link}\n                                />\n                            }\n                            <div className={\"data\"}>\n                                <div className={\"title\"}>{urlPreview.title}</div>\n                                {urlPreview.site && <div className=\"siteName\">{urlPreview.site}</div>}\n                                {urlPreview.contentSnippet && <div className={\"contentSnippet\"}>{urlPreview.contentSnippet}</div>}\n                            </div>\n                        </div>\n                        <a style={{ position: \"relative\", float: \"right\", fontWeight: \"bold\", fontSize: \"12px\", color: \"#000000\", zIndex: 1 }} href={urlPreview.link} target=\"_blank\">{translate(\"$__openLink\", \"*\")}</a>\n                    </div>\n                    <div dangerouslySetInnerHTML={{\n                        __html: nl2br(messageWithUrl, true, '\\n', '\\n')\n                    }} />\n                </div>\n\n            )\n        }\n    }\n\n    if (storie.message === \"\" && storie.cardId && storie.cardId !== props.nodeId && !reduxStore.getState().db.cards[storie.cardId])\n        return null\n\n    return (\n        <div>\n            <div\n                className=\"message\"\n                style={{\n                    position: \"relative\",\n                    float: \"left\",\n                    width: \"100%\",\n                    marginBottom: \"20px\",\n                    display: \"flex\",\n                    alignItems: \"center\"\n                }}\n                onMouseLeave={() => { closeOptionsHandle(1000) }}\n                onMouseOver={() => {\n                    if (!props.isReply)\n                        overOptionsHandle(true)\n                }}\n                onClick={() => {\n                    if (!props.isReply)\n                        overOptionsHandle(true)\n                }}\n            >\n                <div\n                    style={{ display: \"flex\" }}\n                >\n                    <div\n                        style={{\n                            position: \"relative\",\n                            float: \"left\",\n                            fontSize: \"10px\",\n                            fontWeight: \"bold\",\n                            display: \"flex\",\n                            alignItems: \"center\",\n                            whiteSpace: \"nowrap\",\n                            marginRight: \"15px\"\n                        }}\n                    >\n                        <UserBadge\n                            overlap=\"circular\"\n                            anchorOrigin={{\n                                vertical: \"bottom\",\n                                horizontal: \"right\",\n                            }}\n                            userId={storie.user._id}\n                        // variant={storie.user && storie.user._id && usersStatus.users && usersStatus.users[storie.user._id] && usersStatus.users[storie.user._id].status ? \"dot\" : \"standard\"}\n                        // status={usersStatus.users && usersStatus.users[storie.user._id] && usersStatus.users[storie.user._id].status ? usersStatus.users[storie.user._id].status : null}\n                        >\n                            <Avatar alt={storie.user.displayName ? storie.user.displayName : storie.user.name} src={`${storie.user.image}`}\n                                style={{\n                                    width: \"22px\",\n                                    height: \"22px\"\n                                }} />\n                        </UserBadge>\n                        {storie.user.displayName ? storie.user.displayName : storie.user.name} <span style={{ fontSize: \"10px\" }}>({moment(new Date()).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") === moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY\") ?\n                            `${moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"H:mm\")}`\n                            :\n                            moment(new Date()).tz(\"America/Sao_Paulo\").format(\"YYYY\") === moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"YYYY\") ?\n                                `${moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM H:mm\")}`\n                                :\n                                `${moment(storie.created_at * 1000).tz(\"America/Sao_Paulo\").format(\"DD/MM/YYYY H:mm\")}`\n                        })</span>\n                    </div>\n                </div>\n                <div>\n                    {\n                        storie.files && Object.keys(storie.files).length > 0 &&\n                        <div className=\"files\"\n                            style={{\n                                position: \"relative\",\n                                display: \"flex\",\n                                justifyContent: my ? `flex-end` : `none`,\n                                flexWrap: \"wrap\"\n                            }}>\n                            {storie.files && Object.keys(storie.files).length > 0 && Object.keys(storie.files).map((id, i) => {\n                                let file = storie.files[id]\n                                let fileName = file.name.split(\".\")\n                                let ext = fileName[fileName.length - 1]\n\n                                let img = `attachment`\n                                if (db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0) {\n                                    img = db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].icon\n                                        || `https://machen.azureedge.net/${file.file}`\n                                }\n\n                                let viewer = \"img\"\n                                if (db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0 && db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].viewer)\n                                    viewer = db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].viewer\n\n                                return (\n                                    <div key={id}\n                                        style={{\n                                            position: \"relative\",\n                                            display: \"flex\",\n                                            alignItems: \"center\",\n                                            marginBottom: \"5px\",\n                                            whiteSpace: \"nowrap\",\n                                            textOverflow: \"ellipsis\",\n                                            cursor: \"pointer\",\n                                            overflow: \"hidden\",\n                                            padding: \"7px\",\n                                            zIndex: \"10 !important\",\n                                            borderRadius: \"15px\",\n                                            width: viewer === \"img\"\n                                                ? (\n                                                    Object.keys(storie.files).length < 4\n                                                        ? `33%`\n                                                        : `25%`)\n                                                : viewer === \"movie\"\n                                                    ? \"50%\"\n                                                    : viewer === \"audio\"\n                                                        ? \"50%\"\n                                                        : \"20%\",\n                                            maxWidth: viewer === \"img\"\n                                                ? `440px`\n                                                : `none`,\n                                            minWidth: (\n                                                viewer === \"img\"\n                                                ||\n                                                (\n                                                    (viewer !== \"movie\" && viewer !== \"audio\" && typeof img === \"string\" && img.indexOf(\"blob:\") === -1 && img.indexOf(\"svg\") === -1)\n                                                    || viewer !== \"movie\" && viewer !== \"audio\" && !(viewer === \"img\" && img && img.indexOf(\"svg\") > -1)\n                                                )\n                                            ) ? \"140px\" : \"100%\"\n                                        }}\n                                        onClick={(e) => {\n                                            if (props.openLightBox) {\n                                                props.openLightBox(storie.files[id]._id)\n                                            }\n                                            e.preventDefault();\n                                        }}\n                                        title={storie.files[id].name}\n                                    >\n                                        {(viewer === \"img\"\n                                            ||\n                                            (\n                                                (viewer !== \"movie\" && viewer !== \"audio\" && typeof img === \"string\" && img.indexOf(\"blob:\") === -1 && img.indexOf(\"svg\") === -1)\n                                                || viewer !== \"movie\" && viewer !== \"audio\" && !(viewer === \"img\" && img && img.indexOf(\"svg\") > -1)\n                                            )) &&\n                                            <Tooltip\n                                                title={storie.files[id].name}>\n                                                <div style={{\n                                                    position: \"absolute\",\n                                                    bottom: \"7px\",\n                                                    left: \"7px\",\n                                                    right: \"7px\",\n                                                    padding: \"3px\",\n                                                    background: \"rgba(0,0,0,0.8)\",\n                                                    color: \"#FFFFFF\",\n                                                    borderRadius: \"0px 0px 15px 15px\",\n                                                    overflow: \"hidden\",\n                                                    textOverflow: \"ellipsis\",\n                                                }}>{storie.files[id].name}</div>\n                                            </Tooltip>\n                                        }\n                                        {/* IMAGES */}\n                                        {viewer === \"img\"\n                                            &&\n                                            (\n                                                typeof img === \"string\"\n                                                && img.indexOf(\"https\") > -1\n                                                && img.indexOf(\"svg\") === -1\n                                            ) &&\n                                            <img\n                                                src={`${img}`}\n                                                style={\n                                                    {\n                                                        borderRadius: \"15px\",\n                                                        boxShadow: `0 1px 2px 2px rgba(0,0,0,0.1)`,\n                                                        maxWidth: \"100%\",\n                                                        height: \"100%\",\n                                                        maxHeight: \"33vh\"\n                                                    }}\n                                                onError={(e) => {\n                                                    if (\n                                                        storie.created_at\n                                                        && typeof storie.created_at === \"string\"\n                                                        && parseInt(storie.created_at) > moment().unix(\"X\") - 60\n                                                    )\n                                                        e.target.src = img\n                                                }\n                                                }\n                                            />\n                                        }\n                                        {(viewer !== \"movie\" && typeof img === \"string\" && img.indexOf(\"blob:\") === -1 && img.indexOf(\"svg\") === -1) ?\n                                            <Icon icon={img} size=\"50px\" />\n                                            : (viewer !== \"movie\" && !(viewer === \"img\" && img && img.indexOf(\"svg\") > -1)) &&\n                                            <img src={img} style={{ width: \"100%\", height: \"100%\" }} />\n                                        }\n                                        {/* IMAGES */}\n                                        {(viewer === \"img\" && img && img.indexOf(\"svg\") > -1) &&\n                                            <img\n                                                src={SVGIcon}\n                                                style={\n                                                    {\n                                                        borderRadius: \"15px\",\n                                                        boxShadow: `0 1px 2px 2px rgba(0,0,0,0.1)`,\n                                                        maxWidth: \"100%\",\n                                                        height: \"100%\",\n                                                        maxHeight: \"33vh\"\n                                                    }}\n                                            />\n                                        }\n\n                                        {viewer === \"movie\"\n                                            &&\n                                            <video\n                                                style={{\n                                                    width: \"100%\"\n                                                }}\n                                                src={`https://machen.azureedge.net/${file.file}`} controls></video>\n                                        }\n                                        {viewer === \"audio\"\n                                            &&\n                                            <ReactAudioPlayer\n                                                src={`https://machen.azureedge.net/${file.file}`}\n                                                // autoPlay\n                                                controls\n                                            />\n                                        }\n                                    </div>\n                                )\n                            })\n                            }\n                        </div>\n                    }\n                    {renderMessage()}\n                </div>\n\n            </div>\n        </div>\n    );\n}\n//REACT\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Timeline));","import {\r\n  infoColor,\r\n  primaryColor,\r\n  successColor,\r\n  dangerColor,\r\n  warningColor,\r\n  whiteColor,\r\n  blackColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport { customApp } from \"functions/\";;\r\nconst timelineStyle = theme => ({\r\n  root: {\r\n    position: \"absolute\",\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    overflowY: \"auto\"\r\n  },\r\n  content: {\r\n    position: \"absolute\",\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    overflowY: \"auto\",\r\n    backgroundColor: \"rgba(249,249,249,1)\"\r\n  },\r\n  timeline: {\r\n    listStyle: \"none\",\r\n    padding: \"0\",\r\n    position: \"absolute\",\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    display: \"flex\",\r\n    width: \"100%\",\r\n    \"& .file-drop-target\": {\r\n      width: \"100%\"\r\n    }\r\n  },\r\n  scrollEnd: {\r\n    marginTop: \"160px\",\r\n    position: \"relative\",\r\n    width: \"100%\",\r\n    height: 0,\r\n    marginBottom: \"-100px\"\r\n  },\r\n  scrollEndNoEditor: {\r\n    marginTop: \"30px\",\r\n    position: \"relative\",\r\n    width: \"100%\",\r\n    height: 0,\r\n    marginBottom: \"-100px\"\r\n  },\r\n  timelineSimple: {\r\n    position: \"relative\",\r\n    // overflowX: 'auto',\r\n    overflow: \"hidden\",\r\n    marginTop: 0,\r\n    padding: \"0 0 20px\",\r\n    width: \"-webkit-fill-available\",\r\n    \"&:before\": {\r\n      left: \"15px\"\r\n    },\r\n    \"&:after\": {\r\n      clear: \"both\"\r\n    }\r\n  },\r\n  timelineSimpleWithHeader: {\r\n    position: \"relative\",\r\n    overflowX: \"auto\",\r\n    marginTop: \"60px\",\r\n    padding: \"0 0 50px\",\r\n    width: \"-webkit-fill-available\",\r\n    \"&:before\": {\r\n      left: \"15px\"\r\n    },\r\n  },\r\n  item: {\r\n    marginBottom: \"5px\",\r\n    position: \"relative\",\r\n    paddingLeft: \"15px\",\r\n    width: \"calc(100% - 15px)\",\r\n    \"&:before,&:after\": {\r\n      content: \"\",\r\n      display: \"table\"\r\n    },\r\n    \"&:after\": {\r\n      clear: \"both\"\r\n    }\r\n  },\r\n  timelineBadge: {\r\n    color: whiteColor,\r\n    width: \"30px\",\r\n    height: \"30px\",\r\n    lineHeight: \"25px\",\r\n    fontSize: \"12px\",\r\n    textAlign: \"center\",\r\n    position: \"absolute\",\r\n    bottom: \"23px\",\r\n    left: \"50%\",\r\n    marginLeft: \"-7px\",\r\n    zIndex: \"1\",\r\n    borderTopRightRadius: \"50%\",\r\n    borderTopLeftRadius: \"50%\",\r\n    borderBottomRightRadius: \"50%\",\r\n    borderBottomLeftRadius: \"50%\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\"\r\n\r\n  },\r\n  timelineSimpleBadge: {\r\n    left: \"7px\"\r\n  },\r\n  timelineBadgeInverted: {\r\n    color: whiteColor,\r\n    width: \"30px\",\r\n    height: \"30px\",\r\n    lineHeight: \"25px\",\r\n    fontSize: \"12px\",\r\n    textAlign: \"center\",\r\n    position: \"absolute\",\r\n    bottom: \"23px\",\r\n    right: \"50%\",\r\n    marginRight: \"-7px\",\r\n    zIndex: \"1\",\r\n    borderTopRightRadius: \"50%\",\r\n    borderTopLeftRadius: \"50%\",\r\n    borderBottomRightRadius: \"50%\",\r\n    borderBottomLeftRadius: \"50%\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\"\r\n\r\n  },\r\n  timelineSimpleBadgeInverted: {\r\n    right: \"7px\"\r\n  },\r\n  custom: {\r\n    backgroundColor: customApp(\"color\"),\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.4)\"\r\n  },\r\n  info: {\r\n    backgroundColor: infoColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(infoColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  success: {\r\n    backgroundColor: successColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(successColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  danger: {\r\n    backgroundColor: dangerColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(dangerColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  warning: {\r\n    backgroundColor: warningColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(warningColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  primary: {\r\n    backgroundColor: primaryColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(primaryColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  badgeIcon: {\r\n    width: \"14px\",\r\n    height: \"14px\"\r\n  },\r\n  timelinePanel: {\r\n    maxWidth: \"calc(100% - 70px)\",\r\n    float: \"right\",\r\n    padding: \"7px\",\r\n    marginBottom: \"5px\",\r\n    marginRight: \"40px\",\r\n    position: \"relative\",\r\n    boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n    borderRadius: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n    background: customApp(\"timelineMyMessage\"),\r\n  },\r\n  timelinePanelInverted: {\r\n    maxWidth: \"calc(100% - 70px)\",\r\n    float: \"left\",\r\n    padding: \"7px\",\r\n    marginLeft: \"40px\",\r\n    marginBottom: \"5px\",\r\n    position: \"relative\",\r\n    boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n    borderRadius: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n    background: \"#ffffff\",\r\n  },\r\n\r\n\r\n  timelineHeading: {\r\n    marginBottom: 0,\r\n    display: \"flex\",\r\n    alignItems: \"center\"\r\n  },\r\n  timelineDate: {\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    padding: \"5px\",\r\n    backgroundColor: \"#CCCCCC\"\r\n  },\r\n  timelineBody: {\r\n    overflowWrap: \"anywhere\",\r\n    fontSize: \"12px\",\r\n    lineHeight: \"21px\",\r\n    position: \"relative\",\r\n    width: \"100%\",\r\n    float: \"left\",\r\n  },\r\n  timelineLog: {\r\n    fontSize: \"12px\",\r\n    lineHeight: \"21px\",\r\n    // display: \"flex\",\r\n  },\r\n  timelineFooter: {\r\n    zIndex: \"1\",\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    width: \"100%\",\r\n    display: \"inline-flex\",\r\n    justifyContent: \"space-between\"\r\n  },\r\n  footerUser: {\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    fontSize: \"12px\",\r\n    fontWeight: \"bold\",\r\n    color: customApp(\"medium\"),\r\n    padding: \"0 7px\",\r\n  },\r\n  footerLine: {\r\n    position: \"relative\",\r\n    marginTop: \"10px\",\r\n    marginBottom: \"5px\"\r\n  },\r\n  dropFile: {\r\n    display: \"none\",\r\n  },\r\n  onDropFile: {\r\n    position: \"absolute\",\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\",\r\n    color: \"#FFFFFF\",\r\n    backgroundColor: \"rgba(0,0,0,0.77)\",\r\n    zIndex: 1,\r\n  },\r\n  editor: {\r\n    position: \"absolute\",\r\n    bottom: 0,\r\n    minHeight: \"50px\",\r\n    padding: \"10px\",\r\n    height: \"auto\",\r\n    width: \"calc(100% - 0px)\",\r\n    backgroundColor: \"rgba(240,240,240,1)\",\r\n    zIndex: 10,\r\n  },\r\n  files: {\r\n    display: \"inline-table\",\r\n    position: \"relative\"\r\n  },\r\n  textEditor: {\r\n    //display: \"flex\"\r\n  },\r\n  textEditorIcon: {\r\n    cursor: \"pointer\",\r\n    color: customApp(\"color\"),\r\n  },\r\n  progressBar: {\r\n    backgroundColor: `${customApp(\"color\", \"0.1\")} !important`,\r\n    \"& .MuiLinearProgress-indeterminate\": {\r\n      backgroundColor: `${customApp(\"color\")} !important`\r\n    },\r\n    \"& .MuiLinearProgress-bar\": {\r\n      backgroundColor: `${customApp(\"color\")} !important`\r\n    },\r\n  },\r\n  actionButton: {\r\n    alignItems: \"center\",\r\n    cursor: \"pointer\",\r\n    float: \"left\",\r\n    height: \"30px\",\r\n    position: \"relative\",\r\n    textAlign: \"center\",\r\n    width: \"30px\",\r\n  },\r\n  sendingMessage: {\r\n    width: \"100%\"\r\n  },\r\n  valuePositive: {\r\n    positive: \"relative\",\r\n    float: \"left\",\r\n    color: \"blue\",\r\n  },\r\n  valueNegative: {\r\n    positive: \"relative\",\r\n    float: \"left\",\r\n    color: \"red\",\r\n  },\r\n  lastValue: {\r\n    positive: \"relative\",\r\n    float: \"right\",\r\n    color: \"grey\",\r\n  },\r\n  timeInfo: {\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    color: \"grey\",\r\n    width: \"100%\",\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    marginBottom: \"7px\",\r\n    \"& .text\": {\r\n      marginLeft: \"7px\",\r\n    }\r\n  },\r\n  urlPreview: {\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    marginBottom: \"33px\",\r\n    \"& img\": {\r\n      maxWidth: \"20%\",\r\n      height: \"auto\",\r\n      // position: \"relative\",\r\n      // float: \"left\",\r\n      marginTop: \"30px\",\r\n      marginRight: \"7px\"\r\n    },\r\n    \"& .data\": {\r\n      // position: \"relative\",\r\n      // float: \"left\",\r\n      //width: \"75%\",\r\n      \"& .title\": {\r\n        fontSize: \"16px\",\r\n        fontWeight: \"bold\",\r\n      },\r\n      \"& .siteName\": {\r\n        fontSize: \"14px\",\r\n        fontWeight: \"bold\",\r\n        color: \"#909090\"\r\n      },\r\n      \"& .contentSnippet\": {\r\n        fontSize: \"12px\",\r\n        color: \"#909090\"\r\n      }\r\n    }\r\n  },\r\n  users: {\r\n    position: \"relative\",\r\n    bottom: 0,\r\n    right: \"2px\",\r\n    fontSize: \"10px\",\r\n    \"& .MuiAvatarGroup-root\": {\r\n      justifyContent: \"flex-end\",\r\n    },\r\n    \"& .MuiAvatar-root\": {\r\n      width: \"25px\",\r\n      height: \"25px\",\r\n      fontSize: \"10px\",\r\n    }\r\n  }\r\n});\r\n\r\nexport default timelineStyle;\r\n","import React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//DEPENDENCIES\nimport SendingMessage from \"./newSending.js\"\nimport Comment from \"./comment\";\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\nimport Skeleton from '@material-ui/lab/Skeleton';\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/timelineSocialStyle.js\";\n\n//FUNCTIONS\nimport {\n  chatReaded,\n  loadTimeline\n} from \"functions/chat\";\n\nconst Timeline = (props) => {\n  const { classes } = props;\n  const { db, session, functions, chat, timeline } = reduxStore.getState();\n  const { socket } = functions;\n  const [stories, setStories] = React.useState(props.stories || {})\n  const [loading, setLoading] = React.useState(true)\n  const [skip, setSkip] = React.useState(false)\n  const [limit, setLimit] = React.useState(false)\n\n  let files = []; //USED IN LIGHTBOX;\n\n  React.useEffect(() => {\n    if (timeline && timeline[props.data._id] && Object.keys(timeline[props.data._id]).length !== Object.keys(stories).length) {\n      setStories(timeline[props.data._id])\n    }\n    return () => {\n      //CLEAN UNMOUNT\n    }\n  }, [timeline])\n\n  React.useEffect(() => {\n    if (props.data._id)\n      init()\n  }, [props.data])\n\n  const init = async () => {\n    const timelineD = await loadTimeline(\n      {\n        ...props,\n        fnIdentification: \"Timeline/social/init()\"\n      },\n      {\n        ids: [props.data._id],\n        db: 'cards',\n        type: \"comment\",\n        limit,\n        skip\n      }\n      // {\n      //   ids: props.nodeId,\n      //   db: timelineDb,\n      //   type: props.type ? props.type : 'comment',\n      //   limit: true,\n      //   skip: stories.filter(fil => fil.type === props.type).length > 0 ? stories.filter(fil => fil.type === props.type).length - 1 : 0\n      // }\n    )\n    if (timelineD && timelineD.timelines && timelineD.timelines[props.data._id]) {\n      setStories(timelineD.timelines[props.data._id])\n      setTimeout(() => {\n        setLoading(false)\n      }, 300)\n    } else if (timelineD && timelineD.result) {\n      setTimeout(() => {\n        setLoading(false)\n      }, 300)\n    }\n  }\n\n\n  const openLightBox = (f) => {\n    props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n      open: true,\n      files: files,\n      file: f\n    })\n  }\n\n  const readMessages = async () => {\n    if (Object.keys(stories)\n      .filter(st => {\n        if (stories[st].user\n          && stories[st].user._id !== session._id\n          && (\n            !stories[st].readedBy\n            || (\n              stories[st].readedBy\n              && !stories[st].readedBy[session._id]\n            )\n          )) {\n          return true\n        }\n      }).length > 0) {\n\n      chatReaded(props, {\n        readedBy: session._id,\n        id: props.nodeId,\n        db: db.cards[props.nodeId] ? 'cards' : 'users'\n      })\n      socket.emit(\"data\", {\n        module: \"chat\",\n        method: \"put\",\n        action: \"read\"\n      }, {\n        readedBy: session._id,\n        id: props.nodeId,\n        db: db.cards[props.nodeId] ? 'cards' : 'users',\n        _client: db.cards[props.nodeId] && db.cards[props.nodeId].client ? db.cards[props.nodeId].client : null\n      })\n    }\n  }\n\n  if (loading)\n    return (\n      <div style={{ width: \"100%\" }}>\n        <Skeleton variant=\"text\" height={11} style={{ marginBottom: '3px' }} />\n        <Skeleton variant=\"text\" height={11} style={{ marginBottom: '3px' }} />\n        <Skeleton variant=\"text\" height={11} style={{ marginBottom: '3px' }} />\n      </div>\n    )\n\n  return (\n    <div style={{ position: \"relative\", float: \"left\", width: \"100%\" }}>\n\n      <ul className={classes.timelineSimple}\n        id={`tms_${props.nodeId}`}\n        style={{ zIndex: 1 }}\n      >\n        {stories\n          && Object.keys(stories).length > 0\n          && Object.keys(stories).sort((a, b) => {\n            if (parseInt(stories[a].created_at) < parseInt(stories[b].created_at)) {\n              return -1\n            } else if (parseInt(stories[a].created_at) > parseInt(stories[b].created_at)) {\n              return 1\n            } else {\n              return 0\n            }\n          }\n          ).map((id, key) => {\n            let storie = stories[id]\n            if (!props.showUnReaded && key > Object.keys(stories).length - 4) {\n              if (storie.files && Object.keys(storie.files).length > 0)\n                Object.keys(storie.files).map((id, i) => {\n                  let file = storie.files[id]\n                  files.push(file)\n                })\n              return (\n                <li\n                  key={id}\n                >\n                  <Comment\n                    openLightBox={(e) => { openLightBox(e) }}\n                    storie={storie}\n                    reply={storie.reply ? stories[storie.reply] : null}\n                    hideCards={props.hideCards ? true : false}\n                    db={props.db}\n                    nodeId={props.nodeId}\n                  />\n                </li>\n              );\n            } else if (\n              props.showUnReaded\n              && storie\n              && storie.user\n              && storie.user._id !== session._id\n              && (\n                !storie.readedBy\n                ||\n                (\n                  storie.readedBy\n                  && !storie.readedBy[session._id]\n                )\n              )\n            ) {\n              if (storie.files && Object.keys(storie.files).length > 0)\n                Object.keys(storie.files).map((id, i) => {\n                  let file = storie.files[id]\n                  files.push(file)\n                })\n              return (\n                <li\n                  className={classes.item}\n                  key={id}\n                  style={{\n                  }}>\n                  <Comment\n                    openLightBox={(e) => { openLightBox(e) }}\n                    storie={storie}\n                    reply={storie.reply ? stories[storie.reply] : null}\n                    hideCards={props.hideCards ? true : false}\n                    db={props.db}\n                    nodeId={props.nodeId}\n                  />\n                </li>\n              );\n            }\n          })}\n        <div style={{ marginBottom: '15px', clear: 'both' }}></div>\n      </ul>\n      {props.data && props.data._id &&\n        <SendingMessage nodeId={props.data._id} onSending={() => { readMessages() }} placeholder={\"Escreva um comentário\"} />\n      }\n    </div >\n  );\n}\n//REACT\nconst mapStateToProps = (store, ownProps) => ({\n  store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n  mapStateToProps,\n  mapDispatchToProps\n)(withStyles(styles)(Timeline));","//CORE\nimport React from \"react\"\nimport Moment from \"moment-timezone\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Reactions from \"components/Reactions_V2\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport Timeline from \"components/Timeline/social\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/BrightAndConnected-card.js\"\nimport { translate, customApp } from \"functions\"\n\n\nfunction Component(props) {\n    const { classes } = props\n    const [data, setData] = React.useState({})\n\n    React.useEffect(() => {\n        setData(props.data)\n    }, [])\n\n    const sendToInsight = () => {\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...reduxStore.getState().sideModule,\n            id: \"new\",\n            activeModule: \"cardEdit\",\n            db: \"cards\",\n            data: {\n                _id: \"new\",\n                type: \"link\",\n                name: data.title,\n                description: data.contentSnippet,\n                pubDate: data.isoDate ? data.isoDate : data.pubDate,\n                image: data.img,\n                url: data.link,\n            }\n        })\n    }\n    return (\n        <div className={classes.feed} style={{ cursor: \"pointer\" }}\n            onClick={props.onClick ? () => props.onClick() : null}\n        >\n            {data && data.img &&\n                <div\n                    style={\n                        {\n                            display: \"flex\",\n                            alignItems: \"center\",\n                            justifyContent: \"center\",\n                        }\n                    }\n                >\n                    <img\n                        src={data.img}\n                        style={{ width: \"100%\" }}\n                        onError={() => {\n                            setData({\n                                ...data,\n                                img: null\n                            })\n                        }}\n                    />\n                </div>\n            }\n            <div className={classes.infos}>\n                <div className={classes.linkTitle}\n                    dangerouslySetInnerHTML={{ __html: data.title }}>\n                </div>\n\n                <div\n                    dangerouslySetInnerHTML={{ __html: data.contentSnippet }}\n                    className={classes.linkContent}\n                />\n                <div className={classes.feedFooter} onClick={(e) => { e.stopPropagation() }}>\n                    <div className={classes.feedDate}>{Moment(data.isoDate ? data.isoDate : data.pubDate).format(\"DD/MM/YYYY HH:MM\")}</div>\n                    {data.title && data.title.indexOf('Violet ganham') > -1 && console.log(data)}\n                    <Reactions data={data}>\n                        <div style={{ marginLeft: \"15px\" }}>\n                            <IconButton\n                                icon={\"settings_input_antenna\"}\n                                title={translate(`$__sendToRadar`, 1)}\n                                iconColor={customApp(\"menu\")}\n                                size={\"18px\"}\n                                onClick={() => {\n                                    sendToInsight()\n                                }}\n                            />\n                        </div>\n                    </Reactions>\n                </div>\n                {!props.hideTimeline &&\n                    <div className={classes.feedFooter} onClick={(e) => { e.stopPropagation() }}>\n                        <Timeline data={data} />\n                    </div>\n                }\n            </div>\n        </div>\n    )\n}\n\nconst mapStateToProps = store => ({\n    store\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport Card from \"components/BrightAndConnected/socialCard\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport LinearProgress from \"components/Progress/linear\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/BrightAndConnected-card.js\"\n\n//FUNCTIONS\nimport api from \"api/\"\nimport apims from \"apims\"\n\n\nfunction Component(props) {\n    const { data } = props\n    const [page, setPage] = React.useState(0)\n    const [total, setTotal] = React.useState(0)\n    const [limit, setLimit] = React.useState(7)\n    const [hashs, setHashs] = React.useState([])\n    const [links, setLinks] = React.useState([])\n    const [loading, setLoading] = React.useState(true)\n    const [mounted, setMounted] = React.useState(false)\n\n    React.useEffect(() => {\n        let Nhashs = window.location.hash.split(\"/\")\n        Nhashs[0] = Nhashs[0].replace(\"#\", \"\")\n        if (JSON.stringify(Nhashs) !== JSON.stringify(hashs)) {\n            setHashs(Nhashs)\n        }\n        setLoading(true)\n    }, [])\n\n    React.useEffect(() => {\n        if (hashs.length > 0 && !mounted) {\n            loadLinks(page, limit)\n            if (hashs[2] && hashs[2].length !== 36) {\n                setLoading(true)\n            }\n            setMounted(true)\n        }\n    }, [hashs])\n\n    React.useEffect(() => {\n        if (total > Object.keys(links).length) {\n            setLoading(true)\n            loadLinks(page, limit)\n        }\n    }, [page, limit])\n\n    React.useEffect(() => {\n        setLoading(false)\n    }, [links])\n\n    const loadLinks = async (p, l) => {\n        if ((total === 0 || total > Object.keys(links).length)) {\n            setLoading(true)\n            try {\n                const response = await apims.post(\"/Feed_Social_V2\", {\n                    ids: null,\n                    // ids: hashs[2] ? hashs[2] : null,\n                    skip: p * l,\n                    limit: l\n                })\n\n                let loadFeeds = {}\n                let total = 0\n\n                if (response && response.data && response.data.length > 0) {\n                    response.data.map(lk => {\n                        let reactions = {}\n                        if (lk.reactions && lk.reactions.filter(a => a && a.user && a.user._id).length > 0)\n                            lk.reactions.map(r => {\n\n                                reactions = {\n                                    ...reactions,\n                                    [r.react.type]: {\n                                        ...reactions && reactions[r.react.type] ? reactions && reactions[r.react.type] : {},\n                                        [r.user._id]: {\n                                            ...r.user,\n                                            reactDate: r.react.created_at\n                                        }\n                                    }\n                                }\n                            })\n                        loadFeeds = {\n                            ...loadFeeds,\n                            [lk.link._id]: {\n                                ...lk.link,\n                                _reactions: reactions\n                            }\n                        }\n                        if (lk.total > total)\n                            total = lk.total\n                    })\n                }\n                setTotal(total)\n                setLinks({\n                    ...links,\n                    ...loadFeeds,\n                })\n            } catch (e) {\n                console.log(e)\n            }\n        }\n    }\n\n    const scrollFunction = (e) => {\n        var scrollDiv = document.getElementById(`linkList`);\n        if (!loading && scrollDiv.scrollHeight - scrollDiv.scrollTop < 2500)\n            setPage(page + 1)\n    }\n\n    return (\n        <div style={{\n            position: \"absolute\",\n            bottom: 0,\n            left: 0,\n            right: 0,\n            top: 0,\n        }}>\n            <div style={{\n                position: \"absolute\",\n                top: data && (data.customTitle || data.name) ? 50 : 0,\n                left: 0,\n                right: 0,\n                bottom: 0,\n                padding: \"0px 15px\",\n                overflow: \"auto\"\n            }}\n                id={\"linkList\"}\n                onScroll={(e) => {\n                    scrollFunction(e)\n                }}\n            >\n                <GridContainer>\n                    {total > 0 && Object.keys(links).sort((a, b) => {\n                        if (links[a].isoDate && links[b].isoDate && links[a].isoDate < links[b].isoDate)\n                            return 1\n                        if (links[a].isoDate && links[b].isoDate && links[a].isoDate > links[b].isoDate)\n                            return -1\n                        return 0\n                    }).map(lk => {\n                        return (\n                            <GridContainer\n                                key={lk}\n                                style={{\n                                    display: \"flex\",\n                                    justifyContent: \"center\"\n                                }}\n                            >\n                                <GridItem\n                                    xs={12}\n                                    sm={10}\n                                    md={8}\n                                    lg={6}\n                                    xl={6}\n                                >\n                                    <Card\n                                        db=\"cards\"\n                                        data={links[lk]}\n                                        onClick={() => { window.open(links[lk].link, \"_blank\") }}\n                                    />\n                                </GridItem>\n                            </GridContainer>\n                        )\n                    })}\n                </GridContainer>\n                {(loading) &&\n                    <div style={{ position: \"relative\", width: \"100%\" }}>\n                        <LinearProgress />\n                    </div>\n                }\n            </div>\n        </div>\n    )\n}\nconst mapStateToProps = () => ({\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport Card from \"components/BrightAndConnected/socialCard\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport IconButton from \"components/CustomButtons/IconButton.js\"\nimport LinearProgress from \"components/Progress/linear\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/BrightAndConnected-card.js\"\n\n//FUNCTIONS\nimport apims from \"apims\"\n\nfunction Component(props) {\n    const { data, classes } = props\n    const { db } = reduxStore.getState()\n    const [page, setPage] = React.useState(0)\n    const [total, setTotal] = React.useState(0)\n    const [limit, setLimit] = React.useState(5)\n    const [hashs, setHashs] = React.useState([])\n    const [links, setLinks] = React.useState([])\n    const [loading, setLoading] = React.useState(true)\n    const [mounted, setMounted] = React.useState(false)\n\n    React.useEffect(() => {\n        let Nhashs = window.location.hash.split(\"/\")\n        Nhashs[0] = Nhashs[0].replace(\"#\", \"\")\n        if (JSON.stringify(Nhashs) !== JSON.stringify(hashs)) {\n            setHashs(Nhashs)\n        }\n        setLoading(true)\n    }, [])\n\n    React.useEffect(() => {\n        if (hashs.length > 0 && !mounted) {\n            loadLink()\n            if (hashs[2] && hashs[2].length !== 36) {\n                setLoading(true)\n            }\n            setMounted(true)\n        }\n    }, [hashs])\n\n    const loadLink = async (p, l) => {\n        if ((total === 0 || total > Object.keys(links).length)) {\n            setLoading(true)\n            try {\n                const response = await apims.post(\"/Feed_Social\", {\n                    id: hashs[2],\n                })\n\n                let loadFeeds = {}\n                if (response && response.data && response.data.links) {\n                    loadFeeds = {\n                        ...loadFeeds,\n                        ...response.data.links\n                    }\n                    setLinks({\n                        ...links,\n                        ...loadFeeds,\n                    })\n                    setLoading(false)\n                } else {\n                    setLoading(false)\n                }\n            } catch (e) {\n                console.log(e)\n            }\n        }\n    }\n\n    return (\n        <div style={{\n            position: \"absolute\",\n            bottom: 0,\n            left: 0,\n            right: 0,\n            top: 0,\n        }}>\n            <div style={{\n                position: \"absolute\",\n                top: data && (data.customTitle || data.name) ? 50 : 0,\n                left: 0,\n                right: 0,\n                bottom: 0,\n                padding: \"0px 15px\",\n                overflow: \"auto\"\n            }}\n                id={\"linkList\"}\n            >\n                <GridContainer>\n                    {Object.keys(links).length > 0 ?\n                        Object.keys(links).sort((a, b) => {\n                            if (links[a].isoDate && links[b].isoDate && links[a].isoDate < links[b].isoDate)\n                                return 1\n                            if (links[a].isoDate && links[b].isoDate && links[a].isoDate > links[b].isoDate)\n                                return -1\n                            return 0\n                        }).map(lk => {\n                            return (\n                                <GridContainer\n                                    key={lk}\n                                    style={{\n                                        display: \"flex\",\n                                        justifyContent: \"center\"\n                                    }}\n                                >\n                                    <GridItem\n                                        xs={12}\n                                        sm={6}\n                                        md={6}\n                                        lg={6}\n                                        xl={6}\n                                    >\n                                        <Card\n                                            db=\"cards\"\n                                            data={links[lk]}\n                                            onClick={() => { window.open(links[lk].link, \"_blank\") }}\n                                        />\n                                    </GridItem>\n                                </GridContainer>\n                            )\n                        })\n                        :\n                        <GridContainer\n                            style={{\n                                display: \"flex\",\n                                justifyContent: \"center\"\n                            }}\n                        >\n                            <GridItem\n                                xs={12}\n                                sm={6}\n                                md={6}\n                                lg={6}\n                                xl={6}\n                            >\n                                A feed solicitado não pode ser exibido\n                            </GridItem>\n                        </GridContainer>\n                    }\n                </GridContainer>\n                {(loading) &&\n                    <div style={{ position: \"relative\", width: \"100%\" }}>\n                        <LinearProgress />\n                    </div>\n                }\n            </div>\n        </div>\n    )\n}\nconst mapStateToProps = store => ({\n    store\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","import React from 'react';\r\n\r\n//REDUX\r\nimport { connect } from 'react-redux';\r\nimport { bindActionCreators } from 'redux';\r\nimport * as reduxActions from 'store/actions';\r\nimport reduxStore from \"store/\";\r\nimport history from \"store/history\";\r\n\r\n//COMPONENTS\r\nimport CardsLoader from \"components/Card/loader\";\r\nimport FilterHeader from \"components/Filter/header\";\r\n\r\n//DEPENCIES\r\nimport InsightBoards from \"./InsightBoards\";\r\nimport Radar from \"./Radar\";\r\nimport Feeds from \"./Feeds\";\r\nimport Home from \"./Home\";\r\nimport Read from \"./Read\";\r\nimport ListLinks from \"components/BrightAndConnected/listLinks\"\r\n\r\n//FUNCTIONS\r\nimport { getAppAccess, translate, customApp } from \"functions/\"\r\n\r\nfunction App(props) {\r\n    React.useEffect(() => {\r\n        console.log(\"StrategyAndPlans\")\r\n        return () => {\r\n            // return false\r\n        }\r\n    }, [])\r\n    if (!window.location.hash.split('/')[0].replace('#', '')) {\r\n        history.push('bright-and-connected#tab/home')\r\n    }\r\n\r\n    let hashs = window.location.hash.split('/')\r\n    hashs[0] = hashs[0].replace('#', '')\r\n\r\n    return (\r\n        <div>\r\n            {hashs[1]\r\n                && (\r\n                    hashs[1] === 'radar'\r\n                    || hashs[1] === 'insight-boards'\r\n                )\r\n                &&\r\n                <CardsLoader />\r\n            }\r\n            {hashs[1] && hashs[1] === 'home' &&\r\n                <React.Fragment>\r\n                    {/* <FilterHeader /> */}\r\n                    <Home />\r\n                </React.Fragment>\r\n            }\r\n            {hashs[1] && hashs[1] === 'read' &&\r\n                <React.Fragment>\r\n                    <FilterHeader />\r\n                    <Read />\r\n                </React.Fragment>\r\n            }\r\n            {hashs[1] && hashs[1] === 'insight-boards' &&\r\n                <React.Fragment>\r\n                    <FilterHeader />\r\n                    <InsightBoards />\r\n                </React.Fragment>\r\n            }\r\n            {hashs[1] && hashs[1] === 'radar' &&\r\n                <div style={{ top: 33 }}>\r\n                    {/* <FilterHeader /> */}\r\n                    <Radar />\r\n                </div>\r\n            }\r\n            {hashs[1] && (hashs[1] === 'feeds' || hashs[1] === 'bright-and-connected') &&\r\n                <React.Fragment>\r\n                    <FilterHeader />\r\n                    <Feeds />\r\n                </React.Fragment>\r\n            }\r\n            {hashs[1] && hashs[1] === 'hideFeeds' &&\r\n                <React.Fragment>\r\n                    <FilterHeader />\r\n                    <Feeds showHidden={true} />\r\n                </React.Fragment>\r\n            }\r\n            {hashs[1] && hashs[1] === 'allNews' &&\r\n                <React.Fragment>\r\n                    <FilterHeader />\r\n                    <div style={{\r\n                        position: \"absolute\",\r\n                        bottom: 0,\r\n                        left: 0,\r\n                        right: 0,\r\n                        top: 0,\r\n                    }}>\r\n                        <ListLinks />\r\n                    </div>\r\n                </React.Fragment>\r\n            }\r\n        </div>\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    history: store.db.history\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch);\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(App);","import { withStyles } from '@material-ui/core/styles';\nimport Tooltip from \"@material-ui/core/Tooltip\"\n\nconst HtmlTooltip = withStyles((theme) => ({\n    tooltip: {\n        backgroundColor: 'rgba(0,0,0,0.5) !important',\n        color: 'rgba(0, 0, 0, 0.87)',\n        padding: \"5px !important\",\n        fontSize: theme.typography.pxToRem(12),\n        border: 'none',\n        borderRadius: '7px',\n        boxShadow: '3px 3px 7px 0px rgba(0,0,0,0.7)',\n        // display: 'flex',\n        alignItems: 'center',\n        justifyContent: 'center',\n    },\n}))(Tooltip);\n\nexport default HtmlTooltip","import React from \"react\"\r\nimport { Calendar, momentLocalizer, dateFnsLocalizer } from \"react-big-calendar\"\r\nimport withDragAndDrop from 'react-big-calendar/lib/addons/dragAndDrop'\r\nimport moment from \"moment\"\r\nimport 'moment/locale/pt-br';\r\nimport HtmlTooltip from \"components/Tooltip/transparent\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n//COMPONENTS\r\nimport ActivityCard from \"components/Card/\";\r\nimport Badge from \"components/Icon/Badge\";\r\nimport Card from \"components/Card/Card.js\";\r\nimport CardBody from \"components/Card/CardBody.js\";\r\nimport CardsLoader from \"components/Card/loader\"\r\nimport CustomButton from \"components/Buttons/custom\";\r\nimport GridContainer from \"components/Grid/GridContainer.js\";\r\nimport GridItem from \"components/Grid/GridItem.js\";\r\nimport MoreMenu from \"components/MoreMenu\";\r\n\r\n//FUNCTIONS\r\nimport { customApp, translate, textColor, hexToRgba } from \"functions\";\r\nimport { updateCardData, setCompleted } from \"functions/cards\"\r\n\r\n//STYLES\r\nimport \"assets/css/components/react-big-calendar.css\"\r\nimport \"assets/css/components/react-big-calendar-resizable.css\"\r\n\r\nconst MachenCalendar = withDragAndDrop(Calendar)\r\n//VARIABLES\r\n\r\nconst messages = {\r\n  allDay: translate(\"$__allDay\"),\r\n  previous: '<',\r\n  next: '>',\r\n  today: translate(\"$__today\"),\r\n  month: translate(\"$__month\"),\r\n  week: translate(\"$__week\"),\r\n  day: translate(\"$__aday\"),\r\n  agenda: translate(\"$__agenda\"),\r\n  date: translate(\"$__date\"),\r\n  time: translate(\"$__hour\"),\r\n  event: translate(\"$__activity\"),\r\n  showMore: (total) => `+ (${total}) ${translate(\"$__activities\")}`,\r\n}\r\n\r\nexport let navigate = {\r\n  PREVIOUS: 'PREV',\r\n  NEXT: 'NEXT',\r\n  TODAY: 'TODAY',\r\n  DATE: 'DATE',\r\n}\r\n\r\nfunction CustomToolbar(props) {\r\n  const { session } = reduxStore.getState()\r\n\r\n  let { localizer: { messages }, label } = props\r\n\r\n  const navigate = action => {\r\n    props.onNavigate(action)\r\n  }\r\n\r\n  const buttomStyle = {}\r\n  return (\r\n    <div className=\"rbc-toolbar\">\r\n      <span className=\"rbc-btn-group\">\r\n        <button type=\"button\"\r\n          onClick={() => { navigate('PREV') }} style={{ backgroundColor: customApp('menu'), borderRadius: 0 }}>{translate(\"$__prev\")}</button>\r\n      </span>\r\n      <span className=\"rbc-toolbar-label\">{label}</span>\r\n      <span className=\"rbc-btn-group\">\r\n        <button type=\"button\" onClick={() => { navigate('NEXT') }} style={{ backgroundColor: customApp('menu'), borderRadius: 0 }}>{translate(\"$__next\")}</button>\r\n      </span>\r\n      <span className=\"rbc-btn-group\">\r\n        <button type=\"button\" onClick={() => { navigate('TODAY') }} style={{ backgroundColor: customApp('menu'), borderRadius: 0 }}>{translate(\"$__today\")}</button>\r\n      </span>\r\n      <span className=\"rbc-btn-group\">\r\n        <button type=\"button\" onClick={() => { navigate('day') }} style={{ backgroundColor: customApp('menu'), borderRadius: 0 }}>{translate(\"$__day\")}</button>\r\n      </span>\r\n      <span className=\"rbc-btn-group\">\r\n        <button type=\"button\" onClick={() => { navigate('week') }} style={{ backgroundColor: customApp('menu'), borderRadius: 0 }}>{translate(\"$__week\")}</button>\r\n      </span>\r\n      <span className=\"rbc-btn-group\">\r\n        <button type=\"button\" onClick={() => { navigate('month') }} style={{ backgroundColor: customApp('menu'), borderRadius: 0 }}>{translate(\"$__month\")}</button>\r\n      </span>\r\n      {/* <span className=\"rbc-btn-group\">\r\n        <button type=\"button\" onClick={() => { navigate('agenda') }} style={{ backgroundColor: customApp('menu'), borderRadius: 0 }}>{translate(\"$__agenda\")}</button>\r\n      </span> */}\r\n    </div >\r\n  )\r\n}\r\n\r\nfunction CalendarComponent(props) {\r\n  const { reduxFunction, search } = props\r\n  const { db, session } = reduxStore.getState()\r\n  const [events, setEvents] = React.useState([]);\r\n  const [alert, setAlert] = React.useState(null);\r\n  const [view, setView] = React.useState('week')\r\n  const [selectedDate, setSelectedDate] = React.useState(moment().toLocaleString())\r\n  const [selectedCard, setSelectedCard] = React.useState(null)\r\n  const [showAllEvents, setShowAllEvents] = React.useState(false)\r\n  const [severalDaysActivities, setSeveralDaysActivities] = React.useState(false)\r\n  const [disabledTypes, setDisabledTypes] = React.useState([])\r\n\r\n  moment.locale(session.language ? session.language.toLowerCase() : 'pt-br', {\r\n    week: {\r\n      dow: 1\r\n    }\r\n  });\r\n  const localizer = momentLocalizer(moment);\r\n\r\n  React.useEffect(() => {\r\n    let preffers = session && session.calendarPreffers ? JSON.parse(session.calendarPreffers) : {}\r\n    if (preffers.view)\r\n      setView(preffers.view)\r\n    if (preffers.view)\r\n      setShowAllEvents(preffers.showAllEvents)\r\n    if (preffers.severalDaysActivities)\r\n      setSeveralDaysActivities(preffers.severalDaysActivities)\r\n    if (preffers.disabledTypes)\r\n      setDisabledTypes(Array.from(preffers.disabledTypes))\r\n  }, [])\r\n\r\n  React.useEffect(() => {\r\n    iniCards()\r\n  }, [props.cards, search])\r\n\r\n  React.useEffect(() => {\r\n    iniCards()\r\n    saveCalendarPreffers()\r\n  }, [severalDaysActivities, disabledTypes])\r\n\r\n  const saveCalendarPreffers = async () => {\r\n    let preffers = session.calendarPreffers ? JSON.parse(session.calendarPreffers) : {}\r\n    preffers = {\r\n      ...preffers,\r\n      disabledTypes: Array.from(disabledTypes),\r\n      showAllEvents: showAllEvents,\r\n      severalDaysActivities: severalDaysActivities,\r\n      view: view,\r\n    }\r\n\r\n    const { socket } = reduxStore.getState().functions\r\n    socket.emit(\"data\", {\r\n      module: \"user\",\r\n      method: \"post\",\r\n      action: \"preffers\"\r\n    }, {\r\n      calendarPreffers: JSON.stringify(preffers)\r\n    }, data => {\r\n      if (data.error)\r\n        console.log(\"hideSupportAndAppBanner\", data.error)\r\n    })\r\n  }\r\n\r\n  const iniCards = async () => {\r\n    let CalendarEvents = []\r\n    Object.keys(reduxStore.getState().db.cards).filter(dt =>\r\n      reduxStore.getState().db.cards[dt]\r\n      && reduxStore.getState().db.cards[dt]._users\r\n      && reduxStore.getState().db.cards[dt]._users[session._id]\r\n      &&\r\n      (\r\n        !reduxStore.getState().db.cards[dt].checklist\r\n        || (\r\n          reduxStore.getState().db.cards[dt].checklist\r\n          && reduxStore.getState().db.cards[dt].showCard\r\n        )\r\n      )\r\n      && (\r\n        moment(reduxStore.getState().db.cards[dt].startDate * 1000).isValid()\r\n        && moment(reduxStore.getState().db.cards[dt].endDate * 1000).isValid()\r\n      )\r\n      && (disabledTypes.length === 0\r\n        || (\r\n          disabledTypes.length > 0\r\n          && disabledTypes.indexOf(reduxStore.getState().db.cards[dt].type) === -1\r\n        )\r\n      )\r\n      && reduxStore.getState().db.cards[dt].type !== \"plan\"\r\n      && reduxStore.getState().db.cards[dt].type !== \"chatGroup\"\r\n      && reduxStore.getState().db.cards[dt].status !== \"completed\"\r\n      && !reduxStore.getState().db.cards[dt].deleted\r\n      && (\r\n        severalDaysActivities\r\n        ||\r\n        (\r\n          !severalDaysActivities\r\n          && (\r\n            moment(reduxStore.getState().db.cards[dt].startDate * 1000).format('YYYY-MM-DD') === moment(reduxStore.getState().db.cards[dt].endDate * 1000).format('YYYY-MM-DD')\r\n          )\r\n        )\r\n      )\r\n      && (\r\n        search.tags.length === 0\r\n        ||\r\n        (\r\n          search.tags.length > 0\r\n          && reduxStore.getState().db.cards[dt]._tags\r\n          && reduxStore.getState().db.cards[dt]._tags.length > 0\r\n          && reduxStore.getState().db.cards[dt]._tags.filter(tag => {\r\n            let result = false\r\n            search.tags.map(tagFilter => {\r\n              if (tagFilter.value === tag.value)\r\n                result = true\r\n            })\r\n            return result\r\n          }\r\n          ).length > 0\r\n        )\r\n      )\r\n      && (\r\n        search.text === \"\"\r\n        || (\r\n          search.text !== \"\"\r\n          && (\r\n            reduxStore.getState().db.cards[dt].name.toLowerCase().indexOf(search.text.toLowerCase()) > -1\r\n            || (\r\n              reduxStore.getState().db.cards[dt].description\r\n              && reduxStore.getState().db.cards[dt].description.toLowerCase().indexOf(search.text.toLowerCase()) > -1\r\n            )\r\n          )\r\n        )\r\n      )\r\n      && search.cards.status[reduxStore.getState().db.cards[dt].status]\r\n      && (\r\n        search.cards.priority.all\r\n        || (\r\n          reduxStore.getState().db.cards[dt].priority\r\n          && search.cards.priority[reduxStore.getState().db.cards[dt].priority]\r\n        )\r\n      )\r\n      && (\r\n        search.cards.risk.all\r\n        || (\r\n          reduxStore.getState().db.cards[dt].risk\r\n          && search.cards.risk[reduxStore.getState().db.cards[dt].risk]\r\n        )\r\n      )\r\n      && (\r\n        search.cards.complexity.all\r\n        || (\r\n          reduxStore.getState().db.cards[dt].complexity\r\n          && search.cards.complexity[reduxStore.getState().db.cards[dt].complexity]\r\n        )\r\n      )\r\n      && (\r\n        search.cards.impact.all\r\n        || (\r\n          reduxStore.getState().db.cards[dt].impact\r\n          && search.cards.impact[reduxStore.getState().db.cards[dt].impact]\r\n        )\r\n      )\r\n      && (\r\n        Object.keys(search.users.selected).length === 0\r\n        || (\r\n          Object.keys(search.users.selected).length > 0\r\n          && Object.keys(reduxStore.getState().db.cards[dt]._users).filter(uf => search.users.selected[uf]).length > 0\r\n        )\r\n      )\r\n    ).map(dt => {\r\n      let allDay = false\r\n      let startDate = moment(reduxStore.getState().db.cards[dt].startDate * 1000).toDate()\r\n      let endDate = moment(reduxStore.getState().db.cards[dt].endDate * 1000).toDate()\r\n      let diffDate = moment(reduxStore.getState().db.cards[dt].endDate * 1000).unix('x') - moment(reduxStore.getState().db.cards[dt].startDate * 1000).unix('x')\r\n\r\n      if (\r\n        (\r\n          moment(reduxStore.getState().db.cards[dt].startDate * 1000).format(\"HH:mm:ss\") === \"00:00:00\"\r\n          && moment(reduxStore.getState().db.cards[dt].endDate * 1000).format(\"HH:mm:ss\") === \"23:59:59\"\r\n        )\r\n        ||\r\n        (\r\n          Math.ceil(diffDate / 60 / 60) > 23\r\n        )\r\n      )\r\n        allDay = true\r\n\r\n      CalendarEvents.push(\r\n        {\r\n          title: reduxStore.getState().db.cards[dt].name,\r\n          allDay: allDay,\r\n          startDate: startDate,\r\n          endDate: endDate,\r\n          _id: dt,\r\n        }\r\n      )\r\n    })\r\n    setEvents(CalendarEvents)\r\n  }\r\n\r\n  const addNewEvent = (e) => {\r\n    reduxFunction(\"ASYNC\", \"SET_MODULE\", {\r\n      ...reduxStore.getState().sideModule,\r\n      db: 'cards',\r\n      id: 'new',\r\n      module: \"cardEdit\",\r\n      activeModule: 'cardEdit',\r\n      data: {\r\n        type: \"task\",\r\n        startDate: moment(e.start).unix(\"x\"),\r\n        endDate: moment(e.end).unix(\"x\"),\r\n      },\r\n    })\r\n  };\r\n\r\n  return (\r\n    <div>\r\n      {alert}\r\n      <CardsLoader />\r\n      <GridContainer>\r\n        <div\r\n          style={{\r\n            display: \"flex\",\r\n            justifyContent: \"flex-end\",\r\n            alignItems: \"center\",\r\n            width: \"100%\",\r\n          }}\r\n        >\r\n          <MoreMenu\r\n            text={translate(\"$__legend\")}\r\n            icon={\"style\"}\r\n            horizontalButton\r\n            transparent\r\n            size={'21px'}\r\n            color={'lightgray'}\r\n            btColor={'lightgray'}\r\n            buttonStyle={{ backgroundColor: customApp('menu'), borderRadius: 0 }}\r\n            options={[\r\n              {\r\n                name: translate(\"$__scheduleColor\", 1),\r\n                icon: 'label',\r\n                iconColor: \"gray\",\r\n                color: \"gray\",\r\n                disabled: true,\r\n              },\r\n              {\r\n                name: translate(\"$__late\", 1),\r\n                icon: 'label',\r\n                iconColor: \"red\",\r\n                disabled: true\r\n              },\r\n              ...db.status.map(x => {\r\n                return {\r\n                  name: translate(`${x.label}`, 1),\r\n                  icon: 'label',\r\n                  iconColor: x.color,\r\n                  disabled: true\r\n                }\r\n              }),\r\n              {\r\n                name: translate(\"$__scheduleLeftBorderColor\", 1),\r\n                icon: 'border_left',\r\n                color: 'gray',\r\n                iconColor: \"gray\",\r\n                disabled: true\r\n              },\r\n              ...db.priority.map(x => {\r\n                return {\r\n                  name: translate(`${x.label}`, 1),\r\n                  icon: 'border_left',\r\n                  color: x.color,\r\n                  iconColor: x.color,\r\n                  disabled: true\r\n                }\r\n              }),\r\n            ]}\r\n          />\r\n\r\n          <MoreMenu\r\n            text={translate(\"$__type\")}\r\n            icon={\"collections_bookmark\"}\r\n            horizontalButton\r\n            transparent\r\n            size={'21px'}\r\n            color={customApp(\"lightgray\")}\r\n            btColor={customApp(\"lightgray\")}\r\n            buttonStyle={{ backgroundColor: customApp('menu'), borderRadius: 0 }}\r\n            forceStopPropagation={true}\r\n            options={[\r\n              ...db.type.filter(x => x.calendar).map(x => {\r\n                return {\r\n                  name: translate(`${x.label}`, 1),\r\n                  icon: x.icon,\r\n                  iconColor: disabledTypes.indexOf(x.value) > -1 ? 'lightgray' : customApp('menu'),\r\n                  color: disabledTypes.indexOf(x.value) > -1 ? 'lightgray' : customApp('menu'),\r\n                  onClick: () => {\r\n                    let types = Array.from(disabledTypes)\r\n                    if (types.indexOf(x.value) === -1) {\r\n                      types.push(x.value)\r\n                    } else {\r\n                      types.splice(types.indexOf(x.value), 1)\r\n                    }\r\n                    setDisabledTypes(types)\r\n                  }\r\n                }\r\n              }),\r\n              {\r\n                name: disabledTypes.length === db.type.filter(xx => xx.calendar).length ? translate(`$__showAll`, 1) : translate(`$__hideAll`, 1),\r\n                icon: 'clear_all',\r\n                iconColor: disabledTypes.length !== db.type.filter(xx => xx.calendar).length ? 'lightgray' : customApp('menu'),\r\n                color: disabledTypes.length !== db.type.filter(xx => xx.calendar).length ? 'lightgray' : customApp('menu'),\r\n                onClick: () => {\r\n                  if (disabledTypes.length === db.type.filter(xx => xx.calendar).length) {\r\n                    setDisabledTypes([])\r\n                  } else {\r\n                    let types = []\r\n                    db.type.filter(xx => xx.calendar).map(xx => {\r\n                      types.push(xx.value)\r\n                    })\r\n                    setDisabledTypes(types)\r\n                  }\r\n                }\r\n              }\r\n            ]}\r\n          />\r\n          <MoreMenu\r\n            text={translate(\"$__options\")}\r\n            icon={\"settings\"}\r\n            horizontalButton\r\n            transparent\r\n            size={'21px'}\r\n            color={\"lightgray\"}\r\n            btColor={\"lightgray\"}\r\n            buttonStyle={{ backgroundColor: customApp('menu'), borderRadius: 0 }}\r\n            style={{\r\n              marginRight: \"15px\"\r\n            }}\r\n            options={[\r\n              {\r\n                name: translate(`$__showAllEvents`, '*'),\r\n                icon: !showAllEvents ? 'radio_button_unchecked' : 'check_circle_outline',\r\n                onClick: () => {\r\n                  setShowAllEvents(prev => !prev)\r\n                },\r\n              },\r\n              {\r\n                name: translate(`$__activitiesTInSeveralDays`, '*'),\r\n                icon: !severalDaysActivities ? 'radio_button_unchecked' : 'check_circle_outline',\r\n                onClick: () => {\r\n                  setSeveralDaysActivities(prev => !prev)\r\n                },\r\n              },\r\n            ]}\r\n          />\r\n        </div>\r\n        <GridItem xs={12} sm={12} md={12}>\r\n          <Card>\r\n            <CardBody>\r\n              <MachenCalendar\r\n                selectable\r\n                localizer={localizer}\r\n                events={events}\r\n                messages={messages}\r\n                defaultDate={new Date()}\r\n                onSelectSlot={addNewEvent}\r\n                startAccessor=\"startDate\"\r\n                endAccessor=\"endDate\"\r\n                onView={(x) => {\r\n                  setView(x)\r\n                }}\r\n                onSelectEvent={(event) => {\r\n                  setSelectedCard(event._id)\r\n                  reduxFunction(\"ASYNC\", \"SET_MODULE\", {\r\n                    ...reduxStore.getState().sideModule,\r\n                    db: 'cards',\r\n                    id: event._id,\r\n                    module: \"cardEdit\",\r\n                    activeModule: \"cardEdit\",\r\n                    data: reduxStore.getState().db.cards[event._id],\r\n                  })\r\n                }}\r\n                eventPropGetter={\r\n                  (event, start, end, isSelected) => {\r\n                    let data = reduxStore.getState().db.cards[event._id]\r\n                    let statusColor = reduxStore.getState().db.status.filter(x => x.value === reduxStore.getState().db.cards[event._id].status)[0].color\r\n                    let backgroundColor = statusColor\r\n\r\n\r\n                    let ini = moment(new Date(start)).unix('x')\r\n                    let fin = moment(new Date(end)).unix('x')\r\n\r\n                    if (moment(new Date(end)).unix('x') < moment().unix('x')\r\n                    ) backgroundColor = \"#ff0000\"\r\n\r\n                    let percent = (((fin - ini) / 60) / (24 * 60) * 100)\r\n\r\n                    if (percent > 100)\r\n                      percent = 100\r\n\r\n                    let newStyle = {\r\n                      height: `${percent}%`,\r\n                      ...view === 'week' || view === \"day\" ? {\r\n                        minHeight: `${percent}%`\r\n                      } : {\r\n                        minHeight: 22,\r\n                      },\r\n                      width: \"100%\",\r\n                      border: \"solid 1px rgba(0,0,0,0.1)\",\r\n                      borderRadius: 3,\r\n                      // paddingRight: 7,\r\n                      boxShadow: \"0px 1x 2px 0px rgba(0,0,0,0.3)\",\r\n                      backgroundColor:\r\n                        !isSelected\r\n                          ? `${hexToRgba(backgroundColor, 0.5)}`\r\n                          : `${hexToRgba(backgroundColor, 0.3)}`,\r\n                      ...data.priority && db.priority.filter(a => String(a.value) === String(data.priority)).length > 0 ? {\r\n                        borderLeft: `solid 5px ${db.priority.filter(a => String(a.value) === String(data.priority))[0].color}`\r\n                      } : {}\r\n                    };\r\n\r\n                    return {\r\n                      className: \"\",\r\n                      style: newStyle\r\n                    };\r\n                  }\r\n                }\r\n                components={{\r\n                  event: ({ event }) => {\r\n                    let ini = moment(event.startDate).unix('x')\r\n                    let fin = moment(event.endDate).unix('x')\r\n                    let data = reduxStore.getState().db.cards[event._id]\r\n                    let statusColor = reduxStore.getState().db.status.filter(x => x.value === data.status)[0].color\r\n                    let backgroundColor = statusColor\r\n\r\n                    if (\r\n                      moment(event.endDate).format(\"YYYY-MM\") === moment().format(\"YYYY-MM\")\r\n                      && moment(event.endDate).format(\"DD\") < moment().format(\"DD\")\r\n                    ) backgroundColor = \"#ff0000\"\r\n\r\n\r\n                    let diff = fin - ini\r\n                    let icon = data.type && db && db.dataType && db.dataType.filter(a => a.name === data.type)[0] ? db.dataType.filter(a => a.name === data.type)[0].icon : \"$__topic\"\r\n\r\n                    return (\r\n                      <HtmlTooltip\r\n                        leaveDelay={800}\r\n                        title={(\r\n                          <React.Fragment>\r\n                            <div style={{\r\n                              display: \"flex\",\r\n                              alignItems: \"center\",\r\n                              zIndex: 5000,\r\n                            }}\r\n                            // onClick={e => {\r\n                            //   e.stopPropagation()\r\n                            // }}\r\n                            >\r\n                              <ActivityCard data={data}\r\n                                onlyOption\r\n                                notGlobalExpanded\r\n                              />\r\n                              {/* <div\r\n                                onClick={e => {\r\n                                  e.stopPropagation()\r\n                                }}\r\n                              >\r\n                                <CustomButton\r\n                                  title={data.status !== \"completed\" ? translate(\"$__conclude\", 1) : translate(\"$__undoConclude\", 1)}\r\n                                  color={data.status !== \"completed\" ? \"lightgrey\" : \"grey\"}\r\n                                  icon={data.status !== \"completed\" ? \"radio_button_unchecked\" : \"check_circle\"}\r\n                                  onClick={() => {\r\n                                    setCompleted(props, data)\r\n                                  }}\r\n                                  transparent\r\n                                />\r\n                              </div> */}\r\n                            </div>\r\n                          </React.Fragment>\r\n                        )\r\n                        }>\r\n                        <div style={{\r\n                          display: \"flex\",\r\n                          alignItems: \"center\",\r\n                          fontSize: 10,\r\n                          height: \"100%\",\r\n                          maxWidth: \"100%\",\r\n                          textOverflow: \"ellipsis\",\r\n                          overflow: \"hidden\"\r\n                        }}>\r\n                          <div style={{ marginRight: 5 }}>\r\n                            <Badge\r\n                              overlap=\"rectangular\"\r\n                              size={'12px'}\r\n                              icon={icon}\r\n                              color={\"bkack\"}\r\n                              title={translate(`$__${data.type}`)}\r\n                            />\r\n                          </div>{event.title}\r\n\r\n                        </div>\r\n\r\n                      </HtmlTooltip>\r\n                    )\r\n                  },\r\n                  toolbar: CustomToolbar,\r\n                  month: {\r\n                    dateHeader: ({ date, label }) => {\r\n                      return <div style={{ color: customApp(\"menu\"), cursor: \"pointer\" }}>{label}</div>\r\n                    },\r\n                  },\r\n                  week: {\r\n                    dateHeader: ({ date, label }) => {\r\n                      return <div style={{ color: customApp(\"menu\"), cursor: \"pointer\" }}>{label}</div>\r\n                    },\r\n                  }\r\n                }}\r\n                onNavigate={(dt, view, action) => {\r\n                  if (!selectedDate || moment(dt).format(\"YYYY-MM\") !== moment(selectedDate).format(\"YYYY-MM\"))\r\n                    setSelectedDate(dt)\r\n                  if (action !== \"NEXT\" && action !== \"PREV\" && action !== \"TODAY\" && action !== \"DATE\")\r\n                    setView(action)\r\n\r\n                }}\r\n                view={view}\r\n                onEventResize={(d) => {\r\n                  updateCardData(\r\n                    {\r\n                      ...props,\r\n                      data: { _id: d.event._id }\r\n                    }, {\r\n                    startDate: moment(d.start).unix('x'),\r\n                    endDate: moment(d.end).unix('x')\r\n                  })\r\n                }}\r\n                onEventDrop={(d) => {\r\n                  updateCardData(\r\n                    {\r\n                      ...props,\r\n                      data: { _id: d.event._id }\r\n                    }, {\r\n                    startDate: moment(d.start).unix('x'),\r\n                    endDate: moment(d.end).unix('x')\r\n                  })\r\n                }}\r\n                showMultiDayTimes\r\n                showAllEvents={showAllEvents}\r\n                popup\r\n                resizable={true}\r\n                defaultView={\"week\"}\r\n              />\r\n            </CardBody>\r\n          </Card>\r\n          <div\r\n            style={{\r\n              height: 300,\r\n              width: \"100%\"\r\n            }}\r\n          ></div>\r\n        </GridItem>\r\n      </GridContainer>\r\n    </div >\r\n  );\r\n}\r\n\r\n//EXPORT\r\nconst mapStateToProps = (store) => {\r\n  return {\r\n    search: store.search,\r\n    cards: store.db.cards\r\n  }\r\n}\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n  bindActionCreators(reduxActions, dispatch)\r\n\r\n//EXPORT\r\nexport default connect(mapStateToProps, mapDispatchToProps)(CalendarComponent)\r\n","\r\nconst dashboardStyle = {\r\n    widgetsContent: {\r\n        backgroundColor: '#FFFFFF',\r\n        // boxShadow: \"0 3px 3px 3px rgba(0,0,0,0.05)\",\r\n        // padding: '7px',\r\n        height: 'calc(100vh - 200px)',\r\n        maxHeight: 'calc(100vh - 350px)',\r\n        position: 'relative',\r\n        overflowX: 'auto'\r\n    }\r\n};\r\n\r\nexport default dashboardStyle;\r\n\r\n","// ID_CREATED*************************\n\nimport React from \"react\"\n\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Button from \"@material-ui/core/Button\"\nimport CustomButton from \"components/Buttons/custom\"\nimport NewCard from \"components/Card/new\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport Icon from \"components/Icon\"\nimport Checklist from \"components/Checklist\"\nimport QuickCardAdd from \"components/Quick/card\"\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/dashboard\"\n\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n    nl2br\n} from \"functions/\"\n\n//ICONS\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\n//VARIABLES\nfunction Dashboard(props) {\n    const { db, session } = reduxStore.getState()\n    const [channelAdd, setChannelAdd] = React.useState(null)\n    const [showCards, setShowCards] = React.useState(false)\n\n    let showIn = Object.keys(db.cards).filter(c =>\n        db.cards[c].type === \"step\"\n        && db.cards[c].showInPanel\n    ).sort((a, b) => {\n        let paramA = db.cards[a].name.toLowerCase().trim(), paramB = db.cards[b].name.toLowerCase().trim()\n\n        if (paramA < paramB)\n            return -1\n        if (paramA > paramB)\n            return 1\n        return 0\n    }\n    ).map(c => db.cards[c])\n\n\n    if (showIn.length === 0)\n        return (<React.Fragment></React.Fragment>)\n\n    return (\n        <div style={{ width: \"100%\", position: \"relative\", float: \"left\", clear: \"both\" }}>\n            {showIn && showIn.length > 0 ?\n                <GridContainer\n                    style={{ paddingLeft: 15, paddingRight: 15, boxShadow: \"0 5px 7px 1px rgba(0,0,0,0.03)\", backgroundColor: \"rgba(250,250,250,0.07)\", paddingBottom: 33 }}\n                >\n                    <div\n                        style={{\n                            position: \"relative\",\n                            float: \"left\",\n                            width: \"100%\",\n                            color: customApp(\"menu\"),\n                            fontWeight: \"bold\",\n                            fontSize: \"16px\",\n                            marginTop: \"16px\",\n                            display: \"flex\",\n                            alignItems: \"center\",\n                            // justifyContent: \"space-between\"\n                        }}\n                    >\n                        {translate(\"$__myChannels\")}\n                        <div style={{\n                            padding: 3,\n                            backgroundColor: \"rgba(250,250,250,1)\",\n                            marginLeft: 15\n                        }}\n                            onClick={() => {\n                                setShowCards(prev => !prev)\n                            }}\n                        >\n                            {!showCards ? `Ver minhas solicitações` : `Fazer nova solicitação`}\n                        </div>\n                    </div>\n                    {showCards ?\n                        <GridItem\n                            xs={12}\n                            sm={6}\n                            md={6}\n                            style={{ paddingTop: 33, padding: 7 }}\n                        >\n                            <fieldset style={{ backgroundColor: \"#FFFFFF\", borderRadius: 7, marginTop: 15 }}>\n                                <legend>{translate(\"$__legends\")}</legend>\n                                <div style={{ alignItems: \"center\", display: \"flex\", justifyContent: \"space-between\" }}>\n                                    <div style={{ alignItems: \"center\", display: \"flex\" }}>\n                                        <div style={{\n                                            height: 10,\n                                            width: 30,\n                                            backgroundColor: \"#02b915\",\n                                            borderRadius: 7,\n                                            marginRight: 7\n                                        }}></div>\n                                        <div>{translate(\"$__completedStep\")}</div>\n                                    </div>\n                                    <div style={{ alignItems: \"center\", display: \"flex\" }}>\n                                        <div style={{\n                                            height: 10,\n                                            width: 30,\n                                            backgroundColor: \"#00a2e9\",\n                                            borderRadius: 7,\n                                            marginRight: 7\n                                        }}></div>\n                                        <div>{translate(\"$__actualStep\")}</div>\n                                    </div>\n                                    <div style={{ alignItems: \"center\", display: \"flex\" }}>\n                                        <div style={{\n                                            height: 10,\n                                            width: 30,\n                                            backgroundColor: \"#e9e9e9\",\n                                            borderRadius: 7,\n                                            marginRight: 7\n                                        }}></div>\n                                        <div>{translate(\"$__stepNotStarted\")}</div>\n                                    </div>\n                                </div>\n                            </fieldset>\n                            {Object.keys(db.cards).filter(card =>\n                                db.cards[card]?._createdBy?.channel\n                            ).map(card => <NewCard db=\"cards\" key={card} data={db.cards[card]} noShadow />)}\n                        </GridItem>\n                        : <React.Fragment></React.Fragment>}\n                    {!showCards && showIn.map(sol => {\n                        return (\n                            <GridItem\n                                xs={12}\n                                sm={6}\n                                md={4}\n                                lg={3}\n                                xl={2}\n                                key={sol._id}\n                                style={{ marginTop: \"33px\", cursor: \"pointer\", padding: 5 }}\n                                onClick={() => {\n                                    setChannelAdd(sol._id)\n                                }}\n                            >\n                                <div style={{\n                                    backgroundColor: \"#FFFFFF\",\n                                    borderRadius: 7\n                                }}>\n                                    <div style={{\n                                        padding: 3,\n                                        color: customApp(\"menu\"),\n                                        fontWeight: \"bold\",\n                                        fontSize: 14\n                                    }}>\n                                        {sol.shortCutTitle}\n                                    </div>\n                                    <div\n                                        style={{\n                                            padding: 3,\n                                            color: customApp(\"menu\"),\n                                            // fontWeight:\"bold\",\n                                            fontSize: 12\n                                        }}\n                                    >\n                                        {sol.shortCutDescription}\n                                    </div>\n                                    <div\n                                        style={{\n                                            padding: 3,\n                                            color: customApp(\"menu\"),\n                                            fontWeight: \"bold\",\n                                            fontSize: 16\n                                        }}\n\n                                    >\n                                        {sol.shortCutButtonToAdd}\n                                    </div>\n                                </div>\n                            </GridItem>\n                        )\n                    })}\n                    {channelAdd ?\n                        <QuickCardAdd\n                            nodeId={channelAdd}\n                            onCancel={() => setChannelAdd(null)}\n                            onSave={() => setChannelAdd(null)}\n                            placeHolder={showIn.filter(a => a._id === channelAdd)[0].shortCutButtonToAdd || null}\n                            explain={showIn.filter(a => a._id === channelAdd)[0].shortCutDescription || null}\n                            backgroundColor={\"rgba(250,250,250,1)\"}\n                            initialData={{\n                                channel: true\n                            }}\n                        />\n                        : <React.Fragment></React.Fragment>\n                    }\n                </GridContainer>\n                : <React.Fragment></React.Fragment>}\n        </div >\n    )\n}\n\nconst mapStateToProps = (store) => {\n    return {\n        store: {\n            cards: store.db.cards,\n        },\n        hidePrivate: store.controls.hidePrivate,\n    }\n}\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Dashboard))","// ID_CREATED*************************\n\nimport React from \"react\"\nimport moment from \"moment-timezone\"\nimport { useCookies, setCookie } from 'react-cookie'\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport Button from \"@material-ui/core/Button\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Card from \"components/Card\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport Icon from \"components/Icon\"\nimport Checklist from \"components/Checklist\"\nimport QuickCardAdd from \"components/Quick/card\"\n\n//DEPENDENCIES\nimport ShowIn from \"./myChannels\"\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/dashboard\"\n\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n    nl2br\n} from \"functions/\"\n\n//ICONS\nimport MockupApp from \"assets/img/dashboard/Mockup_App_WEB.png\"\nimport MockupSupport from \"assets/img/dashboard/supportMockup.png\"\n\nimport { setMyDay } from \"functions/cards\"\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\n//VARIABLES\nfunction Dashboard(props) {\n    const { db, session } = reduxStore.getState()\n    const { dataType, users } = db\n    const [viewSuggestions, setViewSuggestions] = React.useState(false)\n    const [nextTasksOrderBy, setNextTasksOrderBy] = React.useState(\"EndDate\")\n    const [cookies, setCookie] = useCookies(['banner']);\n    const [channelAdd, setChannelAdd] = React.useState(false)\n    // const [mounted, setMounted] = React.useState(false)\n\n    let myCards = []\n\n    const hideSupportAndAppBanner = async () => {\n        const { socket } = reduxStore.getState().functions\n\n        setCookie('banner', true, { path: '/' });\n        try {\n            socket.emit(\"data\", {\n                module: \"user\",\n                method: \"post\",\n                action: \"preffers\"\n            }, {\n                hideSupportAndAppBanner: true\n            }, data => {\n                if (data.error)\n                    console.log(\"hideSupportAndAppBanner\", data.error)\n            })\n        } catch (e) {\n            console.log(e)\n        }\n    }\n\n    myCards = Object.keys(reduxStore.getState().db.cards).filter(a =>\n        reduxStore.getState().db.cards[a]\n        && !reduxStore.getState().db.cards[a].checklist\n        && dataType.filter(dt => dt.name === reduxStore.getState().db.cards[a].type).length > 0\n        // && dataType.filter(dt => dt.name === reduxStore.getState().db.cards[a].type)[0].myTasks\n        && (\n            !props.hidePrivate\n            || (\n                props.hidePrivate\n                && !reduxStore.getState().db.cards[a].private\n            )\n        )\n    ).map(c => reduxStore.getState().db.cards[c])\n\n    const today = moment().format(\"YYYY-MM-DD\")\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    let subtractDays = String(session.dashboard.period).replace(\"$__last\", \"\")\n    subtractDays = subtractDays.replace(\"Days\", \"\")\n\n    let myDayTasksSuggestionsContent = myCards.filter(a => {\n        if (\n            a._users\n            && !a.deleted\n            && !a.checklist\n            && a._users[session._id]\n            && a.status !== \"completed\"\n            &&\n            (\n                (\n                    a._users[session._id].myDay\n                    && moment(new Date(a._users[session._id].myDay * 1000)).tz(\"America/Sao_Paulo\").unix('x') > moment().subtract(15, \"days\").unix('x')\n                    && moment(new Date(a._users[session._id].myDay * 1000)).tz(\"America/Sao_Paulo\").unix('x') < moment(new Date(today)).unix('x')\n                )\n                ||\n                (\n                    a._users[session._id].isResponsible\n                    && (\n                        (a.endDate\n                            && moment(new Date(a.endDate * 1000)).tz(\"America/Sao_Paulo\").unix('x') < moment().unix('x')\n                        )\n                        ||\n                        (a.startDate\n                            && moment(new Date(a.startDate * 1000)).tz(\"America/Sao_Paulo\").unix('x') > moment(new Date(today)).subtract(15, \"days\").unix('x')\n                        )\n                    )\n                    && (\n                        a._users[session._id]\n                        && !a._users[session._id].myDay\n                        || (\n                            a._users[session._id].myDay\n                            && moment(new Date(a._users[session._id].myDay * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") !== today\n                            && moment(new Date(a._users[session._id].myDay * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") > moment(new Date()).tz(\"America/Sao_Paulo\").subtract(30, \"d\").format(\"YYYY-MM-DD\")\n                        )\n                    )\n                )\n            )\n            && (\n                !props.hidePrivate\n                || (\n                    props.hidePrivate\n                    && !a.private\n                )\n            )\n        ) return true\n    }\n    ).sort((a, b) => {\n        if (reduxStore.getState().db.orderByTitle\n            && reduxStore.getState().db.orderByTitlePosition === \"ASC\"\n            && a && a.name && b && b.name && a.name.toLowerCase().trim() < b.name.toLowerCase().trim()\n        ) {\n            return -1\n        } else if (reduxStore.getState().db.orderByTitle\n            && reduxStore.getState().db.orderByTitlePosition === \"DESC\"\n            && a && a.name && b && b.name && a.name.toLowerCase().trim() > b.name.toLowerCase().trim()\n        ) {\n            return -1\n        } else if (reduxStore.getState().db.orderByTitle) {\n            return 0\n        } else if (!reduxStore.getState().db.orderByTitle && String(a.order) && String(b.order) && String(a.order?.low || 0) && String(b.order?.low || 0) && parseInt(a.order?.low || 0) < parseInt(b.order?.low || 0)) {\n            return -1\n        } else {\n            return 1\n        }\n    }\n    ).map((a, i) =>\n        <div style={{ width: \"calc(100%)\", display: \"flex\", alignItems: \"center\", justifyContent: \"center\" }} key={a._id}>\n            <Card db=\"cards\" data={a} noShadow />\n            <Button\n                onClick={() => {\n                    setMyDay(props, {\n                        _id: a._id,\n                        userId: session._id,\n                        option: true\n                    })\n                }}\n            >\n                <Icon\n                    icon=\"add\"\n                    color={customApp(\"menu\")}\n                    title={translate(\"$__addOnMyDay\")}\n                />\n            </Button>\n        </div>\n    )\n\n    let nextDaysContent = myCards.filter(a =>\n        a.status !== \"completed\"\n        && a.name\n        && !a.deleted\n        && !a.archived\n        && a._users\n        && a._users[session._id]\n        &&\n        (\n            !a._users[session._id].myDay\n            ||\n            (\n                a._users[session._id].myDay\n                && moment(new Date(a._users[session._id].myDay * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") !== today\n            )\n        )\n        &&\n        (\n            (a.endDate\n                && moment(new Date(a.endDate * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") >= moment().format(\"YYYY-MM-DD\")\n                && moment(new Date(a.endDate * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") <= moment(new Date(today)).add(10, \"days\").format(\"YYYY-MM-DD\")\n            )\n            ||\n            (a.startDate\n                && moment(new Date(a.startDate * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") >= moment().format(\"YYYY-MM-DD\")\n                && moment(new Date(a.startDate * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") <= moment(new Date(today)).add(10, \"days\").format(\"YYYY-MM-DD\")\n            )\n        )\n    ).sort((a, b) => {\n        let paramA = a.name.toLowerCase().trim(), paramB = b.name.toLowerCase().trim()\n        if (nextTasksOrderBy === 'IniDate') {\n            paramA = parseInt(a.startDate)\n            paramB = parseInt(b.startDate)\n        }\n        if (nextTasksOrderBy === 'EndDate') {\n            paramA = parseInt(a.endDate)\n            paramB = parseInt(b.endDate)\n        }\n\n        if (paramA < paramB)\n            return -1\n        if (paramA > paramB)\n            return 1\n        return 0\n    }\n    ).map((a, i) => <Card db=\"cards\" key={a._id} data={a} noShadow />)\n\n    const user = users && Object.keys(users).length > 0 ? users[Object.keys(users).find(a => session && session._id && users[a] && users[a]._id && users[a]._id.indexOf(session._id) > -1)] : {}\n\n    const now = new Date\n    const timeMessage =\n        (now.getHours() >= 0 && now.getHours() < 5)\n            ? \"$__goodNight\"\n            : (now.getHours() >= 5 && now.getHours() < 12)\n                ? \"$__goodMorning\"\n                : (now.getHours() >= 12 && now.getHours() < 18)\n                    ? \"$__goodAfternoon\"\n                    : \"$__goodNight\"\n\n    let FavoritePlans = Object.keys(db.cards)\n        .filter(fil =>\n            db.cards[fil]\n            && !db.cards[fil].deleted\n            && !db.cards[fil].archived\n            && db.cards[fil].type === \"plan\"\n            && db.cards[fil]._users\n            && db.cards[fil]._users[session._id]\n            && db.cards[fil].status !== \"completed\"\n            && db.cards[fil]._isFavorite\n            && (\n                !props.hidePrivate\n                || (\n                    props.hidePrivate\n                    && !db.cards[fil].private\n                )\n            )\n        )\n    return (\n        <div style={{ width: \"100%\" }}>\n            <GridContainer\n            >\n                {!cookies.banner && !session.hideSupportAndAppBanner ?\n                    <React.Fragment>\n                        <GridItem\n                            xs={12}\n                            sm={12}\n                            md={6}\n                            lg={6}\n                            xl={6}\n                        >\n                            <div\n                                style={{\n                                    display: \"flex\",\n                                    justifyContent: \"center\",\n                                    flexDirection: \"column\",\n                                    alignItems: \"center\",\n                                    marginBottom: \"33px\"\n                                }}\n                                id={'view_dashboard_welcomeMessage'}\n                            >\n                                <div style={{\n                                    fontSize: \"16px\",\n                                    padding: \"15px 0\",\n                                    fontWeight: \"bold\",\n                                    width: \"100%\",\n                                    textAlign: \"left\",\n                                    color: customApp(\"menu\"),\n                                    paddingLeft: \"15px\"\n                                }}>\n                                    {translate(timeMessage, 1)}, {user && user.displayName ? user.displayName : user.name ? user.name : \"\"}!\n                                </div>\n                                <GridContainer\n                                    style={{ width: \"100%\" }}\n                                >\n\n                                    <GridItem\n                                        xs={12}\n                                        sm={12}\n                                        md={6}\n                                        lg={6}\n                                        xl={6}\n                                    >\n                                        <img src={MockupSupport} width={800} height={610} style={{ width: \"100%\", height: \"auto\", borderRadius: 17, boxShadow: \"0 0 7px 1px rgba(0,0,0,0.1)\" }} />\n                                    </GridItem>\n                                    <GridItem\n                                        xs={12}\n                                        sm={12}\n                                        md={6}\n                                        lg={6}\n                                        xl={6}\n                                    >\n                                        <div style={{ position: \"relative\", paddingBottom: 33, height: \"100%\" }}>\n                                            <div style={{\n                                                fontSize: \"16px\",\n                                                color: customApp(\"medium\"),\n                                                paddingRight: 15\n                                            }} dangerouslySetInnerHTML={{\n                                                __html: nl2br(translate(\"$__supportWelcomeMessage\", 1))\n                                            }}\n                                            />\n                                            <div style={{ position: \"absolute\", bottom: 0, left: 0 }}>\n                                                <CustomButton\n                                                    title={translate(`$__clickToaccessSupportPage`, '*')}\n                                                    text={translate(\"$__clickToaccessSupportPage\")}\n                                                    color={customApp('menu')}\n                                                    icon={'help_outline'}\n                                                    // transparent\n                                                    onClick={() => {\n                                                        window.open(\"https://support.machen.ai/\", \"_blank\")\n                                                    }}\n                                                    size={'17px'}\n                                                />\n                                            </div>\n\n                                        </div>\n                                    </GridItem>\n\n                                </GridContainer>\n                            </div>\n                        </GridItem>\n                        <GridItem\n                            xs={12}\n                            sm={12}\n                            md={6}\n                            lg={6}\n                            xl={6}\n                        >\n                            <div\n                                style={{ position: \"relative\" }}\n                            >\n                                <img src={MockupApp} width={800} height={640} style={{ width: \"100%\", height: \"auto\" }} />\n                                <div style={{\n                                    position: \"absolute\",\n                                    bottom: -33,\n                                    right: 15\n                                }}>\n                                    <CustomButton\n                                        title={translate(`$__hideSupportAndAppBanner`, '*')}\n                                        text={translate(\"$__hideSupportAndAppBanner\")}\n                                        color={customApp('menu')}\n                                        icon={'close'}\n                                        // transparent\n                                        onClick={() => {\n                                            hideSupportAndAppBanner()\n\n                                        }}\n                                        size={'12px'}\n                                    />\n                                </div>\n                            </div>\n                        </GridItem>\n                    </React.Fragment>\n                    : <React.Fragment></React.Fragment>\n                }\n\n            </GridContainer>\n\n            {FavoritePlans.length > 0 ?\n                <GridContainer\n                    style={{ marginTop: \"33px\", marginBottom: \"33px\", }}\n                >\n                    <GridItem\n                        xs={12}\n                        sm={12}\n                        md={12}\n                        lg={12}\n                        xl={12}\n                        id={\"view_dashboard_favorites\"}\n                        style={{ boxShadow: \"0 5px 7px 1px rgba(0,0,0,0.03)\", backgroundColor: \"rgba(250,250,250,0.07)\", paddingBottom: 33 }}\n                    >\n                        <div\n                            style={{\n                                position: \"relative\",\n                                float: \"left\",\n                                width: \"100%\",\n                                // padding: \"0 16px\",\n                                // paddingBottom: 33,\n                                marginBottom: 33\n                            }}\n                        >\n                            <div\n                                style={{\n                                    position: \"relative\",\n                                    float: \"left\",\n                                    width: \"100%\",\n                                    color: customApp(\"menu\"),\n                                    fontWeight: \"bold\",\n                                    fontSize: \"16px\",\n                                    marginTop: \"16px\",\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                    justifyContent: \"space-between\"\n                                }}\n                            >\n                                {translate(\"$__favoritePlans\")}{FavoritePlans.length > 3 ?\n                                    <CustomButton\n                                        title={`${translate(`$__viewAllFavorites`, '*')} (${FavoritePlans.length})`}\n                                        text={`${translate(`$__viewAllFavorites`, '*')} (${FavoritePlans.length})`}\n                                        color={customApp('menu')}\n                                        icon={'favorite'}\n                                        transparent\n                                        onClick={() => {\n                                            history.push(`sp#tab/home`)\n                                        }}\n                                        size={'25px'}\n                                    />\n                                    : <React.Fragment></React.Fragment>}\n                            </div>\n\n                            <GridContainer\n                                style={{\n                                    flexDirection: \"row\",\n                                    overflowY: \"auto\",\n                                    flexWrap: \"nowrap\",\n                                    display: \"-webkit-inline-box\"\n                                }}\n                            >\n                                {FavoritePlans\n                                    .sort((a, b) => {\n                                        let updA = db.cards[a].updated_at && db.cards[a].updated_at.low ? db.cards[a].updated_at.low : 0\n                                        let updB = db.cards[b].updated_at && db.cards[b].updated_at.low ? db.cards[b].updated_at.low : 0\n                                        if (updA > updB)\n                                            return -1\n                                        if (updA < updB)\n                                            return 1\n                                        return 0\n                                    })\n                                    .map((a, i) => {\n                                        if (i < 6)\n                                            return (\n                                                <GridItem\n                                                    xs={12}\n                                                    sm={6}\n                                                    md={4}\n                                                    lg={3}\n                                                    xl={2}\n                                                    key={db.cards[a]._id}\n                                                    style={{ marginTop: \"33px\", cursor: \"pointer\" }}\n                                                    onClick={() => {\n                                                        history.push(`sp#${db.cards[a]._id}/dashboard`)\n                                                    }}\n                                                >\n                                                    <Card data={db.cards[a]}\n                                                        expanded\n                                                        Avatar\n                                                        ignoreList\n                                                    />\n                                                </GridItem>\n                                            )\n                                    })}\n                            </GridContainer>\n                        </div>\n                        <div style={{ clear: \"both\" }}></div>\n                    </GridItem>\n                </GridContainer>\n                : <React.Fragment></React.Fragment>\n            }\n            <ErrorBoundary>\n                <ShowIn />\n            </ErrorBoundary>\n            <GridContainer style={{\n                paddingBottom: 33,\n                marginTop: 33\n            }}>\n                <GridItem\n                    xs={12}\n                    sm={12}\n                    md={6}\n                    lg={6}\n                    xl={6}\n                    style={{\n                        borderRight: `2px solid ${customApp(\"menu\")}`\n                    }}\n                    id={'view_dashboard_myDay'}\n                >\n                    <div\n                        style={{\n                            position: \"relative\",\n                            float: \"left\",\n                            width: \"100%\",\n                            padding: \"0 16px\",\n\n                        }}\n                    >\n                        {!viewSuggestions ?\n                            <React.Fragment>\n                                <div\n                                    style={{\n                                        position: \"relative\",\n                                        float: \"left\",\n                                        width: \"100%\",\n                                        color: customApp(\"menu\"),\n                                        fontWeight: \"bold\",\n                                        fontSize: \"16px\",\n                                        marginBottom: \"16px\",\n                                    }}\n                                >\n                                    {translate(\"$__myDay\")}\n                                    {myDayTasksSuggestionsContent.length > 0 &&\n                                        <div style={{\n                                            color: customApp(\"menu\"),\n                                            fontSize: \"16px\",\n                                            marginTop: \"7px\",\n                                            cursor: \"pointer\",\n                                            textAlign: \"left\",\n                                            padding: \"7px\",\n                                            color: \"#f50057\",\n                                            display: \"flex\",\n                                            alignItems: \"center\"\n                                        }}\n                                            onClick={() => {\n                                                setViewSuggestions(true)\n                                            }}\n                                            id={'view_dashboard_myDaySuggestionsOptions'}\n                                        >\n\n                                            <Icon icon={\"info\"} color={customApp(\"medium\")} style={{ marginRight: \"15px\" }} />\n                                            {translate(\"$__clickHereToCheckTaskSuggestions\")}\n                                        </div>\n                                    }\n                                </div>\n                                {/* <div style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    maxHeight: \"300px\",\n                                    paddingBottom: 15\n                                }}> */}\n                                <Checklist\n                                    noChecklist\n                                    noDelete\n                                    showCard\n                                    myDay\n                                    db={\"cards\"}\n                                />\n                                {/* <div style={{ clear: \"both\" }}></div> */}\n                                {/* </div> */}\n\n                            </React.Fragment>\n                            :\n                            <React.Fragment>\n                                <div\n                                    style={{\n                                        position: \"relative\",\n                                        float: \"left\",\n                                        width: \"100%\",\n                                        color: customApp(\"menu\"),\n                                        fontWeight: \"bold\",\n                                        fontSize: \"16px\",\n                                        marginBottom: \"16px\",\n                                        display: \"flex\",\n                                        alignItems: \"center\"\n                                    }}\n                                >\n                                    <Button\n                                        onClick={() => {\n                                            setViewSuggestions(false)\n                                        }}\n                                    >\n                                        <Icon\n                                            icon=\"undo\"\n                                            color={customApp(\"menu\")}\n                                            title={translate(\"$__backToMyDay\")}\n                                        />\n                                    </Button>\n                                    {translate(\"$__taskSuggestions\")}\n                                </div>\n                                <div\n                                    style={{\n                                        position: \"relative\",\n                                        float: \"left\",\n                                        width: \"100%\",\n                                        color: customApp(\"medium\"),\n                                        fontWeight: \"bold\",\n                                        fontSize: \"12px\",\n                                        marginBottom: \"16px\",\n                                        display: \"flex\",\n                                        alignItems: \"center\"\n                                    }}\n                                    id={\"view_dashboardSuggestionsAddButton\"}\n                                >\n                                    {/* {translate(\"$__clickIn+ToAddInMyDay\")} */}\n                                    Clique no + para adicionar as tarefas ao seu dia.\n                                </div>\n                                <div>\n                                    {myDayTasksSuggestionsContent}\n                                </div>\n                            </React.Fragment>\n                        }\n                    </div>\n                </GridItem>\n                <GridItem\n                    xs={12}\n                    sm={12}\n                    md={6}\n                    lg={6}\n                    xl={6}\n                    style={{\n                        borderRight: `2px solid ${customApp(\"menu\")}`,\n                    }}\n                    id={\"view_dashboard_nextTasks\"}\n                >\n                    <div\n                        style={{\n                            position: \"relative\",\n                            float: \"left\",\n                            width: \"100%\",\n                            padding: \"0 16px\",\n                        }}\n                    >\n                        <div\n                            style={{\n                                position: \"relative\",\n                                float: \"left\",\n                                width: \"100%\",\n                                display: \"flex\",\n                                justifyContent: \"space-between\"\n                            }}\n                        >\n                            <div\n                                style={{\n                                    color: customApp(\"menu\"),\n                                    fontWeight: \"bold\",\n                                    fontSize: \"16px\",\n                                    marginBottom: \"16px\"\n                                }}\n                            >\n                                {translate(\"$__nextTasks\")}\n                            </div>\n                            <div>\n                                <CustomButton\n                                    title={translate(`$__orderBy${nextTasksOrderBy}`)}\n                                    color={'lightgray'}\n                                    // load={loadingDeleted}\n                                    icon={nextTasksOrderBy === 'IniDate' ? \"today\" : nextTasksOrderBy === 'EndDate' ? \"event\" : \"text_rotate_vertical\"}\n                                    onClick={() => {\n                                        if (nextTasksOrderBy === 'IniDate')\n                                            setNextTasksOrderBy(\"EndDate\")\n                                        if (nextTasksOrderBy === 'EndDate')\n                                            setNextTasksOrderBy(\"name\")\n                                        if (nextTasksOrderBy === 'name')\n                                            setNextTasksOrderBy(\"IniDate\")\n                                    }}\n                                    size={'21px'}\n                                    style={{ padding: \"0px !important\" }}\n                                />\n                            </div>\n                        </div>\n                        <div>\n                            {nextDaysContent}\n                        </div>\n                    </div>\n                </GridItem>\n            </GridContainer>\n        </div >\n    )\n}\n\nconst mapStateToProps = (store) => {\n    return {\n        store: {\n            cards: store.db.cards,\n        },\n        hidePrivate: store.controls.hidePrivate,\n    }\n}\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Dashboard))","// ID_CREATED*************************\n\nimport React from \"react\"\nimport { Carousel } from 'react-responsive-carousel';\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport HeaderWithMenu from \"components/Header/card\"\nimport CustomButton from \"components/Buttons/custom\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport Insights from \"views/BrightAndConnected/InsightBoards\"\nimport ListLinks from \"components/BrightAndConnected/listLinks\"\nimport Radar from \"views/BrightAndConnected/Radar\"\nimport UiCard from \"components/Card/Card\"\nimport UiCardBody from \"components/Card/CardBody\"\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//DEPENDENCIES\nimport ResumeTasks from \"./resumeTasks\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/dashboard\"\nimport \"react-responsive-carousel/lib/styles/carousel.min.css\"; // requires a loader\n\n//ICONS\nimport Ideas from \"assets/icons/Ideas\"\n\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n} from \"functions/\"\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\n//VARIABLES\nfunction DashboardResume(props) {\n    const { session } = reduxStore.getState()\n    React.useEffect(() => {\n        return () => {\n        }\n    }, [])\n\n\n    let countProfile = 0\n\n    if (session && session.GlobalData) {\n        if (session.GlobalData.message)\n            countProfile = countProfile + 1\n        if (session.GlobalData.history)\n            countProfile = countProfile + 1\n        if (session.GlobalData.vocation)\n            countProfile = countProfile + 1\n        if (session.GlobalData.legacy)\n            countProfile = countProfile + 1\n    }\n\n    let xs = 12 / countProfile\n\n    return (\n        <div style={{ width: \"100%\" }}>\n            {countProfile ?\n                <Carousel\n                    utoPlay={true}\n                    showArrows={true}\n                    stopOnHover={true}\n                    transitionTime={1}\n                    showStatus={false}\n                >\n                    {session.GlobalData.strategicStatement ?\n                        <div style={{\n                            height: \"calc(100% - 33px)\"\n                        }}\n                        >\n                            <UiCard\n                                style={{\n                                    height: \"calc(100% - 33px)\"\n                                }}\n                            >\n                                <HeaderWithMenu\n                                    title={translate(`$__strategicStatement`, 1)}\n                                    icon={'history_edu'}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <UiCardBody style={{\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                }}>\n                                    <div dangerouslySetInnerHTML={{ __html: session.GlobalData.strategicStatement }} />\n                                </UiCardBody>\n                            </UiCard>\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.message ?\n                        <div style={{\n                            height: \"calc(100% - 33px)\"\n                        }}\n                        >\n                            <UiCard\n                                style={{\n                                    height: \"calc(100% - 33px)\"\n                                }}\n                            >\n                                <HeaderWithMenu\n                                    title={translate(`$__presidentMessage`, 1)}\n                                    icon={'account_box'}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <UiCardBody style={{\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                }}>\n                                    <div dangerouslySetInnerHTML={{ __html: session.GlobalData.message }} />\n                                </UiCardBody>\n                            </UiCard>\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.vocation ?\n                        <div style={{\n                            height: \"calc(100% - 33px)\"\n                        }}\n                        >\n                            <UiCard\n                                style={{\n                                    height: \"calc(100% - 33px)\"\n                                }}\n                            >\n                                <HeaderWithMenu\n                                    title={translate(`$__vocation`, 1)}\n                                    icon={'spoke'}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <UiCardBody style={{\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                }}>\n                                    <div dangerouslySetInnerHTML={{ __html: session.GlobalData.vocation }} />\n                                </UiCardBody>\n                            </UiCard>\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.history ?\n                        <div style={{\n                            height: \"calc(100% - 33px)\"\n                        }}\n                        >\n                            <UiCard\n                                style={{\n                                    height: \"calc(100% - 33px)\"\n                                }}\n                            >\n                                <HeaderWithMenu\n                                    title={translate(`$__history`, 1)}\n                                    icon={'menu_book'}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <UiCardBody style={{\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                }}>\n                                    <div dangerouslySetInnerHTML={{ __html: session.GlobalData.history }} />\n                                </UiCardBody>\n                            </UiCard>\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.values ?\n                        <div style={{\n                            height: \"calc(100% - 33px)\"\n                        }}\n                        >\n                            <UiCard\n                                style={{\n                                    height: \"calc(100% - 33px)\"\n                                }}\n                            >\n                                <HeaderWithMenu\n                                    title={translate(`$__values`, 1)}\n                                    icon={'join_inner'}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <UiCardBody style={{\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                }}>\n                                    <div dangerouslySetInnerHTML={{ __html: session.GlobalData.values }} />\n                                </UiCardBody>\n                            </UiCard>\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.legacy ?\n                        <div style={{\n                            height: \"calc(100% - 33px)\"\n                        }}\n                        >\n                            <UiCard\n                                style={{\n                                    height: \"calc(100% - 33px)\"\n                                }}\n                            >\n                                <HeaderWithMenu\n                                    title={translate(`$__legacy`, 1)}\n                                    icon={'subtitles'}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <UiCardBody\n                                    style={{\n                                        display: \"flex\",\n                                        alignItems: \"center\",\n                                    }}\n                                >\n                                    <div dangerouslySetInnerHTML={{ __html: session.GlobalData.legacy }} />\n                                </UiCardBody>\n                            </UiCard>\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                </Carousel>\n                :\n                <React.Fragment>\n\n                </React.Fragment>\n            }\n            <ErrorBoundary>\n                <ResumeTasks />\n            </ErrorBoundary>\n            <GridContainer\n                style={{\n                    paddingBottom: 33\n                }}\n            >\n                <GridItem\n                    xs={12}\n                    sm={12}\n                    md={12}\n                    lg={12}\n                    xl={12}\n                >\n                    <div style={{\n                        position: \"relative\",\n                        backgroundColor: \"rgba(250,250,250,0.7)\",\n                        boxShadow: \"0px 0px 3px 7px rgba(0,0,0,0.03)\",\n                        marginBottom: 33,\n                        // borderRadius: 7,\n                        overflow: \"hidden\",\n                    }}>\n                        <div style={{\n                            position: \"relative\",\n                            height: 40,\n                            marginBottom: 15\n                        }}>\n                            <div style={{\n                                position: \"absolute\",\n                                top: 0,\n                                left: 0,\n                                right: 0,\n                                height: 40,\n                                background: customApp('ColumnTitleColor'),\n                                display: \"flex\",\n                                alignItems: \"center\",\n                                justifyContent: \"space-between\",\n                                color: customApp('colorText'),\n                                padding: \"0 15px\"\n                            }}>\n                                <div style={{ display: \"flex\" }}>\n                                    {translate(`$__lastNews`, '*')}\n                                </div>\n                                <CustomButton\n                                    title={translate(`$__save`, '*')}\n                                    text={translate(\"$__viewAllNews\")}\n                                    color={'white'}\n                                    icon={'feed'}\n                                    transparent\n                                    onClick={() => {\n                                        history.push(`bright-and-connected#tab/allNews`)\n                                    }}\n                                    size={'25px'}\n                                />\n                            </div>\n                        </div>\n                        <ErrorBoundary>\n                            <ListLinks max={6} horizontal />\n                        </ErrorBoundary>\n                    </div>\n                </GridItem>\n                <GridItem\n                    xs={12}\n                    sm={12}\n                    md={12}\n                    lg={12}\n                    xl={12}\n                >\n                    <div style={{\n                        position: \"relative\",\n                        backgroundColor: \"rgba(250,250,250,0.7)\",\n                        boxShadow: \"0px 0px 3px 7px rgba(0,0,0,0.03)\",\n                        marginBottom: 33,\n                        // borderRadius: 7,\n                        overflow: \"hidden\"\n                    }}>\n                        <div style={{\n                            position: \"relative\",\n                            height: 40,\n                            marginBottom: 15\n                        }}>\n                            <div style={{\n                                position: \"absolute\",\n                                top: 0,\n                                left: 0,\n                                right: 0,\n                                height: 40,\n                                background: customApp('ColumnTitleColor'),\n                                display: \"flex\",\n                                alignItems: \"center\",\n                                justifyContent: \"space-between\",\n                                color: customApp('colorText'),\n                                padding: \"0 15px\"\n                            }}>\n                                <div style={{ display: \"flex\" }}>\n                                    {translate(`$__lastAddRadar`, '*')}\n                                </div>\n                                <CustomButton\n                                    title={translate(`$__save`, '*')}\n                                    text={translate(\"$__viewAllRadar\")}\n                                    color={'white'}\n                                    icon={'settings_input_antenna'}\n                                    transparent\n                                    onClick={() => {\n                                        history.push(`bright-and-connected#tab/radar`)\n                                    }}\n                                    size={'25px'}\n                                />\n                            </div>\n                        </div>\n                        <ErrorBoundary>\n                            <Radar max={6} horizontal noPagination />\n                        </ErrorBoundary>\n                    </div>\n                </GridItem>\n                <GridItem\n                    xs={12}\n                    sm={12}\n                    md={12}\n                    lg={12}\n                    xl={12}\n                >\n                    <div style={{\n                        position: \"relative\",\n                        backgroundColor: \"rgba(250,250,250,0.7)\",\n                        boxShadow: \"0px 0px 3px 7px rgba(0,0,0,0.03)\",\n                        marginBottom: 33,\n                        // borderRadius: 7,\n                        overflow: \"hidden\"\n                    }}>\n                        <div style={{\n                            position: \"relative\",\n                            height: 40,\n                            marginBottom: 15\n                        }}>\n                            <div style={{\n                                position: \"absolute\",\n                                top: 0,\n                                left: 0,\n                                right: 0,\n                                height: 40,\n                                background: customApp('ColumnTitleColor'),\n                                display: \"flex\",\n                                alignItems: \"center\",\n                                justifyContent: \"space-between\",\n                                color: customApp('colorText'),\n                                padding: \"0 15px\"\n                            }}>\n                                <div style={{ display: \"flex\" }}>\n                                    {translate(`$__lastAddInsights`, '*')}\n                                </div>\n                                <CustomButton\n                                    title={translate(`$__save`, '*')}\n                                    text={translate(\"$__viewAllInsights\")}\n                                    color={'white'}\n                                    icon={Ideas}\n                                    transparent\n                                    onClick={() => {\n                                        history.push(`bright-and-connected#tab/insight-boards`)\n                                    }}\n                                    size={'25px'}\n                                />\n                            </div>\n                        </div>\n                        <ErrorBoundary>\n                            <Insights max={6} horizontal noPagination />\n                        </ErrorBoundary>\n                    </div>\n                </GridItem>\n\n            </GridContainer>\n        </div >\n    )\n}\n\nconst mapStateToProps = () => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(DashboardResume))","import React from \"react\";\r\nimport moment from \"moment-timezone\";\r\nimport { ResponsivePie } from '@nivo/pie';\r\n\r\n\r\n//REDUX\r\nimport reduxStore from \"store/\";\r\n\r\n//COMPONENTS\r\nimport Card from \"components/Card\";\r\n\r\n//IMAGES\r\nimport userCover from \"assets/img/userCover.jpg\"\r\n\r\n//FUNCTIONS\r\nimport {\r\n    customApp\r\n} from \"functions/\";\r\n\r\nfunction Dashboard(props) {\r\n    const { db, session } = reduxStore.getState()\r\n    const { dataType } = db\r\n    const { data } = props\r\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\r\n    const [ImagePreview, setImagePreview] = React.useState(null)\r\n\r\n    let myCards = Object.keys(reduxStore.getState().db.cards).filter(a => reduxStore.getState().db.cards[a]).map(c => reduxStore.getState().db.cards[c])\r\n\r\n    let myDayTasksContent = myCards.filter(a =>\r\n        a._users\r\n        && !a.checklist\r\n        && !a.deleted\r\n        && a._users[data._id]\r\n        && a._users[data._id].myDay\r\n        && (\r\n            !a.private\r\n            ||\r\n            (\r\n                a.private\r\n                && a._users[session._id]\r\n            )\r\n        )\r\n        && (\r\n            moment(new Date(parseInt(a._users[data._id].myDay) * 1000)).tz('America/Sao_Paulo').format('YYYY/MM/DD') === today\r\n        )\r\n    ).sort((a, b) => {\r\n        if (reduxStore.getState().db.orderByTitle\r\n            && reduxStore.getState().db.orderByTitlePosition === 'ASC'\r\n            && a.name.toLowerCase().trim() < b.name.toLowerCase().trim()\r\n        ) {\r\n            return -1\r\n        } else if (reduxStore.getState().db.orderByTitle\r\n            && reduxStore.getState().db.orderByTitlePosition === 'DESC'\r\n            && a.name.toLowerCase().trim() > b.name.toLowerCase().trim()\r\n        ) {\r\n            return -1\r\n        } else if (reduxStore.getState().db.orderByTitle) {\r\n            return 0\r\n        } else if (!reduxStore.getState().db.orderByTitle && String(a.order) && String(b.order) && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low)) {\r\n            return -1\r\n        } else {\r\n            return 1\r\n        }\r\n    }\r\n    ).map((a, i) => <Card db=\"cards\" key={i} data={a} showStatus onlyOption />)\r\n\r\n    return (\r\n        <div style={{\r\n            width: \"100%\",\r\n            minHeight: \"120px\",\r\n            backgroundColor: \"#FFFFFF\",\r\n            boxShadow: \"0 0 9px 3px rgba(0,0,0,0.2)\",\r\n            position: \"relative\",\r\n        }}\r\n        >\r\n            <div\r\n                style={{\r\n                    backgroundColor: customApp('menu'),\r\n                    height: \"43px\",\r\n                    paddingLeft: \"45px\",\r\n                    fontSize: \"12px\",\r\n                    color: \"#FFFFFF\",\r\n                    fontWeight: \"bold\",\r\n                    display: \"flex\",\r\n                    alignItems: \"center\",\r\n                    justifyContent: \"space-between\"\r\n                }}>\r\n                <div style={{\r\n                    maxWidth: 'calc(100% - 10px)',\r\n                    textOverflow: \"ellipsis \",\r\n                    whiteSpace: \"nowrap\",\r\n                    overflow: \"hidden\",\r\n                }}>\r\n                    {data.name ? data.name : data.name} ({myDayTasksContent.length})\r\n                </div>\r\n            </div>\r\n            {(!ImagePreview || (data.image && data.image !== ImagePreview)) ?\r\n                <img\r\n                    style={{\r\n                        width: \"37px\",\r\n                        height: \"37px\",\r\n                        top: \"3x\",\r\n                        left: \"3px\",\r\n                        borderRadius: '50%',\r\n                        border: `solid 2px ${customApp('color')}`,\r\n                        zIndex: '5 !important',\r\n                        position: 'absolute',\r\n                        backgroundColor: `${customApp('color')}`,\r\n                    }}\r\n                    src={`${data.image ? data.image : userCover}`}\r\n                    onError={(e) => {\r\n                        e.target.src = `${userCover}`\r\n                    }}\r\n                    onLoad={(e) => {\r\n                        setImagePreview(`${data.image ? data.image : userCover}`)\r\n                    }}\r\n                    width=\"100%\" />\r\n                :\r\n                <div\r\n                    style={{\r\n                        width: \"37px\",\r\n                        height: \"37px\",\r\n                        top: \"3px\",\r\n                        left: \"3px\",\r\n                        borderRadius: '50%',\r\n                        border: `solid 2px ${customApp('color')}`,\r\n                        zIndex: '5 !important',\r\n                        position: 'absolute',\r\n                        backgroundColor: `${customApp('color')}`,\r\n                        backgroundImage: `url(\"${ImagePreview}\")`,\r\n                        backgroundSize: \"cover\",\r\n                        backgroundPosition: \"center center\"\r\n                    }}\r\n                >\r\n                </div>\r\n            }\r\n            <React.Fragment>\r\n                {/* <div style={{\r\n                    width: '100%',\r\n                    height: '333px',\r\n                    overflowX: 'hide'\r\n                }}\r\n                >\r\n                    <ResponsivePie\r\n                        data={[\r\n                            ...db.status.map((st, index) => {\r\n                                return {\r\n                                    id: translate(st.label, 1),\r\n                                    label: translate(st.label, 1),\r\n                                    value: Object.keys(db.cards).filter(fil =>\r\n                                        db.cards[fil]\r\n                                        && !db.cards[fil].deleted\r\n                                        && db.cards[fil]._users\r\n                                        && db.cards[fil]._users[data._id]\r\n                                        && db.cards[fil]._users[data._id].myDay\r\n                                        && (moment(new Date(parseInt(db.cards[fil]._users[data._id].myDay) * 1000)).tz('America/Sao_Paulo').format('YYYY/MM/DD') === today)\r\n                                        && db.cards[fil].status\r\n                                        && db.cards[fil].status === st.value\r\n                                    ).length,\r\n                                    color: st.color\r\n                                }\r\n                            })\r\n                        ]}\r\n                        activeOuterRadiusOffset={8}\r\n                        arcLabelsSkipAngle={10}\r\n                        arcLabelsTextColor={\"#FFFFFF\"}\r\n                        arcLinkLabelsColor={{ from: 'color' }}\r\n                        arcLinkLabelsSkipAngle={10}\r\n                        arcLinkLabelsTextColor=\"#333333\"\r\n                        arcLinkLabelsThickness={7}\r\n                        borderColor={{ from: 'color', modifiers: [['darker', 0.2]] }}\r\n                        borderWidth={1}\r\n                        colors={['#929497', '#011E41', '#EBA900', '#5A7F71']}\r\n                        cornerRadius={3}\r\n                        enableArcLinkLabels={false}\r\n                        innerRadius={0.5}\r\n                        margin={{ top: 40, right: 40, bottom: 40, left: 40 }}\r\n                        padAngle={1.3}\r\n                    />\r\n                </div> */}\r\n                <div style={{\r\n                    width: '100%',\r\n                    maxHeight: 'calc(50vh - 90px)',\r\n                    overflowX: 'auto'\r\n                }}>\r\n                    {myDayTasksContent}\r\n                </div>\r\n            </React.Fragment>\r\n        </div >\r\n    );\r\n}\r\n\r\n//EXPORT\r\nexport default Dashboard","import React from \"react\";\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport DayList from \"components/User/dayList\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/dashboard\";\n\n//FUNCTIONS\nimport {\n    customApp,\n    getAppAccess,\n    translate,\n} from \"functions/\";\n\n\nfunction Dashboard(props) {\n    const { db } = reduxStore.getState()\n    const { dataType, users } = db\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\n    const [mounted, setMounted] = React.useState(false)\n    let AppAccess = getAppAccess()\n\n    React.useEffect(() => {\n        if (!mounted) {\n            if (!reduxStore.getState().session.cards.adminViewLoader)\n                setAdminView()\n            setMounted(true)\n        }\n        return function cleanup() {\n            props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                ...reduxStore.getState().session,\n                cards: {\n                    ...reduxStore.getState().session.cards,\n                    adminView: false\n                }\n            });\n        }\n    }, [])\n\n    if (AppAccess && AppAccess.plan && (\n        !AppAccess.planAdmin\n        && !AppAccess.planModerate\n    ))\n        return <React.Fragment></React.Fragment>\n\n    const setAdminView = async (enabled) => {\n        props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n            ...reduxStore.getState().session,\n            cards: {\n                ...reduxStore.getState().session.cards,\n                adminView: !reduxStore.getState().session.cards.adminView\n            }\n        });\n    }\n\n    let myCards = Object.keys(reduxStore.getState().db.cards).filter(a => reduxStore.getState().db.cards[a]\n        && dataType.filter(dt => dt.name === reduxStore.getState().db.cards[a].type).length > 0\n    ).map(c => reduxStore.getState().db.cards[c])\n\n    let filtered = Object.keys(users).filter(fil =>\n        !users[fil].deleted &&\n        users[fil].type === 'user' &&\n        (!users[fil]._parent || users[fil]._parent === \"\")\n        && myCards.filter(a =>\n            a._users\n            && a._users[fil]\n            && a._users[fil].myDay\n            && (moment(new Date(parseInt(a._users[fil].myDay) * 1000)).tz('America/Sao_Paulo').format('YYYY/MM/DD') === today)\n        ).length > 0\n    ).sort((a, b) => {\n        if (users[a].name < users[b].name) {\n            return -1\n        } else if (users[a].name > users[b].name) {\n            return 1\n        } else {\n            return 0\n        }\n    }\n    ).map(a => users[a])\n\n    return (\n        <div style={{ width: '100%' }}>\n            <GridContainer>\n                <GridItem\n                    xs={12}\n                    sm={12}\n                    md={12}\n                    lg={12}\n                    xl={12}\n                    style={{\n                        display: 'flex',\n                        justifyContent: 'space-between'\n                    }}\n                >\n                    <div style={{\n                        fontSize: '33px',\n                        padding: '15px 0',\n                        fontWeight: 'bold',\n                        color: customApp('menu')\n                    }}>\n                        {translate('$__dayTasks', 1)}\n                    </div>\n\n                </GridItem>\n                {filtered.map(a =>\n                    <GridItem\n                        xs={12}\n                        sm={12}\n                        md={3}\n                        lg={3}\n                        xl={3}\n                        key={a._id}\n                        style={{\n                            marginBottom: '7px'\n                        }}\n                    >\n                        <DayList data={a} />\n                    </GridItem>\n                )}\n\n            </GridContainer>\n        </div >\n    );\n}\n\nconst mapStateToProps = (store) => {\n    return {\n        store\n    }\n};\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Dashboard))","import React from \"react\"\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport CardsLoader from \"components/Card/loader\"\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//DEPENDENCIES\nimport Resume from \"./resume\"\nimport DayTasks from \"./daytasks\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/dashboard\"\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\nfunction Dashboard() {\n\n  React.useEffect(() => {\n    return () => {\n    }\n  }, [])\n\n\n\n  let hashs = window.location.hash.split('/')\n  hashs[0] = hashs[0].replace('#', '')\n\n  return (\n    <div>\n      <CardsLoader />\n      {(hashs[0] === 'tab' && hashs[1] === 'resume') &&\n        <ErrorBoundary>\n          <Resume />\n        </ErrorBoundary>\n      }\n      {(hashs[0] === 'tab' && hashs[1] === 'dayTasks') &&\n        <ErrorBoundary>\n          <DayTasks />\n        </ErrorBoundary>\n      }\n    </div >\n  )\n}\n\n//EXPORT\nconst mapStateToProps = (store) => {\n  return {\n    history: store.db.history\n  }\n}\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Dashboard))","import { title, whiteColor } from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst errorPageStyles = () => ({\r\n  contentCenter: {\r\n    position: \"absolute\",\r\n    top: \"50%\",\r\n    left: \"50%\",\r\n    zIndex: \"3\",\r\n    transform: \"translate(-50%,-50%)\",\r\n    textAlign: \"center\",\r\n    color: whiteColor,\r\n    padding: \"0 15px\",\r\n    width: \"100%\",\r\n    maxWidth: \"880px\"\r\n  },\r\n  title: {\r\n    ...title,\r\n    fontSize: \"13.7em\",\r\n    color: whiteColor,\r\n    letterSpacing: \"14px\",\r\n    fontWeight: \"700\"\r\n  },\r\n  subTitle: {\r\n    fontSize: \"2.25rem\",\r\n    marginTop: \"0\",\r\n    marginBottom: \"8px\"\r\n  },\r\n  description: {\r\n    fontSize: \"1.125rem\",\r\n    marginTop: \"0\",\r\n    marginBottom: \"8px\"\r\n  }\r\n});\r\n\r\nexport default errorPageStyles;\r\n","import React from \"react\";\n\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n// core components\nimport GridContainer from \"components/Grid/GridContainer.js\";\nimport GridItem from \"components/Grid/GridItem.js\";\n\nimport styles from \"assets/jss/material-dashboard-pro-react/views/errorPageStyles.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function ErrorPage() {\n  const classes = useStyles();\n  return (\n    <div className={classes.contentCenter}>\n      <GridContainer>\n        <GridItem md={12}>\n          <h1 className={classes.title}>404</h1>\n          <h2 className={classes.subTitle}>Page not found :(</h2>\n          <h4 className={classes.description}>\n            Ooooups! Looks like you got lost.\n          </h4>\n        </GridItem>\n      </GridContainer>\n    </div>\n  );\n}\n","import React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\n\n//COMPONENTS\nimport CustomButton from \"components/Buttons/custom\"\nimport File from \"components/Files/file_V2\"\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport Icon from \"components/Icon\"\nimport LinearProgress from \"components/Progress/linear\"\nimport TextField from \"components/TextField/\"\n\n//@MATERIAL\nimport InputAdornment from '@material-ui/core/InputAdornment';\nimport TablePagination from \"@material-ui/core/TablePagination\"\n\n//FUNCTIONS\nimport {\n    translate,\n} from \"functions/\"\n\nimport { customApp } from \"functions\"\n\nimport { navFiles, navFolders } from \"functions/files\"\n\nfunction Component(props) {\n    const { db, session } = reduxStore.getState()\n    const [mounted, setMounted] = React.useState(false)\n    const [selectedParent, setSelectedParent] = React.useState(null)\n    const [cardsIds, setCardsIds] = React.useState([])\n    const [page, setPage] = React.useState(0)\n    const [limit, setLimit] = React.useState(10)\n    const [locked, setLocked] = React.useState(false)\n    const [cardType, setCardType] = React.useState(cardType)\n    const [files, setFiles] = React.useState([])\n    const [countFiles, setCountFiles] = React.useState(0)\n    const [orderBy, setOrderBy] = React.useState('created_at')\n    const [orderDESC, setorderDESC] = React.useState(true)\n    const [searchText, setSearchText] = React.useState(\"\")\n    const [preloader, setPreloader] = React.useState(true)\n    const [folders, setFolders] = React.useState({})\n    const [searchFolder, setSearchFolder] = React.useState(\"\")\n    const [navigation, setNavigation] = React.useState({\n        all: {\n            name: translate(\"$__all\", 1),\n            icon: \"inventory\",\n            open: false,\n            size: 0,\n            type: \"all\"\n        },\n        users: {\n            name: translate(\"$__users\", 1),\n            open: false,\n            size: 0,\n            type: \"user\"\n        },\n        plans: {\n            name: translate(\"$__plans\", 1),\n            open: false,\n            size: 0,\n            type: \"plan\"\n        },\n        myCards: {\n            name: translate(\"$__unlinkedCards\", 1),\n            open: false,\n            size: 0,\n            type: \"myTask\"\n        }\n    })\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    let idPlan = null\n    if (\n        hashs[0]\n        && hashs[0].length === 36\n        && reduxStore.getState().db.cards[hashs[0]]\n        && reduxStore.getState().db.cards[hashs[0]]._users\n        && reduxStore.getState().db.cards[hashs[0]]._users[session._id]\n    ) {\n        idPlan = hashs[0]\n    }\n\n    React.useEffect(() => {\n        reqFolders({ id: idPlan })\n        navFolders()\n        return () => {\n            setFiles([])\n            setFolders({})\n            setPreloader(true)\n        }\n    }, [])\n\n    React.useEffect(() => {\n        if (selectedParent)\n            reqFiles({ id: selectedParent })\n    }, [selectedParent])\n\n    React.useEffect(() => {\n        setPage(0)\n        setPreloader(true)\n        setCardsIds([])\n        if (!mounted) {\n            setMounted(true)\n        }\n        const timer = setTimeout(() => {\n            if (searchText)\n                reqFiles({ id: idPlan })\n        }, 1000)\n        return () => clearTimeout(timer)\n    }, [searchText])\n\n    React.useEffect(() => {\n        reqFiles({ id: idPlan })\n    }, [locked, page, limit, orderBy, orderDESC])\n\n\n    const reqFolders = async (data, fds) => {\n        let lf = await navFolders({\n            ids: data && data.id ? [data.id] : [],\n            childrens: false,\n            type: data.type ? data.type : null\n        })\n        if (lf) {\n            let ff = fds ? fds : folders\n            if (idPlan) {\n                ff = {\n                    ...ff,\n                    [idPlan]: {\n                        name: reduxStore.getState().db.cards[idPlan].name,\n                        parent: reduxStore.getState().db.cards[idPlan]._parent,\n                        private: null,\n                        type: \"plan\",\n                        _id: idPlan,\n                        open: true,\n                    }\n                }\n            }\n            lf.map(folder => {\n                ff = {\n                    ...ff,\n                    [folder._id]: {\n                        ...ff[folder._id] ? ff[folder._id] : {},\n                        ...folder,\n                    }\n                }\n            })\n            setFolders(ff)\n        }\n    }\n\n    const reqFiles = async (data) => {\n        let lf = await navFiles({\n            ids: data && data.id ? [data.id] : [],\n            type: data && data.type || \"cards\",\n            limit,\n            skip: page * limit,\n            asc: !orderDESC,\n            orderBy: orderBy || \"created_at\",\n            search: searchText\n        })\n        if (lf) {\n            setCountFiles(lf && lf[0] && lf[0].total ? parseInt(lf[0].total) : 0)\n            setFiles(lf)\n            setPreloader(false)\n        }\n    }\n\n\n\n    let lightBoxfiles = []\n\n\n    const openLightBox = (f) => {\n        props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n            open: true,\n            files: lightBoxfiles,\n            file: f\n        })\n    }\n\n    const order = (by) => {\n        let ob = orderBy\n        let desc = orderDESC\n        if (orderBy === by) {\n            desc = !orderDESC\n        } else {\n            ob = by\n        }\n        setOrderBy(ob)\n        setorderDESC(desc)\n    }\n\n    const openFolder = async (data, option = false) => {\n        const { id = null, type = null } = data\n        let nFolders = folders\n\n        nFolders = {\n            ...nFolders,\n            [id]: {\n                ...nFolders[id],\n                open: option,\n                loading: true,\n            }\n        }\n        if (Object.keys(folders).filter(a => folders[a].parent === id).length === 0) {\n            reqFolders({ id, type }, nFolders)\n        } else {\n            setFolders(nFolders)\n        }\n    }\n\n    const RenderFolder = (folder, f) => (\n        <div\n            key={f}\n            style={{\n                cursor: \"pointer\",\n                borderLeft: \"solid 0.5px lightgray\",\n                paddingLeft: 7\n            }}\n            onClick={(e) => {\n                if (!folder.private ||\n                    (folder.private && reduxStore.getState().controls.lockPrivate)\n                ) {\n                    openFolder({\n                        id: f,\n                    }, folders[f] && folders[f].open ? false : true)\n                    setSelectedParent(f)\n                } else {\n\n                }\n                e.preventDefault()\n                e.stopPropagation()\n            }}\n        >\n            <HeaderWithIcon\n                title={`${folder.private && !reduxStore.getState().controls.lockPrivate ? translate(\"$__private\") : folder.name}`}\n                tooltipText={`${folder.private && !reduxStore.getState().controls.lockPrivate ? translate(\"$__private\") : folder.name}`}\n                icon={(folder.private && !reduxStore.getState().controls.lockPrivate ? 'private_connectivity' : folder.type && db && db.dataType && db.dataType.filter(a => a.name === folder.type)[0].icon) || \"$__topic\"}\n                fontSize=\"12px\"\n                color={folder.private && !reduxStore.getState().controls.lockPrivate ? 'lightgray' : selectedParent && selectedParent === f ? customApp(\"color\") : customApp(\"gray\")}\n            />\n            {folders[f] && folders[f].open ? reqSubFolders(f) : <React.Fragment></React.Fragment>}\n        </div>\n    )\n\n    const reqSubFolders = (id = null) => {\n        return (\n            <div style={{\n                marginLeft: 7\n            }}>\n                {Object.keys(folders).filter(folder =>\n                (\n                    (\n                        !id\n                    )\n                    ||\n                    (\n                        id &&\n                        folders[folder].parent === id\n                    )\n                )\n                ).length > 0 ?\n                    Object.keys(folders).filter(folder =>\n                    (\n                        (\n                            !id\n                        )\n                        ||\n                        (\n                            id &&\n                            folders[folder].parent === id\n                        )\n                    )\n                    ).sort((a, b) => {\n                        if (folders[a].name.toLowerCase().trim() < folders[b].name.toLowerCase().trim())\n                            return -1\n                        if (folders[a].name.toLowerCase().trim() > folders[b].name.toLowerCase().trim())\n                            return 1\n                        return 0\n                    }).map(f => {\n                        return RenderFolder(folders[f], f)\n                    }) : <React.Fragment></React.Fragment>\n                }\n            </div>\n        )\n    }\n\n    return (\n        <div style={props.expanded ? { width: \"calc(100% - 220px)\", marginLeft: \"220px\" } : { width: \"calc(100% - 0px)\", marginLeft: \"0px\" }}>\n            <div style={{\n                backgroundColor: \"#FFFFFF\",\n                position: \"relative\",\n                padding: \"7px 15px\",\n                float: \"right\",\n                boxShadow: \"0px 0px 7px 3px rgba(0,0,0,0.1)\",\n                display: \"flex\",\n                alignItems: \"center\"\n            }}>\n                <TextField\n                    label={translate('$__search', '*')}\n                    variant={'standard'}\n                    autoFocus\n                    value={searchText}\n                    InputProps={{\n                        endAdornment: (\n                            <InputAdornment position=\"start\">\n                                <Icon color={customApp('color')}>search</Icon>\n                            </InputAdornment>\n                        ),\n                        onChange: e => {\n                            setSearchText(e.target.value)\n                        },\n                        onKeyDown: e => {\n                            // if (String(e.which) === '27')\n                            //     setviewSearch(false)\n                        }\n                    }}\n                />\n                <div style={{\n                    position: \"relative\",\n                    display: \"flex\",\n                    alignItems: \"center\"\n                }}>\n                    <CustomButton\n                        id={`sideModule_saveButton`}\n                        title={orderBy === \"created_at\" && orderDESC ? translate(`$__mostRecent`, 1) : translate(`$__olderFirst`, 1)}\n                        color={orderBy === \"created_at\" ? customApp(\"color\") : 'gray'}\n                        icon={\"calendar_month\"}\n                        onClick={() => { order('created_at') }}\n                        size={\"25px\"}\n                    />\n                    {orderBy === \"created_at\" &&\n                        <div\n                            style={{\n                                position: \"absolute\",\n                                ...orderDESC ? { bottom: 0 } : { top: 0 },\n                                right: -5\n                            }}>\n                            <Icon\n                                size=\"15px\"\n                                color={customApp(\"menu\")}\n                                style={{ marginLeft: \"-3px\" }}\n                            >{orderDESC ? \"south\" : \"north\"}</Icon>\n                        </div>\n                    }\n                </div>\n                <div style={{\n                    position: \"relative\",\n                    display: \"flex\",\n                    alignItems: \"center\"\n                }}>\n                    <CustomButton\n                        id={`sideModule_saveButton`}\n                        title={orderBy === \"name\" && orderDESC ? translate(`$__nameDesc`, 1) : translate(`$__nameAsc`, 1)}\n                        color={orderBy === \"name\" ? customApp(\"color\") : 'gray'}\n                        icon={\"sort_by_alpha\"}\n                        onClick={() => { order('name') }}\n                        size={\"25px\"}\n                    />\n                    {orderBy === \"name\" &&\n                        <div\n                            style={{\n                                position: \"absolute\",\n                                ...orderDESC ? { bottom: 0 } : { top: 0 },\n                                right: -5\n                            }}>\n                            <Icon\n                                size=\"15px\"\n                                color={customApp(\"menu\")}\n                                style={{ marginLeft: \"-3px\" }}\n                            >{orderDESC ? \"south\" : \"north\"}</Icon>\n                        </div>\n                    }\n                </div>\n            </div>\n            <div style={{\n                position: \"relative\",\n                backgroundColor: \"#FFFFFF\",\n                boxShadow: \"0px 0px 7px 3px rgba(0,0,0,0.1)\",\n                clear: \"both\",\n                marginTop: -10,\n                minHeight: \"calc(100vh - 150px)\"\n            }}>\n                <div style={{\n                    position: \"absolute\",\n                    width: 333,\n                    height: \"100%\",\n                    minHeight: 1,\n                    padding: 15,\n                    backgroundColor: \"#f4f4f4\",\n                    borderRight: \"solid 0.77px lightGray\",\n                    display: \"flow-root\"\n                }}>\n                    <div style={{ display: \"flex\", marginTop: -10 }}>\n                        <HeaderWithIcon\n                            title={translate(\"$__folders\", 1)}\n                            icon={\"folder\"}\n                            fontSize=\"20px\"\n                            color={customApp(\"menu\")}\n                        />\n                        <TextField\n                            label={translate('$__search', '*')}\n                            variant={'standard'}\n                            autoFocus\n                            value={searchFolder}\n                            InputProps={{\n                                endAdornment: (\n                                    <InputAdornment position=\"start\">\n                                        <Icon color={customApp('lightgray')}>search</Icon>\n                                    </InputAdornment>\n                                ),\n                                onChange: e => {\n                                    setSearchFolder(e.target.value)\n                                },\n                                onKeyDown: e => {\n                                    // if (String(e.which) === '27')\n                                    //     setviewSearch(false)\n                                }\n                            }}\n                        />\n                    </div>\n                    <div style={{\n                        position: \"relative\",\n                        height: \"calc(100% - 33px)\",\n                        overflowX: \"auto\",\n                        backgroundColor: \"rgba(250,250,250,0.9)\",\n                        borderRadius: \"solid 0.5px rgba(0,0,0,0.1)\",\n                        padding: 15\n                    }}>\n                        {/* {idPlan && Object.keys(navigation).map((nav, i) => {\n                            return (<div key={`${nav}-${i}`}\n                                style={{\n                                    cursor: \"pointer\"\n                                }}\n                                onClick={(e) => {\n                                    e.stopPropagation()\n                                    e.preventDefault()\n\n                                    setSelectedParent(nav)\n                                }}\n                            >\n                                <HeaderWithIcon\n                                    title={navigation[nav].name}\n                                    tooltipText={`${translate(`$__${navigation[nav].type}`, '*')} - ${navigation[nav].name}`}\n                                    icon={navigation[nav].icon ? navigation[nav].icon : (navigation[nav].type && db && db.dataType && db.dataType.filter(a => a.name === navigation[nav].type)[0].icon) || \"$__topic\"}\n                                    fontSize=\"12px\"\n                                    color={selectedParent === nav ? customApp(\"color\") : customApp(\"gray\")}\n                                />\n                            </div>)\n                        })} */}\n                        {Object.keys(folders).filter(folder =>\n                            (\n                                (\n                                    (\n                                        !hashs[0]\n                                        ||\n                                        (\n                                            hashs[0]\n                                            && hashs[0].length !== 36\n                                        )\n                                    )\n                                    &&\n                                    !folders[folder].parent\n                                )\n                                ||\n                                (\n                                    (\n                                        hashs\n                                        && hashs[0]\n                                        && hashs[0].length === 36\n                                    )\n                                    && (\n                                        // (\n                                        //     folders[folder]\n                                        //     && folders[folder].parent\n                                        //     && folders[folder].parent === hashs[0]\n                                        // )\n                                        // ||\n                                        (\n                                            folders[folder]._id === hashs[0]\n                                        )\n                                    )\n                                )\n                            )\n                            &&\n                            (\n                                searchFolder === \"\"\n                                ||\n                                (\n                                    searchFolder\n                                    && folders[folder].name.toLowerCase().indexOf(searchFolder.toLowerCase().trim()) > -1\n                                )\n                            )\n                        ).sort((a, b) => {\n                            if (folders[a].name.toLowerCase().trim() < folders[b].name.toLowerCase().trim())\n                                return -1\n                            if (folders[a].name.toLowerCase().trim() > folders[b].name.toLowerCase().trim())\n                                return 1\n                            return 0\n                        }).map(f => {\n                            return RenderFolder(folders[f], f)\n                        }\n                        )}\n                    </div>\n                </div>\n                <div style={{ position: \"relative\", float: \"left\", marginLeft: 333, width: \"calc(100% - 333px)\", overflowY: \"auto\" }}>\n                    <div style={{\n                        position: \"relative\",\n                        width: \"100%\",\n                        padding: \"15px\",\n                    }}>\n                        <div style={{ position: \"relative\", float: \"left\", minWidth: 177 }}>\n                            <HeaderWithIcon\n                                title={translate(\"$__files\", 1)}\n                                icon={\"cloud\"}\n                                fontSize=\"20px\"\n                                color={customApp(\"menu\")}\n                            />\n                        </div>\n                        <div style={{ position: \"relative\", float: \"right\", display: \"flex\", alignItems: \"center\", marginTop: -10 }}>\n                            {/* PAGINATION */}\n                            {translate(\"$__page\")} {page + 1} {translate(\"$__of\")} {Math.ceil(countFiles / limit)}\n                            <div style={{ display: \"flex\", alignItems: \"center\" }}>\n                                <TablePagination\n                                    component=\"div\"\n                                    count={countFiles}\n                                    page={page}\n                                    onPageChange={(event, newPage) => {\n                                        setPage(newPage)\n                                    }}\n                                    rowsPerPage={limit}\n                                    onRowsPerPageChange={(event) => {\n                                        setLimit(parseInt(event.target.value, 10))\n                                    }}\n                                    labelRowsPerPage={translate(\"$__filesPerPage\")}\n                                />\n                            </div>\n                        </div>\n                    </div>\n                    {preloader ?\n                        <LinearProgress />\n                        :\n                        files && files.length > 0 ? files.map((f, fi) => {\n                            lightBoxfiles.push(f.data)\n                            let file = {\n                                ...f.data,\n                                createdBy: f.createdBy,\n                                in: f.in,\n                                // parents: f.parents.filter(a => a._id).length > 0 ? f.parents.reverse() : []\n                            }\n                            return (\n                                <div\n                                    key={`file_${file._id}${fi}`}\n                                    style={{\n                                        position: \"relative\",\n                                        width: \"100%\",\n                                        paddingTop: \"7px\",\n                                        paddingLeft: \"15px\",\n                                        clear: \"both\"\n                                    }}\n                                >\n                                    <File\n                                        data={file}\n                                        openLightBox={\n                                            () => openLightBox(file._id)\n                                        }\n                                        admin={\n                                            file.createdBy._id === session._id\n                                                ||\n                                                file.in._id === session._id\n                                                ||\n                                                (file.access && parseInt(file.access) > 2)\n                                                ? true : false\n                                        }\n                                    />\n                                    <div style={{ clear: \"both\" }}></div>\n                                </div>\n                            )\n                        }\n                        ) : <React.Fragment></React.Fragment>}\n                    {\n                        countFiles > 10 ?\n                            <div style={{\n                                position: \"relative\",\n                                width: \"100%\",\n                                padding: \"15px\",\n                                display: \"flex\",\n                                alignItems: \"center\",\n                                justifyContent: \"center\"\n                            }}>\n                                {/* PAGINATION */}\n                                {translate(\"$__page\")} {page + 1} {translate(\"$__of\")} {Math.ceil(countFiles / limit)}\n                                <div style={{ display: \"flex\", alignItems: \"center\" }}>\n                                    <TablePagination\n                                        component=\"div\"\n                                        count={countFiles}\n                                        page={page}\n                                        onPageChange={(event, newPage) => {\n                                            setPage(newPage)\n                                        }}\n                                        rowsPerPage={limit}\n                                        onRowsPerPageChange={(event) => {\n                                            setLimit(parseInt(event.target.value, 10))\n                                        }}\n                                        labelRowsPerPage={translate(\"$__filesPerPage\")}\n                                    />\n                                </div>\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                    }\n                </div>\n                <div style={{ clear: \"both\" }}></div>\n            </div>\n\n        </div >\n    )\n}\n\nconst mapStateToProps = (store) => ({\n    showPrivate: store.controls.lockPrivate,\n    history: store.db.history\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(Component)","import React from \"react\";\nimport { decode as base64_decode, encode as base64_encode } from 'base-64';\nimport bcrypt from 'bcryptjs';\nimport GoogleLogin from \"react-google-login\";\n\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\nimport Icon from \"@material-ui/core/Icon\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\n\n// @material-ui/icons\nimport Email from \"@material-ui/icons/Email\";\n\n// core components\nimport Button from \"components/CustomButtons/Button.js\";\nimport Card from \"components/Card/Card.js\";\nimport CardBody from \"components/Card/CardBody.js\";\nimport CardFooter from \"components/Card/CardFooter.js\";\nimport CardHeader from \"components/Card/CardHeader.js\";\nimport CustomInput from \"components/CustomInput/CustomInput.js\";\nimport GridContainer from \"components/Grid/GridContainer.js\";\nimport GridItem from \"components/Grid/GridItem.js\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport LinearProgress from \"components/Progress/linear\"\nimport TextField from \"components/TextField\";\n\n// styles\nimport styles from \"assets/jss/material-dashboard-pro-react/views/loginPageStyle.js\";\n\n//FUNCTIONS\nimport apims from \"apims/\"\n\nimport { translate, appAlert, customApp } from \"functions/\"\n\nrequire('dotenv').config()\nconst LKEY = String(process.env.REACT_APP_PROD) === 'true' ? `${String(process.env.REACT_APP_KP)}` : `${String(process.env.REACT_APP_KL)}`\nconst useStyles = makeStyles(styles);\n\nfunction LoginPage(props) {\n  const [user, setUser] = React.useState({ email: null, password: null });\n  const [token, setToken] = React.useState(null)\n  const [reqTwoFactor, setReqTwoFactor] = React.useState(false)\n  const [loginToken, setLoginToken] = React.useState(null)\n  const [login, setLogin] = React.useState(false)\n  const classes = useStyles();\n\n  const emailLogin = async () => {\n    if (\n      (\n        window.location.origin.indexOf('localhost') === -1\n        && window.location.origin.indexOf('hom2022') === -1\n        && window.location.origin.indexOf('homologation') === -1\n        && window.location.origin.indexOf('a1b2c3d4') === -1\n        && window.location.origin.indexOf('192.168') === -1\n      )\n      &&\n      (\n        (\n          window.location.origin.indexOf('sonne.machen') > -1\n          && user.email.indexOf('@sonne.global') === -1\n        ) || (\n          window.location.origin.indexOf('sonne.machen') === -1\n          && user.email.indexOf('@sonne.global') > -1\n        )\n      )\n    ) {\n      props.callback({\n        fn: 'alert',\n        variant: \"warning\",\n        horizontal: \"center\",\n        message: `${translate(`$__emailDomainNotPermitedForThisAddress`, 1)}`\n      })\n    } else if (!user.email) {\n      props.callback({\n        fn: 'alert',\n        variant: \"warning\",\n        horizontal: \"center\",\n        message: `${translate(`$__alertLoginEmptyEmail`, 1)}`\n      })\n    } else if (!user.password) {\n      props.callback({\n        fn: 'alert',\n        variant: \"warning\",\n        horizontal: \"center\",\n        message: `${translate(`$__alertLoginEmptyPassword`, 1)}`\n      })\n    } else {\n      setLogin(true)\n      let pss = await bcrypt.hash(String(user.password), 10)\n      let pss2 = await bcrypt.hash(String(user.password), 10)\n      let newKey = base64_encode(`${pss2}//${LKEY}`)\n\n\n      if (pss, pss2, newKey)\n        try {\n          const res = await apims.post('/Login',\n            base64_encode(base64_encode(JSON.stringify({\n              lp: newKey,\n              login: user.email,\n              password: base64_encode(`${pss}///${base64_encode(user.password)}///${pss2}`),\n            })))\n          )\n          if (res) {\n            if (res.data && res.data.code === 400) {\n              props.callback({\n                fn: 'alert',\n                variant: \"warning\",\n                horizontal: \"center\",\n                message: `${translate(`$__${res.data.error}`, 1)}`\n              })\n            } else if (res && res.data && res.data.twoFactor) {\n              setLoginToken(res.data.token)\n              setReqTwoFactor(true)\n            } else if (res.data.token) {\n              localStorage.setItem('TOKEN', res.data.token)\n              if (props.callback) {\n                props.callback({ fn: 'login', token: res.data.token })\n              }\n            }\n          }\n\n        } catch (err) {\n          console.log(err)\n          props.callback({\n            fn: 'alert',\n            variant: \"warning\",\n            horizontal: \"center\",\n            message: `${translate(\"$__alertServerConectionLogin\", 1)}`\n          })\n        }\n      setTimeout(() => {\n        setLogin(false)\n      }, 1500)\n    }\n  }\n\n\n  const validToken = async () => {\n    setLogin(true)\n    if (!token || (token && token.length !== 6)) {\n      appAlert({\n        message: translate('$__invalidToken', 1),\n        variant: 'warning',\n        persist: false,\n        horizontal: 'right',\n      })\n    } else {\n      const res = await apims.post('/M_User_TwoFactor', {\n        action: 'verify',\n        code: token,\n        token: loginToken\n      })\n      if (res && res.data && res.data.result) {\n        localStorage.setItem('TOKEN', loginToken)\n        if (props.callback) {\n          props.callback({ fn: 'login', token: loginToken })\n        }\n      } else {\n        appAlert({\n          message: translate('$__invalidToken', 1),\n          variant: 'warning',\n          persist: false,\n          horizontal: 'right',\n        })\n      }\n      setToken(null)\n    }\n    setTimeout(() => {\n      setLogin(false)\n    }, 1500)\n  }\n\n  const recoveryPassword = async (email) => {\n    if (!email) {\n      props.callback({\n        fn: 'alert',\n        message: translate('$__loginAlertRecoveryEmailEmpty')\n      })\n    } else {\n      try {\n        const res = await apims.get(`/M_User_RecoveryPass/?email=${email}`)\n        if (res && res.data) {\n          props.callback({\n            fn: 'alert',\n            message: translate('$__loginAlertRecoveryEmailSended')\n          })\n        } else {\n          props.callback({\n            fn: 'alert',\n            message: translate('$__loginAlertRecoveryInvalidEmail')\n          })\n        }\n      } catch (err) {\n        props.callback({\n          fn: 'alert',\n          message: translate('$__loginAlertRecoveryError')\n        })\n      }\n    }\n  }\n  return (\n    <div className={classes.container}>\n      <GridContainer style={{ display: \"flex\", justifyContent: \"center\" }}>\n        <GridItem xl={4} lg={4} md={4} sm={12} xs={12}>\n          <Card db=\"cards\" login>\n            <CardHeader\n              className={`${classes.cardHeader} ${classes.textCenter}`}\n              color=\"primary\"\n              style={{\n                background: customApp(\"ColumnTitleColor\"),\n                boxShadow:\n                  \"0 4px 20px 0 rgba(15,18,35,0.14), 0 7px 10px -5px rgba(15,18,35,0.4)\"\n              }}\n            >\n              <h4 className={classes.cardTitle}>{translate('$__login')}</h4>\n              {/* <div className={classes.socialLine}>\n                  {[\n                    \"fab fa-facebook-square\",\n                    \"fab fa-twitter\",\n                    \"fab fa-google-plus\"\n                  ].map((prop, key) => {\n                    return (\n                      <Button\n                        color=\"transparent\"\n                        justIcon\n                        key={key}\n                        className={classes.customButtonClass}\n                      >\n                        <i className={prop} />\n                      </Button>\n                    );\n                  })}\n                </div> */}\n            </CardHeader>\n            <CardBody>\n              {!reqTwoFactor ?\n                <React.Fragment>\n                  <CustomInput\n                    labelText={translate('$__email')}\n                    id=\"email\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                    inputProps={{\n                      onChange: e => {\n                        setUser({\n                          ...user,\n                          email: e.target.value\n                        })\n                      },\n                      onLoad: e => {\n                        setUser({\n                          ...user,\n                          email: e.target.value\n                        })\n                      },\n                      endAdornment: (\n                        <InputAdornment position=\"end\">\n                          <Email className={classes.inputAdornmentIcon} />\n                        </InputAdornment>\n                      )\n                    }}\n                  />\n                  <CustomInput\n                    labelText={translate('$__password')}\n                    id=\"password\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                    inputProps={{\n                      onChange: e => {\n                        setUser({\n                          ...user,\n                          password: e.target.value\n                        })\n                      },\n                      onLoad: e => {\n                        setUser({\n                          ...user,\n                          password: e.target.value\n                        })\n                      },\n                      onKeyDown: (e) => {\n                        if (e.keyCode === 13)\n                          emailLogin()\n                      },\n                      endAdornment: (\n                        <InputAdornment position=\"end\">\n                          <Icon className={classes.inputAdornmentIcon}>\n                            lock_outline\n                          </Icon>\n                        </InputAdornment>\n                      ),\n                      type: \"password\",\n                      autoComplete: \"off\"\n                    }}\n                  />\n                  <IconButton\n                    icon=\"lock\"\n                    text={translate('$__recoveryPass', '*')}\n                    reverse\n                    style={{ float: 'right' }}\n                    onClick={() => {\n                      recoveryPassword(user.email)\n                    }}\n                  />\n                </React.Fragment>\n                :\n                <React.Fragment>\n                  <fieldset>\n                    <legend>{translate('$__token', 1)}</legend>\n                    <TextField\n                      labelText=\"token\"\n                      id=\"token_to_access\"\n                      name=\"token_to_access\"\n                      formControlProps={{\n                        fullWidth: true\n                      }}\n                      value={token}\n                      inputProps={{\n                        onKeyDown: e => {\n\n                        },\n                        onChange: e => {\n                          setToken(e.target.value)\n                        },\n                        endAdornment: (\n                          <InputAdornment position=\"end\">\n                            <Icon className={classes.inputAdornmentIcon}>\n                              pin\n                            </Icon>\n                          </InputAdornment>\n                        ),\n                        type: \"number\",\n                        autoComplete: false\n                      }}\n                      autoComplete={'new-password'}\n                    />\n                  </fieldset>\n                </React.Fragment>\n              }\n            </CardBody>\n            <CardFooter className={classes.justifyContentCenter}>\n              {!reqTwoFactor ?\n                <Button style={{ backgroundColor: !login ? customApp(\"menu\") : 'gray', color: \"#FFFFFF\" }} simple size=\"lg\" block onClick={() => emailLogin()}>\n                  {translate('$__sigin')}\n                  {login ?\n                    <div style={{ position: \"absolute\", bottom: 0, left: 0, right: 0 }}>\n                      <LinearProgress />\n                    </div>\n                    : <React.Fragment></React.Fragment>\n                  }\n                </Button>\n                :\n                <Button style={{ backgroundColor: !login ? '#c0b283' : 'gray', color: \"#FFFFFF\" }} simple size=\"lg\" block onClick={() => validToken()}>\n                  {translate('$__validateTokenAndSigin')}\n                  {login ?\n                    <div style={{ position: \"absolute\", bottom: 0, left: 0, right: 0 }}>\n                      <LinearProgress />\n                    </div>\n                    : <React.Fragment></React.Fragment>\n                  }\n                </Button>\n              }\n              {/* <InteractiveButton\n                  style={\n                    {\n                      color: 'rgba(15,18,35,1)'\n                    }\n                  }\n                  concludedText={translate(\"$__redirecting\")}\n                  text={translate(\"$__login\")}\n                  onClick={() => emailLogin()}\n                /> */}\n            </CardFooter>\n          </Card>\n          {/* </form> */}\n        </GridItem>\n      </GridContainer>\n    </div >\n  );\n}\n\nconst mapStateToProps = () => ({});\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(LoginPage)","import React from \"react\";\n\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n// core components\nimport GridContainer from \"components/Grid/GridContainer.js\";\nimport GridItem from \"components/Grid/GridItem.js\";\n\nimport styles from \"assets/jss/material-dashboard-pro-react/views/errorPageStyles.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function ErrorPage() {\n  const classes = useStyles();\n  return (\n    <div className={classes.contentCenter}>\n      <GridContainer>\n        <GridItem md={12}>\n          <h1 className={classes.title}>\\o/</h1>\n          <h2 className={classes.subTitle}>Plataforma em atualização :)</h2>\n          <h4 className={classes.description} style={{ color: '#FFFFFF' }}>\n            Tente acessar novamente em alguns minutos. Estamos implementando melhorias para melhor produtividade no seu dia a dia.\n          </h4>\n        </GridItem>\n      </GridContainer>\n    </div>\n  );\n}\n","import React from \"react\";\n\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n// core components\nimport GridContainer from \"components/Grid/GridContainer.js\";\nimport GridItem from \"components/Grid/GridItem.js\";\n\nimport styles from \"assets/jss/material-dashboard-pro-react/views/errorPageStyles.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function ErrorPage() {\n  const classes = useStyles();\n  return (\n    <div className={classes.contentCenter}>\n      <GridContainer>\n        <GridItem md={12}>\n          <h1 className={classes.title}>\"/</h1>\n          <h2 className={classes.subTitle}>Parece que você está OFF-LINE</h2>\n          <h4 className={classes.description} style={{ color: '#FFFFFF' }}>\n            Verifique a conexão de sua internet e tente novamente.\n          </h4>\n          <h4 className={classes.description} style={{ color: '#FFFFFF' }}>\n            Caso você esteja com conexão de internet ativa e ainda esteja visualizando esta página após algumas tentativas, favor entrar em contato com nosso suporte.\n          </h4>\n          <h4 className={classes.description} style={{ color: '#FFFFFF' }}>\n            <a href=\"/login\" target=\"_self\">Clique aqui para tentar novamente</a>\n          </h4>\n        </GridItem>\n      </GridContainer>\n    </div>\n  );\n}\n","import {\r\n  defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = {\r\n  container: {\r\n    borderRadius: '2px',\r\n    marginRight: '7px',\r\n    marginLeft: '7px',\r\n    marginBottom: '15px',\r\n    height: 'min-content',\r\n    width: '100%',\r\n  },\r\n  title: {\r\n    ...defaultFont,\r\n    padding: '3px 0px',\r\n    width: '100%',\r\n    margin: '0px',\r\n    background: customApp('ColumnTitleColor'),\r\n    \"&$reverse\": {},\r\n  },\r\n  reverse: {\r\n    flexDirection: \"row-reverse\",\r\n  },\r\n  cardList: {\r\n    //height: 'auto',\r\n    width: 'calc(100% - 6px)',\r\n    padding: '0px',\r\n    minHeight: '30px',\r\n    \"&::-webkit-scrollbar-track\": {\r\n      // boxShadow: 'inset 0 0 5px grey',\r\n      borderRadius: '0px',\r\n    },\r\n    \"&::-webkit-scrollbar\": {\r\n      width: '7px',\r\n    },\r\n    \"&::-webkit-scrollbar-thumb\": {\r\n      background: customApp('medium'),\r\n      opacity: '0.5 !important',\r\n      borderRadius: '0px',\r\n    }\r\n\r\n  },\r\n  button: {\r\n    padding: '3px auto',\r\n    cursor: 'pointer',\r\n    alignItems: 'center',\r\n    display: 'flex',\r\n    opacity: 1,\r\n    transition: 'visibility 0.1s, opacity 0.5s linear'\r\n  },\r\n  cardAdd: {\r\n    position: 'relative',\r\n    border: `0.5px solid ${customApp('light')}`,\r\n    borderRadius: '2px',\r\n    display: 'block',\r\n    backgroundColor: '#FFFFFF',\r\n    boxShadow: '0px 0px 10px rgba(0,0,0,0.1)',\r\n    overflow: 'hidden',\r\n    padding: '3px'\r\n  }\r\n};\r\n\r\nexport default style;\r\n","import React, { useEffect, useRef, memo } from 'react';\nimport styled from 'styled-components';\nimport { Droppable, Draggable } from 'react-beautiful-dnd';\nimport cx from \"classnames\";\nimport moment from \"moment-timezone\";\nimport { VariableSizeList as List } from \"react-window\";\nimport AutoSizer from \"react-virtualized-auto-sizer\";\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport HeaderWithIcon from \"components/Header/withIcon\";\nimport Card from \"components/Card\";\nimport Icon from \"components/Icon\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport TextField from \"components/TextField\";\n\n\n//FUNCTIONS\nimport api from \"api/\";\nimport { translate, customApp } from \"functions/\";\nimport { sortList, updateCardData, cardStatus, getCardColor } from \"functions/cards\";\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Agile-Column.js\";\n\n// STYLES\nimport columnStyles from \"./Columns.css.js\";\nimport zIndex from '@material-ui/core/styles/zIndex';\n\n\n\nfunction Column(props) {\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\n    const { search, session, db } = reduxStore.getState()\n    const { classes } = props\n    const [name, setName] = React.useState('')\n    // const [rowExpandeds, setRowExpandeds] = React.useState({})\n    const [add, setAdd] = React.useState(false)\n\n    // References\n    const listRef = useRef({});\n    const rowHeights = useRef({});\n    const rowExpandeds = useRef({});\n    const separators = useRef({});\n\n    React.useEffect(() => {\n        if (!props.groupByColor)\n            separators.current = {}\n    }, [props.groupByColor])\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace('#', '')\n    if (hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n\n    let filtered = props.cards\n\n\n    if (search && search.cards && (search.cards.startDate || search.cards.endDate))\n        filtered = filtered.filter(fil => {\n            if (\n                fil\n\n                && (\n                    (\n                        search.cards.startDate\n                        && fil.startDate\n                        && fil.startDate >= search.cards.startDate\n                    )\n                    && (\n                        search.cards.endDate\n                        && fil.endDate\n                        && fil.endDate <= search.cards.endDate\n                    )\n                ))\n                return true\n            return false\n        }).map(res => res)\n    if (search.text)\n        filtered = filtered.filter(fil => {\n            if (fil && fil.name && fil.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n                return true\n            return false\n        }).map(res => res)\n\n\n    filtered = filtered.filter(fil => {\n        if (!fil.status || (fil && fil.status && search.cards.status[fil.status]))\n            return true\n        return false\n    }).map(res => res)\n\n\n    filtered = filtered.filter(fil => {\n        if ((fil && fil.priority && search.cards.priority[fil.priority]) || (search.cards.priority['null'] && !fil.priority))\n            return true\n        return false\n    }).map(res => res)\n\n    if (search.users.selected && Object.keys(search.users.selected).length > 0)\n        filtered = filtered.filter(fil => {\n            if (fil && fil._users && Object.keys(fil._users).filter(uf => search.users.selected[uf]).length > 0)\n                return true\n        }).map(res => res)\n\n    if (Object.keys(search.units.selected).length > 0) {\n        if (search.units.selected['unassigned']) {\n            filtered = filtered.filter(fil => {\n                if (!fil._planId || (\n                    fil._planId\n                    && db.cards[fil._planId]\n                    && !db.cards[fil._planId].client\n                ))\n                    return true\n            }).map(res => res)\n        } else {\n            filtered = filtered.filter(fil => {\n                let result = false\n                Object.keys(db.cards).filter(plan => {\n                    if (db.cards[plan].client && search.units.selected[db.cards[plan].client])\n                        return true\n                }).map(plan => {\n                    if (fil._planId && fil._planId === db.cards[plan]._id)\n                        result = true\n                })\n                return result\n            }).map(res => res)\n        }\n    }\n\n    if (Object.keys(search.groups.selected).length > 0) {\n        if (search.groups.selected['unassigned']) {\n            filtered = filtered.filter(fil => {\n                if (!fil._planId || (\n                    fil._planId\n                    && db.cards[fil._planId]\n                    && !db.cards[fil._planId].client\n                ))\n                    return true\n            }).map(res => res)\n        } else {\n            filtered = filtered.filter(fil => {\n                let result = false\n                Object.keys(db.cards).filter(plan => {\n                    if (db.cards[plan].client && search.groups.selected[db.cards[plan].client])\n                        return true\n                }).map(plan => {\n                    if (fil._planId && fil._planId === db.cards[plan]._id)\n                        result = true\n                })\n                return result\n            }).map(res => res)\n        }\n    }\n\n    if (Object.keys(search.plans.selected).filter(a => a).length > 0) {\n        filtered = filtered.filter(fil => {\n            if (search.plans.selected[fil._planId]) return true\n        }).map(res => res)\n    }\n\n    if (search.tags.length > 0) {\n        filtered = filtered.filter(fil =>\n            fil._tags && fil._tags.length > 0 && fil._tags.filter(tag => {\n                let result = false\n                search.tags.map(tagFilter => {\n                    if (tagFilter.value === tag.value)\n                        result = true\n                })\n                return result\n            }\n            ).length > 0\n        ).map(res => res)\n    }\n\n    let subtractDays = String(session.dashboard.period).replace('$__last', '')\n    subtractDays = subtractDays.replace('Days', '')\n\n    const startDate = moment(new Date()).tz('America/Sao_Paulo').subtract(parseInt(subtractDays), 'd').format('YYYY-MM-DDT00:00')\n    const endDate = moment(new Date()).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59')\n\n    if (props && props.periodFilter)\n        filtered = filtered.filter(fil => {\n            if (\n                (fil.status === 'completed'\n                    && fil.completed_at\n                    && (\n                        (fil.completed_at.low\n                            && moment(new Date(fil.completed_at.low * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59') <= endDate\n                            && moment(new Date(fil.completed_at.low * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT00:00') >= startDate)\n                        || (fil.completed_at && !fil.completed_at.low\n                            && moment(new Date(fil.completed_at * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59') <= endDate\n                            && moment(new Date(fil.completed_at * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT00:00') >= startDate)\n                    )\n                )\n                ||\n                (\n                    fil.status !== 'completed'\n                    && fil.updated_at\n                    && (\n                        (fil.updated_at.low\n                            && moment(new Date(fil.updated_at.low * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59') <= endDate\n                            && moment(new Date(fil.updated_at.low * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT00:00') >= startDate)\n                        || (fil.updated_at && !fil.updated_at.low\n                            && moment(new Date(fil.updated_at * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59') <= endDate\n                            && moment(new Date(fil.updated_at * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT00:00') >= startDate)\n                    )\n                )\n            )\n                return true\n        }\n        ).map(res => res)\n\n    if (!props.showDeleted && !reduxStore.getState().controls.deleted) {\n        filtered = filtered.filter(fil => !fil.deleted).map(res => res)\n    }\n\n    // if (props.orderByTitle)\n    //     filtered = filtered.sort((a, b) => {\n    //         let orderA = props.orderByTitlePosition === \"ASC\" ? a?.name?.toLowerCase()?.trim() : b?.name?.toLowerCase()?.trim()\n    //         let orderB = props.orderByTitlePosition === \"ASC\" ? b?.name?.toLowerCase()?.trim() : a?.name?.toLowerCase()?.trim()\n\n    //         if (props.groupByColor) {\n    //             if (a && a._parent && a._parent !== hashs[0]) {\n    //                 let ac = getCardColor(a) || { color: \"rgba(255, 255, 255, 1)\" }\n    //                 if (!ac.parentId && a._parent) {\n    //                     ac.parentId = a._parent\n    //                 }\n    //                 if (ac.parentId && reduxStore.getState().db.cards[ac.parentId])\n    //                     orderA = `${reduxStore.getState().db.cards[ac.parentId].name.toLowerCase().trim()} - ${a.name.toLowerCase().trim()}`\n    //             }\n    //             if (b && b._parent && b._parent !== hashs[0]) {\n    //                 let bc = getCardColor(b) || { color: \"rgba(255, 255, 255, 1)\" }\n    //                 if (!bc.parentId && b._parent) {\n    //                     bc.parentId = b._parent\n    //                 }\n    //                 if (bc.parentId && reduxStore.getState().db.cards[bc.parentId])\n    //                     orderB = `${reduxStore.getState().db.cards[bc.parentId].name.toLowerCase().trim()} - ${b.name.toLowerCase().trim()}`\n    //             }\n    //         }\n    //         // if (a.type.indexOf(\"guideline\") > -1)\n    //         //     console.log(orderA)\n    //         if (orderA < orderB)\n    //             return -1\n    //         if (orderA > orderB)\n    //             return 1\n    //         return 0\n    //     }).map(res => res)\n\n    // if (!props.orderByTitle)\n    filtered = filtered.sort((a, b) => {\n        let orderA = a?.order?.low || !isNaN(a?.order) ? parseInt(a.order) : String(a.order) ? parseInt(a.order) : 0\n        let orderB = b?.order?.low || !isNaN(b?.order) ? parseInt(b.order) : String(b.order) ? parseInt(b.order) : 0\n\n        if (props.agileOrderBy === 'name') {\n            orderA = a.name.trim().toLowerCase()\n            orderB = b.name.trim().toLowerCase()\n        }\n\n        if (props.agileOrderBy === 'startDate') {\n            orderA = a.startDate ? `${props.agileOrderDesc === 'ASC' ? `Z` : `A`}${String(a.startDate)}` : `${props.agileOrderDesc === 'ASC' ? `A` : `Z`}-${a.name}`\n            orderB = b.startDate ? `${props.agileOrderDesc === 'ASC' ? `Z` : `A`}${String(b.startDate)}` : `${props.agileOrderDesc === 'ASC' ? `A` : `Z`}-${b.name}`\n        }\n\n        if (props.agileOrderBy === 'endDate') {\n            orderA = a.endDate ? `${props.agileOrderDesc === 'ASC' ? `Z` : `A`}${String(a.endDate)}` : `${props.agileOrderDesc === 'ASC' ? `A` : `Z`}-${a.name}`\n            orderB = b.endDate ? `${props.agileOrderDesc === 'ASC' ? `Z` : `A`}${String(b.endDate)}` : `${props.agileOrderDesc === 'ASC' ? `A` : `Z`}-${b.name}`\n        }\n\n        if (props.groupByColor) {\n            if (a && a._parent && a._parent !== hashs[0]) {\n                let ac = getCardColor(a) || { color: \"rgba(255, 255, 255, 1)\" }\n                if (!ac.parentId && a._parent) {\n                    ac.parentId = a._parent\n                }\n                if (ac.parentId && reduxStore.getState().db.cards[ac.parentId]) {\n                    let orderAN = 0\n                    if (reduxStore.getState().db.cards[ac.parentId].order && typeof (reduxStore.getState().db.cards[ac.parentId].order) === 'string')\n                        orderAN = reduxStore.getState().db.cards[ac.parentId].order\n                    if (reduxStore.getState().db.cards[ac.parentId].order && typeof (reduxStore.getState().db.cards[ac.parentId].order) === 'object')\n                        orderAN = reduxStore.getState().db.cards[ac.parentId].order.low\n\n                    for (var i = String(orderAN).length; i < 10; i++) {\n                        orderAN = `0${orderAN}`\n                    }\n\n                    let orderAN2 = typeof (a.order) === 'object' ? String(a.order.low) : String(a.order || 0)\n                    for (var i = String(orderAN2).length; i < 10; i++) {\n                        orderAN2 = `0${orderAN2}`\n                    }\n\n                    orderA = `${orderAN}-${orderA}`\n                }\n            }\n            if (b && b._parent && b._parent !== hashs[0]) {\n                let bc = getCardColor(b) || { color: \"rgba(255, 255, 255, 1)\" }\n                if (!bc.parentId && b._parent) {\n                    bc.parentId = b._parent\n                }\n                if (bc.parentId && reduxStore.getState().db.cards[bc.parentId]) {\n                    let orderBN = 0\n                    if (reduxStore.getState().db.cards[bc.parentId].order && typeof (reduxStore.getState().db.cards[bc.parentId].order) === 'string')\n                        orderBN = reduxStore.getState().db.cards[bc.parentId].order\n                    if (reduxStore.getState().db.cards[bc.parentId].order && typeof (reduxStore.getState().db.cards[bc.parentId].order) === 'object')\n                        orderBN = reduxStore.getState().db.cards[bc.parentId].order.low\n\n                    for (var i = String(orderBN).length; i < 10; i++) {\n                        orderBN = `0${orderBN}`\n                    }\n\n                    let orderBN2 = typeof (b.order) === 'object' ? String(b.order.low) : String(b.order || 0)\n                    for (var i = String(orderBN2).length; i < 10; i++) {\n                        orderBN2 = `0${orderBN2}`\n                    }\n\n                    orderB = `${orderBN}-${orderB}`\n                }\n            }\n\n        }\n\n        if (props.agileOrderDesc === 'DESC') {\n            if (orderA < orderB)\n                return -1\n            if (orderA > orderB)\n                return 1\n        }\n        if (props.agileOrderDesc === 'ASC') {\n            if (orderA > orderB)\n                return -1\n            if (orderA < orderB)\n                return 1\n        }\n        return 0\n    }).map(res => res)\n\n\n    const addCard = async () => {\n        const { socket } = reduxStore.getState().functions\n        let idParent = props.selectedParent ? props.selectedParent : hashs[0] ? hashs[0] : null\n        let parent = idParent && reduxStore.getState().db.cards[idParent] ? reduxStore.getState().db.cards[idParent] : {}\n        socket.emit(\"data\", {\n            module: \"cards\",\n            method: \"post\",\n            action: \"add\"\n        }, {\n            _parent: props.selectedParent ? props.selectedParent : hashs[0] ? hashs[0] : null,\n            _planId: hashs[0] && hashs[0].length === 36 ? hashs[0] : null,\n            name,\n            type: props.typeAdd ? props.typeAdd : props.columnId.length < 36 ? props.columnId : null,\n            status: 'notStarted',\n            ...(parent.childrenAutoTag && parent._tags && parent._tags.length > 0) ? {\n                _tags: parent._tags\n            } : {}\n        })\n        setName('')\n    }\n    let columnName = translate(props.column.name, 1)\n    let columnIcon = null\n    let customColumns = {}\n    if (reduxStore.getState().db.cards[hashs[0]] && reduxStore.getState().db.cards[hashs[0]].customColumns)\n        customColumns = JSON.parse(reduxStore.getState().db.cards[hashs[0]].customColumns)\n\n    if (\n        customColumns\n        && customColumns[props.column.name.replace(\"$__\", \"\")]\n        && customColumns[props.column.name.replace(\"$__\", \"\")].name\n    )\n        columnName = translate(customColumns[props.column.name.replace(\"$__\", \"\")].name, 1)\n\n    if (\n        customColumns\n        && customColumns[props.column.name.replace(\"$__\", \"\")]\n        && customColumns[props.column.name.replace(\"$__\", \"\")].icon\n    )\n        columnIcon = translate(customColumns[props.column.name.replace(\"$__\", \"\")].icon, 1)\n\n\n    let cardbyGroup = []\n\n\n    //INI VIRTUALIZED\n    function Row({ index, style }) {\n        const card = filtered[index]\n        let separatorTitle = ``\n        let separatorColor = ``\n        if (props.groupByColor && !card.color) {\n\n            let a = getCardColor(card)\n            if (!a.parentId && card._parent && card._parent !== hashs[0]) {\n                a.parentId = card._parent\n            }\n            if (a && a.parentId && cardbyGroup.indexOf(a.parentId) === -1 && reduxStore.getState().db.cards[a.parentId]) {\n                separatorTitle = reduxStore.getState().db.cards[a.parentId].name\n                separatorColor = a.color\n                cardbyGroup.push(a.parentId)\n                separators.current = {\n                    ...separators.current,\n                    [`${card._id}_${index}`]: {\n                        title: reduxStore.getState().db.cards[a.parentId].name,\n                        color: a.color || \"#FFFFFF\"\n                    }\n                }\n            }\n\n        }\n\n        return (\n            <React.Fragment>\n                <Draggable\n                    draggableId={card._id}\n                    index={index}\n                    key={card._id}\n                    isDragDisable={props.isDragDisable || false}\n                >\n                    {(provided, snapshot) => (\n                        <div style={style}>\n                            {props.groupByColor && separators.current[`${card._id}_${index}`] ?\n                                <div style={{\n                                    width: \"100%\",\n                                    padding: 3,\n                                    color: \"gray\",\n                                    marginTop: 17,\n                                    borderBottom: `solid 3px ${separators.current[`${card._id}_${index}`]?.color || ``}`\n                                }}>{separators.current[`${card._id}_${index}`].title}</div>\n                                : <React.Fragment></React.Fragment>\n                            }\n                            <Item\n                                separator={props.groupByColor && separatorTitle ? { title: separatorTitle, color: separatorColor } : null}\n                                provided={provided}\n                                isDragging={snapshot?.isDragging}\n                                index={index}\n                                snapshot={snapshot}\n                            // style={style}\n                            />\n                        </div>\n                    )}\n                </Draggable>\n            </React.Fragment>\n        )\n    }\n\n    function Item({ provided, index, snapshot }) {\n        let card = filtered[index]\n        return (\n            <div\n                {...provided.draggableProps}\n                {...provided.dragHandleProps}\n                ref={provided.innerRef}\n            >\n                <Card\n                    separator={props.groupByColor && separators?.current[`${card._id}_${index}`]?.title ? separators?.current[`${card._id}_${index}`] : null}\n                    data={card}\n                    db={props.db}\n                    showOrder={props.showOrder || false}\n                    showSelected={props.showSelected || false}\n                    locked={props.locked || false}\n                    viewButton={props.viewButton || false}\n                    showConnectedIn={props.showConnectedIn ? true : false}\n                    isDragging={snapshot.isDragging && !snapshot.isDropAnimating}\n                    snapshot={snapshot}\n                    cardColorPicker={props.cardColorPicker ? true : false}\n                    manualExpanded={rowExpandeds?.current[`${card._id}_${index}`] || false}\n                    onResize={(size) => {\n                        setRowHeight(`${card._id}_${index}`, size)\n                    }}\n                    onExpand={(expanded) => {\n                        if ((!rowExpandeds.current[`${card._id}_${index}`] && expanded) || (String(expanded) === \"false\" && rowExpandeds.current[`${card._id}_${index}`]))\n                            setRowExpanded(`${card._id}_${index}`, expanded)\n                    }}\n                />\n            </div>\n        );\n    }\n\n    function getRowHeight(index) {\n        let card = filtered[index]\n        return rowHeights.current[`${card._id}_${index}`] + 7 || 67;\n    }\n\n    function setRowHeight(index, size) {\n        if (listRef?.current?.resetAfterIndex)\n            listRef.current.resetAfterIndex(0);\n        rowHeights.current = {\n            ...rowHeights.current, [index]: size\n        }\n    }\n\n    function setRowExpanded(index, expanded) {\n        if (listRef?.current?.resetAfterIndex)\n            listRef.current.resetAfterIndex(0);\n\n        rowExpandeds.current = {\n            ...rowExpandeds.current, [index]: expanded\n        }\n    }\n\n    return (\n        <Draggable draggableId={props.columnId ? String(props.columnId) : 'NOT_ID_SENDED'} index={props.index} >\n            {provided => (\n                <Container\n                    {...!props.isDropDisabled && provided.draggableProps}\n                    {...props}\n                    ref={provided.innerRef}\n                >\n                    <div {...provided.draggableProps}{...provided.dragHandleProps} style={{ display: 'none' }}></div>\n                    <div {...!props.isDropDisabled && provided.dragHandleProps}>\n                        <HeaderWithIcon\n                            title={columnName}\n                            icon={columnIcon || props.column.icon || \"topic\"}\n                            color={customApp('menu')}\n                            style={{\n                                padding: '7px'\n                            }}\n                            {...hashs.length > 0\n                                && hashs[1]\n                                && hashs[1] === 'overview'\n                                && reduxStore.getState().db.cards[hashs[0]]\n                                && reduxStore.getState().db.cards[hashs[0]].planType\n                                && reduxStore.getState().db.cards[hashs[0]].planType === 'flow'\n                                && reduxStore.getState().db.cards[hashs[0]]._users\n                                && reduxStore.getState().db.cards[hashs[0]]._users[session._id]\n                                && reduxStore.getState().db.cards[hashs[0]]._users[session._id].access\n                                && parseInt(reduxStore.getState().db.cards[hashs[0]]._users[session._id].access) > 3\n                                ? {\n                                    permitIcon: true,\n                                    editable: true,\n                                    onEdit: (x) => {\n                                        updateCardData(\n                                            {\n                                                ...props,\n                                                data: { _id: hashs[0] }\n                                            }, {\n                                            customColumns: JSON.stringify({\n                                                ...reduxStore.getState().db.cards[hashs[0]] && reduxStore.getState().db.cards[hashs[0]].customColumns ? JSON.parse(reduxStore.getState().db.cards[hashs[0]].customColumns) : {},\n                                                [props.column.name.replace(\"$__\", \"\")]: x\n                                            })\n                                        })\n                                    },\n                                    placeholder: translate(\"$__columnName\")\n                                } : {}}\n                            customButtons={[\n                                props.columnsSettings &&\n                                {\n                                    name: \"settings\",\n                                    icon: \"more_horiz\",\n                                    color: customApp('color'),\n                                    onClick: () => console.log('s'),\n                                    show: 'hover'\n                                },\n                            ]}\n\n                            periodFilter={props && props.periodFilter ? true : false}\n                        />\n                    </div>\n                    <Droppable\n                        droppableId={props.columnId ? String(props.columnId) : 'NOT_ID_SENDED'}\n                        type=\"card\"\n                        isDropDisabled={props.column.isDropDisabled}\n                        direction={`${props.inLine ? 'horizontal' : 'vertical'}`}\n                        isCombineEnabled={props.isCombineEnabled}\n                        mode={\"virtual\"}\n                        renderClone={(provided, snapshot, rubric) => {\n                            return (\n                                <Item\n                                    provided={provided}\n                                    isDragging={snapshot?.isDragging}\n                                    index={rubric.source.index}\n                                    snapshot={snapshot}\n                                    style={{ margin: 0 }}\n                                />\n                            )\n                        }}\n                    >\n                        {(provided) => (\n                            <div\n                                ref={provided.innerRef}\n                                style={{\n                                    width: \"100%\",\n                                    height: props.inLineAdd ? add ? \"calc(100% - 80px)\" : \"calc(100% - 60px)\" : \"calc(100% - 10px)\"\n                                }}\n                            >\n                                <AutoSizer style={{\n                                    width: \"100%\",\n                                    height: \"100%\"\n                                }}\n                                >\n                                    {({ height, width }) => (\n                                        <List\n                                            className=\"List\"\n                                            height={height}\n                                            width={width}\n                                            ref={listRef}\n                                            itemCount={filtered.length}\n                                            itemSize={getRowHeight}\n                                            outerRef={provided.innerRef}\n                                            // overscanCount={15}\n                                            itemData={filtered}\n                                            style={{\n                                                height: \"100%\"\n                                            }}\n                                        >\n                                            {Row}\n                                        </List>\n                                    )}\n                                </AutoSizer>\n                            </div>\n                        )}\n                    </Droppable>\n                    {props.inLineAdd && !add &&\n                        <div style={{ position: 'relative', float: 'left', width: '100%', padding: '7px' }}>\n                            <IconButton\n                                text={translate(\"$__add\", '*')}\n                                icon=\"add_box\"\n                                iconColor={customApp('medium')}\n                                onClick={() => {\n                                    setAdd(!add);\n                                }}\n                            />\n                        </div>\n                    }\n                    {props.inLineAdd && add &&\n                        <div className={classes.cardAdd} style={{ position: 'relative', float: 'left', width: '100%', padding: '7px', display: 'flex', alignItems: 'center' }}>\n                            <div style={{ width: 'calc(100% - 50px)', display: 'flex' }}>\n                                <TextField\n                                    label={translate('$__nameOfCard')}\n                                    variant={customApp('fieldVariant')}\n                                    name={'name'}\n                                    InputLabelProps={{\n                                        shrink: true,\n                                    }}\n                                    InputProps={{\n                                        autoComplete: 'new-password',\n                                        onChange: (d) => {\n                                            setName(d.target.value)\n                                        },\n                                        onBlur: (d) => {\n                                            if (d.target.value === '')\n                                                setAdd(!add)\n                                        },\n                                        onKeyDown: (e) => {\n                                            if (e.keyCode === 13 && name)\n                                                addCard()\n                                            if (e.keyCode === 27) {\n                                                setAdd(!add)\n                                                setName('')\n                                            }\n                                        }\n                                    }}\n                                    autoFocus\n                                    value={name}\n                                    placeholder={translate('$__titleOfCard_placeholder')}\n                                />\n                            </div>\n                            <div style={{ display: 'flex' }}>\n                                <div className={classes.button}\n                                    onClick={() => addCard()}\n                                >\n                                    <Icon color='green' icon={'save'} title={translate('$__save', '*')} size={props.actionsSize || '25px'} />\n                                </div>\n                                <div className={classes.button}\n                                    onClick={() => {\n                                        setAdd(!add)\n                                        setName('')\n                                    }}\n                                >\n                                    <Icon color={customApp('medium')} icon={'cancel'} title={translate(\"$__cancel\", \"*\")} size={props.actionsSize || '25px'} />\n                                </div>\n                            </div>\n                        </div>\n                    }\n                </Container>\n            )\n            }\n        </Draggable>\n    )\n}\n\nconst Container = styled.div`\n    margin:0 7px;\n    min-width:180px;\n    ${props => props.columnStyle && props.columnStyle.width ? `width:calc(${props.columnStyle.width} - 14px);` : `width:calc(100% - 14px);`}\n    @media(min-width: 960px) {\n        position:relative;\n        max-height:${props => props.columnStyle && props.columnStyle.maxHeight ? props.columnStyle.maxHeight : 'calc(100% - 0px)'};\n       \n        ${props => props.inLine\n        ? `display:block;\n           `\n        : `margin-bottom:0px !important;\n            ${props => props.columnStyle && props.columnStyle.width ? `width:${props.columnStyle.width};` : `width:100%;`}\n                `\n    }\n      }\n    @media(max-width: 959px) {\n        float:left;\n        position: relative;\n      }\n      @media(max-width: 599px) {\n        float:left;\n        position: relative;\n      }\n    `\n\n\nconst CardList = styled.div`\nposition:relative;\nheight:100%;\nwidth:100%;\nmax-height:${props => props.columnStyle && props.columnStyle.maxHeight ? props.columnStyle.maxHeight : 'calc(100% - 30px)'};\n${props => props.columnStyle && props.columnStyle.maxWidth ? props.columnStyle.maxWidth : '250px'};\n ${props =>\n        props.isDraggingOver\n            ? `background-color:${customApp('color')}; opacity:0.5;`\n            : ''};\n${props =>\n        props.inLine ? `\n                display:table;\n                margin-bottom:33px`\n            : `display:block;\n                min-height: 150px !important;\n                padding-bottom:15px;\n                overflow-y: auto;\n                `\n    }\n`;\n\n//REACT\nconst mapStateToProps = (store) => ({\n    search: store.search,\n    dbCards: store.db.cards,\n    agileOrderBy: store.controls.agileOrderBy,\n    agileOrderDesc: store.controls.agileOrderDesc,\n    groupByColor: store.db.groupByColor,\n    orderByTitle: store.db.orderByTitle,\n    orderByTitlePosition: store.db.orderByTitlePosition,\n    cardsExpanded: store.db.cardsExpanded,\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(memo(Column)));","import React from \"react\";\r\nimport { DragDropContext, Droppable } from \"react-beautiful-dnd\";\r\nimport styled from \"styled-components\";\r\nimport moment from \"moment-timezone\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store\";\r\n\r\n//DEPENDENCIES\r\nimport Column from \"./Column\";\r\n\r\nfunction App(props) {\r\n    const { db } = reduxStore.getState()\r\n\r\n    React.useEffect(() => {\r\n\r\n    }, [])\r\n\r\n    const onDragEnd = async result => {\r\n        const { socket } = reduxStore.getState().functions\r\n        const { destination, source, draggableId } = result\r\n        let newCardsOrder = db.cards\r\n        if (result.combine) {\r\n            return;\r\n        }\r\n\r\n\r\n        if (!destination) return false\r\n\r\n        if (destination.droppableId === source.droppableId && destination.id === source.index) return false\r\n\r\n        const sourceColumn = source.droppableId\r\n        const destinationColumn = destination.droppableId\r\n\r\n        const sourceCardIds = Array.from(props.cards.filter(c => c.status === sourceColumn).sort((a, b) => {\r\n            if (a.order && b.order && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low))\r\n                return -1\r\n            return 1\r\n        }\r\n        ).map(a => a._id))\r\n\r\n        //When move Card in single Column\r\n\r\n        if (sourceColumn === destinationColumn && !reduxStore.getState().db.orderByTitle) {\r\n            const newCardsIds = Array.from(props.cards.filter(c => c.status === sourceColumn).sort((a, b) => {\r\n                if (a.order && b.order && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low))\r\n                    return -1\r\n                return 1\r\n            }\r\n            ).map(a => a._id))\r\n\r\n            newCardsIds.splice(source.index, 1)\r\n            newCardsIds.splice(destination.index, 0, draggableId)\r\n            newCardsIds.map((card, i) => {\r\n                newCardsOrder[card] = {\r\n                    ...newCardsOrder[card],\r\n                    order: {\r\n                        low: i\r\n                    }\r\n                }\r\n            })\r\n\r\n            const newState = {\r\n                ...reduxStore.getState().db,\r\n                cards: {\r\n                    ...db.cards,\r\n                    ...newCardsOrder,\r\n                }\r\n            }\r\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                ...newState,\r\n            });\r\n\r\n            socket.emit(\"data\", {\r\n                module: \"cards\",\r\n                method: \"put\",\r\n                action: \"inColumn\",\r\n            }, {\r\n                node: draggableId,\r\n                source: source.droppableId,\r\n                destination: destination.droppableId,\r\n                destinationCards: newCardsIds,\r\n                sourceCards: [],\r\n                columnName: 'status',\r\n            })\r\n            return\r\n        }\r\n\r\n        //When move Card in mult Column\r\n        sourceCardIds.splice(source.index, 1)\r\n\r\n        const destinationCardIds = Array.from(props.cards.filter(c => c.status === destinationColumn).sort((a, b) => {\r\n            if (a.order && b.order && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low))\r\n                return -1\r\n            return 1\r\n        }\r\n        ).map(a => a._id))\r\n        destinationCardIds.splice(destination.index, 0, draggableId)\r\n\r\n        sourceCardIds.map((a, i) => {\r\n            if (!db.cards[a].order || !db.cards[a].order.low) {\r\n                db.cards[a] = {\r\n                    ...db.cards[a],\r\n                    ['order']: {\r\n                        ['low']: parseInt(i)\r\n                    }\r\n                }\r\n            } else {\r\n                db.cards[a].order.low = parseInt(i)\r\n            }\r\n        })\r\n\r\n        destinationCardIds.map((a, i) => {\r\n            if (!db.cards[a].order || !db.cards[a].order.low) {\r\n                db.cards[a] = {\r\n                    ...db.cards[a],\r\n                    ['order']: {\r\n                        ['low']: parseInt(i)\r\n                    }\r\n                }\r\n            } else {\r\n                db.cards[a].order.low = parseInt(i)\r\n            }\r\n        })\r\n\r\n        const newState = {\r\n            ...db,\r\n            cards: {\r\n                ...db.cards,\r\n                [draggableId]: {\r\n                    ...db.cards[draggableId],\r\n                    status: destinationColumn,\r\n                    completed_at: destinationColumn === 'completed' ? {\r\n                        low: moment().tz('America/Sao_Paulo').unix('x'),\r\n                    } : null,\r\n                    updated_at: {\r\n                        low: moment().tz('America/Sao_Paulo').unix('x'),\r\n                    },\r\n                    order: {\r\n                        low: destination.index\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...newState,\r\n        });\r\n\r\n        socket.emit(\"data\", {\r\n            module: \"cards\",\r\n            method: \"put\",\r\n            action: \"inColumn\",\r\n        }, {\r\n            node: draggableId,\r\n            source: source.droppableId,\r\n            destination: destination.droppableId,\r\n            destinationCards: destinationCardIds,\r\n            columnName: 'status',\r\n            sourceCards: sourceCardIds,\r\n        })\r\n\r\n    }\r\n    const onDragStart = async result => {\r\n    }\r\n    const onDragUpdate = async result => {\r\n    }\r\n\r\n    return (\r\n        <DragDropContext\r\n            onDragEnd={onDragEnd}\r\n            onDragStart={onDragStart}\r\n            onDragUpdate={onDragUpdate}\r\n        >\r\n            <Droppable\r\n                droppableId=\"ALL-COLUMNS-STATUS\"\r\n                type=\"column\"\r\n                direction={`${props.inLine ? 'vertical' : 'horizontal'}`}\r\n                isDropDisabled={true}\r\n            >\r\n                {provided => (\r\n                    <Container\r\n                        {...props}\r\n                        ref={provided.innerRef}\r\n                    >\r\n                        {reduxStore.getState().db.status.map((st, index) => {\r\n                            const theColumn = {\r\n                                name: st.label,\r\n                                icon: st.icon,\r\n                                cards: [],\r\n                                emptyHide: false,\r\n                            }\r\n                            return <Column\r\n                                {...props}\r\n                                key={`${st.value}`}\r\n                                columnId={`${st.value}`}\r\n                                isDropDisabled\r\n                                column={theColumn}\r\n                                cards={props.cards.filter(c => c.status === st.value || (st.value === 'notStarted' && !c.status)).map(a => {\r\n                                    return {\r\n                                        ...a,\r\n                                        id: a._id\r\n                                    }\r\n                                })}\r\n                                index={index}\r\n                                columnsSettings={false}\r\n                                locked={false}\r\n                                columnStyle={{\r\n                                    flex: index,\r\n                                    width: \"25%\",\r\n                                    ...props.columnStyle ? props.columnStyle : {}\r\n\r\n                                }}\r\n                                viewButton={props.viewButton || false}\r\n                                periodFilter={st.props && st.props.periodFilter ? true : false}\r\n                            />\r\n                        })}\r\n                        {provided.placeholder}\r\n                        <div style={{ clear: 'both' }}></div>\r\n                    </Container>\r\n                )}\r\n            </Droppable>\r\n        </DragDropContext>\r\n    )\r\n}\r\n\r\n//STYLEDS\r\nconst Container = styled.div`\r\nheight:100%;\r\n${props =>\r\n        props.inLine ?\r\n            `display: block;\r\n                width: -webkit-fill-available;\r\n                position:relative;\r\n                ${props.style}`\r\n            :\r\n            `   display: flex;\r\n                width: 100%;\r\n                ${props.style}\r\n                @media(min-width: 960px) {\r\n                    display: flex;\r\n                }\r\n                `\r\n    }\r\n    @media(max-width: 959px) {\r\n        display: contents !important;\r\n        width: -webkit-fill-available;\r\n        height:auto;\r\n      }\r\n    `\r\n\r\n//REACT\r\nconst mapStateToProps = (store, props) => ({})\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch);\r\n\r\nexport default connect(\r\n    mapStateToProps,\r\n    mapDispatchToProps\r\n)(App);","//CORE\r\nimport React from \"react\"\r\nimport moment from \"moment-timezone\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\nimport history from \"store/history\"\r\n\r\n//COMPONENTS\r\nimport AgileStatus from \"components/AgileV2/status\"\r\nimport FilterHeader from \"components/Filter/header\"\r\nimport HeaderWithIcon from \"components/Header/withIcon\"\r\nimport CardsLoader from \"components/Card/loader\"\r\n\r\n//FUNCTIONS\r\nimport { translate, customApp, getAppAccess } from \"functions/\"\r\nimport { countNotifications } from \"functions/cards\"\r\n\r\nfunction Component(props) {\r\n    const { db, session, search } = reduxStore.getState()\r\n    const { dataType } = db\r\n    // const [cards, setCards] = React.useState([])\r\n    const [mounted, setMounted] = React.useState(false)\r\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD')\r\n    const timeNow = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD')\r\n\r\n    let AppAccess = getAppAccess()\r\n    let title = 'myTasks'\r\n\r\n    let hashs = window.location.hash.split('/')\r\n    hashs[0] = hashs[0].replace('#', '')\r\n\r\n    React.useEffect(() => {\r\n        if (!mounted) {\r\n            setMounted(true)\r\n        }\r\n    }, [db.cards, search, db.users])\r\n\r\n    if (!window.location.hash.split('/')[0].replace('#', '')) {\r\n        history.push('t#tab/myTasks')\r\n    }\r\n\r\n    if (!db.cards)\r\n        return (null)\r\n\r\n    let myCards = Object.keys(props.cards).filter(a =>\r\n        props.cards[a]\r\n        && props.cards[a].type !== 'chatGroup'\r\n        && props.cards[a].type !== 'plan'\r\n        && props.cards[a].type !== 'step'\r\n        && props.cards[a].type !== 'link'\r\n        && props.cards[a].type !== 'insight'\r\n        && dataType.filter(dt => dt.name === props.cards[a].type).length > 0\r\n        &&\r\n        (\r\n            !props.cards[a].checklist\r\n            ||\r\n            (\r\n                props.cards[a].checklist\r\n                && props.cards[a].showCard\r\n            )\r\n        )\r\n        && !props.cards[a].deleted\r\n    ).map(c => props.cards[c])\r\n\r\n    if (!reduxStore.getState().session.cards.adminView) {\r\n        myCards = myCards.filter(c => {\r\n            if (c._users && Object.keys(c._users).filter(u => u === session._id).length > 0)\r\n                return true\r\n        })\r\n    } else {\r\n        myCards = myCards.filter(c => {\r\n            if (\r\n                !c.private\r\n                || (\r\n                    c.private\r\n                    && c._users\r\n                    && Object.keys(c._users).filter(u => u === session._id).length > 0\r\n\r\n                )\r\n            )\r\n                return true\r\n        })\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n    if (hashs[1] && hashs[1] === 'allTasks') {\r\n        myCards = myCards.filter(c =>\r\n            dataType.filter(dt => dt.name === c.type)[0].myTasks\r\n            && c.type !== 'objective'\r\n            && c.type !== 'goal'\r\n            && c.type !== 'plan'\r\n            && c.type.indexOf('guideline') === -1\r\n        )\r\n        title = 'allTasks'\r\n    }\r\n    if (hashs[1] && hashs[1] === 'myTasks') {\r\n        myCards = myCards.filter(c =>\r\n            dataType.filter(dt => dt.name === c.type)[0].myTasks\r\n            && c.type !== 'objective'\r\n            && c.type !== 'goal'\r\n            && c.type !== 'plan'\r\n            && c.type.indexOf('guideline') === -1\r\n            && c._users\r\n            && Object.keys(c._users).filter(u => u === session._id && c._users[u].isResponsible).length > 0\r\n        )\r\n        title = 'myTasks'\r\n    }\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'planningCards') {\r\n        myCards = myCards.filter(c =>\r\n            dataType.filter(dt => dt.name === c.type)[0].myTasks\r\n            && c.type !== 'objective'\r\n            && c.type !== 'goal'\r\n            && c.type !== 'plan'\r\n            && c.type.indexOf('guideline') === -1\r\n            && c._planId\r\n        )\r\n        title = 'planningCards'\r\n    }\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'guidelines') {\r\n        myCards = myCards.filter(c => {\r\n            if (c.type.indexOf('guideline') > -1)\r\n                return true\r\n        }\r\n        )\r\n        title = 'guidelines'\r\n    }\r\n\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'unreaded') {\r\n        myCards = myCards.filter(c => {\r\n            let notifications = countNotifications(c._id)\r\n            if (notifications.total > 0) return true\r\n        }\r\n        )\r\n        title = 'unreaded'\r\n    }\r\n\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'objectives') {\r\n        myCards = myCards.filter(c => c.type === 'objective')\r\n        title = 'objectives'\r\n    }\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'goals') {\r\n        myCards = myCards.filter(c => c.type === 'goal')\r\n        title = 'goals'\r\n    }\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'myDay') {\r\n        myCards = myCards.filter(a =>\r\n            a._users\r\n            && a._users[session._id]\r\n            && a._users[session._id].myDay\r\n            && (moment(new Date(a._users[session._id].myDay * 1000)).tz('America/Sao_Paulo').format('YYYY/MM/DD') === today\r\n            )\r\n        ).map(a => a)\r\n        title = 'myDay'\r\n    }\r\n    if (hashs[0] === 'tab' && hashs[1] === 'ourDay') {\r\n        myCards = myCards.filter(a => {\r\n            if (a && a._users) {\r\n                let result = Object.keys(a._users).filter(us =>\r\n                    us && a._users[us] && a._users[us].myDay && (moment(new Date(a._users[us].myDay * 1000)).tz('America/Sao_Paulo').format('YYYY/MM/DD') === today)\r\n                )\r\n                if (result.length > 0)\r\n                    return true\r\n                return false\r\n            } else {\r\n                return false\r\n            }\r\n        }\r\n        ).map(a => a)\r\n        title = 'ourDay'\r\n    }\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'private') {\r\n        myCards = myCards.filter(c =>\r\n            c.private\r\n        ).map(a => a)\r\n        title = 'nextTasks'\r\n    }\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'nextTasks') {\r\n        myCards = myCards.filter(a =>\r\n        (\r\n            (a.endDate\r\n                && moment(new Date(a.endDate * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") >= moment().format(\"YYYY-MM-DD\")\r\n                && moment(new Date(a.endDate * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") <= moment(new Date(today)).add(10, \"days\").format(\"YYYY-MM-DD\")\r\n            )\r\n            ||\r\n            (a.startDate\r\n                && moment(new Date(a.startDate * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") >= moment().format(\"YYYY-MM-DD\")\r\n                && moment(new Date(a.startDate * 1000)).tz(\"America/Sao_Paulo\").format(\"YYYY-MM-DD\") <= moment(new Date(today)).add(10, \"days\").format(\"YYYY-MM-DD\")\r\n            )\r\n        )\r\n        ).map(a => a)\r\n        title = 'nextTasks'\r\n    }\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'lateTasks') {\r\n        myCards = myCards.filter(c =>\r\n            c.endDate && moment(new Date(c.endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format() && c.status !== 'completed'\r\n        ).map(a => a)\r\n        title = 'lateTasks'\r\n    }\r\n\r\n    if (hashs[0] === 'tab' && hashs[1] === 'unlinkedCards') {\r\n        myCards = myCards.filter(c =>\r\n            !c.parent && !c._parent\r\n        ).map(a => a)\r\n        title = 'lateTasks'\r\n    }\r\n\r\n    return (\r\n        <div style={props.expanded ? { width: 'calc(100% - 220px)', marginLeft: '220px' } : { width: 'calc(100% - 0px)', marginLeft: '0px' }}>\r\n            <CardsLoader />\r\n            <div\r\n                style={{\r\n                    position: 'relative',\r\n                    width: '100%',\r\n                    marginTop: '7px',\r\n                }}\r\n            >\r\n                <FilterHeader />\r\n            </div>\r\n            <div\r\n                style={{\r\n                    position: 'relative',\r\n                    width: '100%',\r\n                }}\r\n            >\r\n                <HeaderWithIcon\r\n                    title={null}\r\n                    icon={null}\r\n                    color={customApp('menu')}\r\n                    style={{\r\n                        background: 'transparent',\r\n                        padding: '7px'\r\n                    }}\r\n                    customButtons={[\r\n                        {\r\n                            title: \"$__orderByStartDate\",\r\n                            icon: \"today\",\r\n                            color: props.agileOrderBy === \"startDate\" ? customApp('color') : customApp('menu'),\r\n                            onClick: () => {\r\n                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                    ...reduxStore.getState().db,\r\n                                    agileOrderBy: 'startDate'\r\n                                })\r\n                            },\r\n                        },\r\n                        {\r\n                            title: \"$__orderByEndDate\",\r\n                            icon: \"event\",\r\n                            color: props.agileOrderBy === \"endDate\" ? customApp('color') : customApp('menu'),\r\n                            onClick: () => {\r\n                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                    ...reduxStore.getState().db,\r\n                                    agileOrderBy: 'endDate'\r\n                                })\r\n                            },\r\n                        },\r\n                        {\r\n                            title: \"$__orderByName\",\r\n                            icon: \"sort\",\r\n                            color: props.agileOrderBy === \"name\" ? customApp('color') : customApp('menu'),\r\n                            onClick: () => {\r\n                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                    ...reduxStore.getState().controls,\r\n                                    agileOrderBy: 'name'\r\n                                })\r\n                            },\r\n                        },\r\n                        {\r\n                            title: props.agileOrderDesc === 'DESC' ? \"$__asc\" : \"$__desc\",\r\n                            icon: props.agileOrderDesc === 'DESC' ? \"text_rotation_down\" : \"text_rotate_up\",\r\n                            color: customApp('menu'),\r\n                            onClick: () => {\r\n                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                    ...reduxStore.getState().controls,\r\n                                    agileOrderDesc: props.agileOrderDesc === 'DESC' ? 'ASC' : 'DESC'\r\n                                })\r\n                            },\r\n                        },\r\n                    ]}\r\n                />\r\n            </div>\r\n            <div\r\n                style={{\r\n                    position: 'relative',\r\n                    minHeight: 'calc(100vh - 150px)',\r\n                    marginTop: '7px',\r\n                    width: '100%',\r\n                    overflowX: 'auto',\r\n                    overflowY: 'hidden',\r\n                }}\r\n            >\r\n                <AgileStatus cards={myCards} inLine={db.viewList} showConnectedIn\r\n                    columnStyle={{\r\n                        ...db.viewList ? { width: \"100%\" } : { maxHeight: \"calc(100vh - 190px)\", width: \"25%\" },\r\n                    }}\r\n                />\r\n                <div style={{ clear: 'both' }}></div>\r\n            </div>\r\n        </div >\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    history: store.db.history,\r\n    cards: store.db.cards,\r\n    viewList: store.db.viewList,\r\n    agileOrderBy: store.controls.agileOrderBy,\r\n    agileOrderDesc: store.controls.agileOrderDesc\r\n})\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","import React from 'react';\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//@MATERIAL\n\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Backoffice-languages.js\";\n\n//APIMS\nimport apims from \"apims\";\n\nfunction Component(props) {\n    const [Accounts, SetAccounts] = React.useState([])\n\n    // React.useEffect(() => {\n    //     ini()\n    // }, [])\n\n    // const ini = async () => {\n    //     const ReqAccounts = await apims.post('Adm_ReqAccounts')\n    //     console.log(ReqAccounts.data)\n\n    // }\n\n    return (\n        <div style={{ width: '100%' }}>\n            Resume\n        </div>\n    );\n}\n\n//REACT\nconst mapStateToProps = (store) => ({\n    store: {\n        languages: store.languages\n    }\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","//CORE\r\nimport React from \"react\";\r\nimport ReactExport from \"react-export-excel\";\r\nimport moment from \"moment-timezone\";\r\n\r\n//REDUX\r\nimport reduxStore from \"store/\";\r\n\r\n//@MATERIAL\r\nimport CustomButton from \"components/Buttons/custom\"\r\n\r\n\r\n//FUNCTIONS\r\nimport { translate, customApp } from \"functions/\";\r\n\r\nfunction ExportAll(props) {\r\n    const ExcelFile = ReactExport.ExcelFile;\r\n    const ExcelSheet = ReactExport.ExcelFile.ExcelSheet;\r\n    const ExcelColumn = ReactExport.ExcelFile.ExcelColumn;\r\n    const data = props.data\r\n    let allUsers = []\r\n    let deletedUsers = []\r\n\r\n    data.map(acc => {\r\n        acc.users.filter(u => !u.deleted).sort((a, b) => a.name.toLowerCase() < b.name.toLowerCase()).map(u => {\r\n            if (allUsers.filter(au => au.id === u.id).length === 0)\r\n                allUsers.push(u)\r\n        })\r\n        acc.users.filter(u => u.deleted).sort((a, b) => a.name.toLowerCase() < b.name.toLowerCase()).map(u => {\r\n            if (deletedUsers.filter(au => au.id === u.id).length === 0)\r\n                deletedUsers.push(u)\r\n        })\r\n    })\r\n    return (\r\n        <ExcelFile\r\n            filename={`${moment().tz('America/Sao_Paulo').format('YYYY-MM-DDTHHMM')}_${translate(\"$__companies\")}_${translate(\"$__users\")}`}\r\n            element={\r\n                <CustomButton\r\n                    title={translate(\"$__export\")}\r\n                    text={translate(\"$__export\")}\r\n                    icon={\"file_download\"}\r\n                    size={\"25px\"}\r\n                />\r\n            }\r\n        >\r\n            <ExcelSheet data={data.sort((a, b) => a.name < b.name)} name={translate(\"$__accounts\")}>\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__id', 1)}`} value=\"id\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__company', 1)}`} value=\"name\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__createdAt', 1)}`} value=\"created_at\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__signaturePlan', 1)}`} value=\"plan\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__activeUsersCount', 1)}`} value=\"usersCount\" />\r\n                {/* <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__adminLimitUsers', 1)}`} value=\"adminsLimit\" /> */}\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__usedDisk', 1)}`} value=\"diskUsed\" />\r\n            </ExcelSheet>\r\n            <ExcelSheet data={allUsers.sort((a, b) => a.name < b.name)} name={\"USUARIOS ATIVOS\"}>\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__id', 1)}`} value=\"id\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__name', 1)}`} value=\"name\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__unity', 1)}`} value=\"unity\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__email', 1)}`} value=\"email\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__createdAt', 1)}`} value=\"created_at\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__lastSessionDate', 1)}`} value=\"lastSession\" />\r\n            </ExcelSheet>\r\n            <ExcelSheet data={deletedUsers.sort((a, b) => a.name < b.name)} name={\"USUÁRIOS REMOVIDOS\"}>\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__id', 1)}`} value=\"id\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__name', 1)}`} value=\"name\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__unity', 1)}`} value=\"unity\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__email', 1)}`} value=\"email\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__createdAt', 1)}`} value=\"created_at\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__lastSessionDate', 1)}`} value=\"lastSession\" />\r\n                <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__removed', 1)}`} value=\"deleted\" />\r\n            </ExcelSheet>\r\n            {data.map((acc, i) => {\r\n                return (\r\n                    <ExcelSheet data={acc.users} name={acc.name} key={i}>\r\n                        <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__id', 1)}`} value=\"id\" />\r\n                        <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__name', 1)}`} value=\"name\" />\r\n                        <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__unity', 1)}`} value=\"unity\" />\r\n                        <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__email', 1)}`} value=\"email\" />\r\n                        <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__createdAt', 1)}`} value=\"created_at\" />\r\n                        <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__lastSessionDate', 1)}`} value=\"lastSession\" />\r\n                        <ExcelColumn width={350} style={{ alignment: { wrapText: true } }} label={`${translate('$__removed', 1)}`} value=\"deleted\" />\r\n                    </ExcelSheet>\r\n                )\r\n            })}\r\n\r\n        </ExcelFile>\r\n    )\r\n}\r\nexport default ExportAll","import React from \"react\"\nimport moment from \"moment\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport CustomButton from \"components/Buttons/custom\"\nimport ExportAll from \"components/Account/exportAll\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Backoffice-languages.js\"\n\n//APIMS\nimport apims from \"apims\"\n\n//FUNCTIONS\nimport {\n    customApp,\n    formatSizeUnits,\n    getDate,\n    translate,\n} from \"functions/\"\n\nfunction Component(props) {\n    const [Accounts, SetAccounts] = React.useState([])\n    const [AccountsExport, SetAccountsExport] = React.useState([])\n    const [viewAccountDetail, setViewAccountDetail] = React.useState(null)\n    const [userOrderBy, setUserOrderBy] = React.useState(\"name\")\n    const [userOrderASC, setUserOrderASC] = React.useState(true)\n    const { plans } = reduxStore.getState().db\n\n\n    React.useEffect(() => {\n        ini()\n    }, [])\n\n    const ini = async () => {\n        const ReqAccounts = await apims.post(\"Adm_ReqAccounts\")\n\n        let AE = []\n        if (ReqAccounts) {\n            ReqAccounts.data.map(acc => {\n                let diskUsed = 0\n                if (AE.filter(aa => aa.id === acc.id).length === 0) {\n                    acc.users.filter(a => a.filesSize).map(a => {\n                        diskUsed = diskUsed + parseInt(a.filesSize)\n                    })\n                    if (diskUsed > 0)\n                        diskUsed = formatSizeUnits(diskUsed)\n\n                    let cd = acc.account.created_at && acc.account.created_at.low ? String(acc.account.created_at.low) : acc.account.created_at\n                    let plan = acc && acc.account && acc.account.plan && plans.filter(pl => pl.value.indexOf(acc.account.plan)).length > 0 ? acc.account.plan : \"p0\"\n\n                    let users = Array.from(acc.users)\n\n                    users.flatMap(us => {\n                        if (us.deleted || us.unityDeleted)\n                            us.deleted = \"SIM\"\n                        us.created_at = moment(us.created_at * 1000).format(\"DD/MM/YYYY HH:mm:ss\")\n                        us.lastSession = us.lastSession ? moment(us.lastSession * 1000).format(\"DD/MM/YYYY HH:mm:ss\") : ``\n                    })\n\n                    AE.push({\n                        id: acc.id,\n                        ...acc.account,\n                        created_at: moment(cd * 1000).format(\"DD/MM/YYYY HH:mm:ss\"),\n                        plan: translate(plans.filter(pl => pl.value.indexOf(plan) > -1)[0].label, '*'),\n                        diskUsed: diskUsed,\n                        usersCount: acc.users.length,\n                        users: users\n                    })\n                    if (acc.account.name === \"ENEVA\") {\n                        console.log(acc, {\n                            id: acc.id,\n                            ...acc.account,\n                            created_at: moment(cd * 1000).format(\"DD/MM/YYYY HH:mm:ss\"),\n                            plan: translate(plans.filter(pl => pl.value.indexOf(plan) > -1)[0].label, '*'),\n                            diskUsed: diskUsed,\n                            usersCount: acc.users.length,\n                            users: users\n                        })\n                    }\n                }\n            })\n\n            SetAccounts(ReqAccounts.data)\n            SetAccountsExport(AE)\n        }\n\n    }\n\n    const u_orderBy = (x) => {\n        if (userOrderBy === x) {\n            setUserOrderASC(prev => !prev)\n        } else {\n            setUserOrderBy(x)\n        }\n    }\n    const User = ({ data, index }) => {\n        let diskUsed = data.filesSize ? parseInt(data.filesSize) : 0\n        if (diskUsed > 0)\n            diskUsed = formatSizeUnits(diskUsed)\n        return (\n            <div>\n                <div\n                    style={{\n                        border: \"solid 1px #f6f6f6\",\n                        width: \"100%\",\n                        padding: 7,\n                        overflowY: \"auto\",\n                        display: \"flex\",\n                        ...data.deleted ? { color: \"red\" } : {},\n                        marginBottom: 7,\n                        ...index % 2 ? { background: \"linear-gradient(33deg, rgba(255, 255, 255, 1), rgba(247,247,247, 1))\" }\n                            : { background: \"linear-gradient(77deg, rgba(247,247,247, 1), rgba(255, 255, 255, 1))\" },\n                    }}\n                >\n                    <div style={{ position: \"relative\", float: \"left\", width: \"100px\" }}>#{data.id}</div>\n                    <div style={{ position: \"relative\", float: \"left\", width: \"150px\", overflow: \"hidden\", textOverflow: \"ellipsis\" }}><div style={{ width: \"100%\", position: \"relative\", float: \"left\" }}>{data.name}</div> {data.unity ? <div style={{ fontSize: 10, width: \"100%\", position: \"relative\", float: \"left\" }}>({data.unity})</div> : ``}</div>\n                    <div style={{ position: \"relative\", float: \"left\", width: \"300px\" }}>{data.email}</div>\n                    <div style={{ position: \"relative\", float: \"left\", width: \"150px\" }}>{data.created_at}</div>\n                    <div style={{ position: \"relative\", float: \"left\", width: \"150px\" }}>{data.lastSession}</div>\n                    {/* <div style={{ position: \"relative\", float: \"left\", width: \"100px\" }}>\n                        <fieldset>\n                            <legend>{translate(`$__userInformations`)}</legend>\n                        </fieldset>\n                    </div> */}\n                </div>\n            </div>)\n    }\n\n    const Item = ({ data, index }) => {\n        let plan = data && data.account && data.account.plan && plans.filter(pl => pl.value.indexOf(data.account.plan) > -1).length > 0 ? data.account.plan : \"p0\"\n        let users = data.users.filter(a => !a.deleted).length\n        let diskUsed = 0\n        data.users.filter(a => a.filesSize).map(a => {\n            diskUsed = diskUsed + parseInt(a.filesSize)\n        })\n        if (diskUsed > 0)\n            diskUsed = formatSizeUnits(diskUsed)\n        return (\n            <div\n                style={{\n                    position: \"relative\",\n                    width: \"100%\",\n                    padding: 7,\n                    marginBottom: 3,\n                    ...data.account.deleted ? {\n                        ...index % 2 ? { background: \"linear-gradient(33deg, rgba(237,20,61,0.1), rgba(237,20,61,0.2))\" }\n                            : { background: \"linear-gradient(33deg, rgba(237,20,61,0.2), rgba(237,20,61,0.1))\" },\n                    } : {\n                        ...index % 2 ? { background: \"linear-gradient(33deg, rgba(255, 255, 255, 1), rgba(247,247,247, 1))\" }\n                            : { background: \"linear-gradient(77deg, rgba(247,247,247, 1), rgba(255, 255, 255, 1))\" },\n                    },\n                }}\n            >\n                <div\n                    style={{\n                        width: \"100%\",\n                        padding: 7,\n                        overflowY: \"auto\",\n                        display: \"flex\",\n                        marginBottom: 3,\n                    }}\n                >\n                    <div style={{ position: \"relative\", float: \"left\", width: \"100px\" }}>#{data.id}</div>\n                    <div style={{ position: \"relative\", float: \"left\", width: \"300px\" }}>{data.account.name}</div>\n                    <div style={{ position: \"relative\", float: \"left\", width: \"200px\" }}>{getDate(data.account.created_at)}</div>\n                    <div style={{ position: \"relative\", float: \"left\", width: \"200px\" }}>{plans.filter(pl => pl.value.indexOf(plan) > -1)[0] && plans.filter(pl => pl.value.indexOf(plan) > -1)[0].label ? translate(`${plans.filter(pl => pl.value.indexOf(plan) > -1)[0].label}`) : ``}</div>\n                    <div style={{ position: \"relative\", float: \"left\", width: \"100px\", cursor: \"pointer\", display: \"flex\" }}\n                        onClick={() => {\n                            if (viewAccountDetail === data.id) {\n                                setViewAccountDetail(null)\n                            } else {\n                                setViewAccountDetail(data.id)\n                            }\n                        }}\n                    ><CustomButton\n                            transparent\n                            title={translate(`$__showUsers`, \"*\")}\n                            color={customApp(\"lightgrey\")}\n                            icon={viewAccountDetail === data.id ? \"expand_less\" : \"expand_more\"}\n                            onClick={() => {\n                                setViewAccountDetail(viewAccountDetail === data.id ? null : data.id)\n                            }}\n                            size={\"25px\"}\n                        />\n                        {users}\n                        {/* {data.account.maxUsers && data.account.maxUsers.low ? ` ${translate(\"$__of\")} ${data.account.maxUsers.low}` : ``} */}\n                    </div>\n                    <div style={{ position: \"relative\", float: \"left\", width: \"100px\" }}>{diskUsed}</div>\n                </div>\n                {\n                    viewAccountDetail === data.id\n                        ?\n                        <fieldset\n                            style={{\n                                borderRadius: 5,\n                                // padding: 7,\n                                width: \"100%\",\n                                overflow: \"auto\",\n                                position: \"relative\",\n                            }}\n                        >\n                            <legend style={{ display: \"flex\" }}>{translate(`$__users`)}<CustomButton\n                                transparent\n                                title={translate(`$__hide`, \"*\")}\n                                color={customApp(\"lightgrey\")}\n                                icon={\"expand_less\"}\n                                onClick={() => {\n                                    setViewAccountDetail(null)\n                                }}\n                                size={\"25px\"}\n                            /></legend>\n\n                            <div\n                                style={{\n                                    border: \"solid 1px #f6f6f6\",\n                                    width: \"100%\",\n                                    padding: 3,\n                                    overflowY: \"auto\",\n                                    display: \"flex\",\n                                    fontWeight: \"bold\",\n                                    color: customApp(\"menu\"),\n                                    fontSize: \"11px\"\n                                }}\n                            >\n                                <div style={{ position: \"relative\", float: \"left\", width: \"100px\" }}\n                                    onClick={() => {\n                                        u_orderBy(\"id\")\n                                    }}\n                                >#{translate(\"$__id\")}</div>\n                                <div style={{ position: \"relative\", float: \"left\", width: \"150px\" }}\n                                    onClick={() => {\n                                        u_orderBy(\"name\")\n                                    }}\n                                >{translate(\"$__name\")}</div>\n                                <div style={{ position: \"relative\", float: \"left\", width: \"300px\" }}\n                                    onClick={() => {\n                                        u_orderBy(\"email\")\n                                    }}\n                                >{translate(\"$__email\")}</div>\n                                <div style={{ position: \"relative\", float: \"left\", width: \"150px\" }}\n                                    onClick={() => {\n                                        u_orderBy(\"createdAt\")\n                                    }}\n                                >{translate(\"$__createdDate\")}</div>\n                                <div style={{ position: \"relative\", float: \"left\", width: \"150px\" }}\n                                    onClick={() => {\n                                        u_orderBy(\"lastSession\")\n                                    }}\n                                >{translate(\"$__lastSession\")}</div>\n                                {/* <div style={{ position: \"relative\", float: \"left\", width: \"100px\" }}>{translate(\"$__infos\")}</div> */}\n                            </div>\n                            {data.users\n                                .sort((a, b) => {\n                                    let A = \"\"\n                                    let B = \"\"\n                                    if (userOrderBy === \"id\") {\n                                        A = a.id\n                                        B = b.id\n                                    }\n                                    if (userOrderBy === \"name\") {\n                                        A = a.name.toLowerCase()\n                                        B = b.name.toLowerCase()\n                                    }\n                                    if (userOrderBy === \"email\") {\n                                        A = a.email.toLowerCase()\n                                        B = b.email.toLowerCase()\n                                    }\n                                    if (userOrderBy === \"createdAt\") {\n                                        A = a.created_at\n                                        B = b.created_at\n                                    }\n                                    if (userOrderBy === \"lastSession\") {\n                                        A = a.lastSession\n                                        B = b.lastSession\n                                    }\n                                    if (A < B)\n                                        return userOrderASC ? -1 : 1\n                                    if (A > B)\n                                        return userOrderASC ? 1 : -1\n                                    return 0\n                                })\n                                .map((us, usi) => (\n                                    <User data={us} index={usi} key={usi} />\n                                ))}\n                        </fieldset>\n                        :\n                        <React.Fragment></React.Fragment>\n                }\n            </div>)\n    }\n    return (\n        <div style={{ width: \"100%\" }}>\n            <ExportAll data={AccountsExport} />\n            <div\n                style={{\n                    border: \"solid 1px #f6f6f6\",\n                    width: \"100%\",\n                    padding: 3,\n                    overflowY: \"auto\",\n                    display: \"flex\",\n                    fontWeight: \"bold\",\n                    color: customApp(\"menu\")\n                }}\n            >\n                <div style={{ position: \"relative\", float: \"left\", width: \"100px\" }}>#{translate(\"$__id\")}</div>\n                <div style={{ position: \"relative\", float: \"left\", width: \"300px\" }}>{translate(\"$__company\")}</div>\n                <div style={{ position: \"relative\", float: \"left\", width: \"200px\" }}>{translate(\"$__createdDate\")}</div>\n                <div style={{ position: \"relative\", float: \"left\", width: \"200px\" }}>{translate(\"$__plan\")}</div>\n                <div style={{ position: \"relative\", float: \"left\", width: \"100px\" }}>{translate(\"$__users\")}</div>\n                <div style={{ position: \"relative\", float: \"left\", width: \"100px\" }}>{translate(\"$__diskUsed\")}</div>\n            </div>\n            <div>\n\n                {Accounts\n                    .filter(x => !viewAccountDetail || viewAccountDetail === x.id)\n                    .sort((a, b) => {\n                        let nameA = a.account.name.toLowerCase()\n                        let nameB = b.account.name.toLowerCase()\n                        if (nameA < nameB)\n                            return -1\n                        if (nameA > nameB)\n                            return 1\n                        return 0\n                    })\n                    .map((acc, i) => <Item index={i} data={acc} key={acc.account._id} />)}\n            </div>\n        </div>\n    );\n}\n\n//REACT\nconst mapStateToProps = (store) => ({\n    store: {\n        languages: store.languages\n    }\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","import React from 'react';\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//@MATERIAL\nimport Paper from \"@material-ui/core/Paper\";\nimport TablePagination from '@material-ui/core/TablePagination';\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//COMPONENTS\nimport HeaderWithIcon from \"components/Header/withIcon\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport TextField from \"components/TextField\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Backoffice-languages.js\";\nimport { translate, customApp } from 'functions';\n\nfunction Component(props) {\n    const { classes } = props\n    const [languages, setLanguages] = React.useState({})\n    const { socket } = reduxStore.getState().functions\n    const [onlyEmpty, setOnlyEmpty] = React.useState(false)\n    const [page, setPage] = React.useState(0)\n    const [limit, setLimit] = React.useState(25)\n    const [filter, setFilter] = React.useState(\"\")\n\n    React.useEffect(() => {\n        setLanguages(reduxStore.getState().languages)\n    }, [JSON.stringify(reduxStore.getState().languages)])\n\n\n\n    //AQUI TEM QUE ATUALIZAR O DB LOCAL \n    const updateLanguage = async (id, alias, locale, text) => {\n        // console.log(id, alias, locale, text)\n        if (!id) {\n            socket.emit(\"data\", {\n                module: \"language\",\n                method: \"post\",\n                action: \"addLocale\"\n            }, {\n                alias,\n                locale,\n                text\n            })\n        } else {\n            socket.emit('language.UPD', {\n                alias,\n                locale,\n                text\n            })\n        }\n    }\n\n    return (\n        <div style={{ width: '100%' }}>\n            <div style={{\n                position: \"relative\",\n                float: 'left',\n                width: '100%',\n                left: '0px',\n                right: '0px',\n                padding: '15px',\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center'\n            }}>\n                {/* PAGINATION */}\n                {translate('$__page')} {page + 1} {translate('$__of')} {Math.ceil(Object.keys(languages).length / limit)}\n                <div style={{ display: 'flex', alignItems: 'center' }}>\n                    <TablePagination\n                        component=\"div\"\n                        count={Object.keys(languages).length}\n                        page={page}\n                        onChangePage={(event, newPage) => {\n                            setPage(newPage)\n                        }}\n                        rowsPerPage={limit}\n                        onChangeRowsPerPage={(event) => {\n                            setLimit(parseInt(event.target.value, 10))\n                        }}\n                        labelRowsPerPage={translate('$__aliasPerPage')}\n                    />\n                </div>\n            </div>\n            <div style={{ width: \"100%\", display: 'flex', alignItems: 'center' }}>\n                <TextField\n                    label={translate('$__search', 1)}\n                    variant={customApp('fieldVariant')}\n                    value={filter}\n                    onChange={(e) => {\n                        setFilter(e.target.value)\n                    }}\n                />\n                <IconButton\n                    text={onlyEmpty ? translate(\"$__all\", '*') : translate(\"$__onlyEmpty\", '*')}\n                    icon={onlyEmpty ? \"subtitles_off\" : \"subtitles\"}\n                    iconColor={customApp('medium')}\n                    onClick={() => {\n                        setOnlyEmpty(!onlyEmpty);\n                    }}\n                />\n            </div>\n            <Paper className={classes.root}>\n                <div className={classes.header}>\n                    <div className={classes.column}>\n                        {translate(`$__alias`, 1)}\n                    </div>\n                    <div className={classes.column}>\n                        {translate(`$__translation`, 1)}\n                    </div>\n                </div>\n                <div className={classes.body}>\n                    <ul>\n                        {languages\n                            && Object.keys(languages)\n                            && Object.keys(languages).length > 0\n                            && Object.keys(languages)\n                                .filter(alias => {\n                                    if (\n                                        (\n                                            !filter\n                                            ||\n                                            (\n                                                filter\n                                                && (\n                                                    alias.indexOf(filter) > -1\n                                                    ||\n                                                    (\n                                                        languages[alias]\n                                                        && languages[alias].locales\n                                                        && languages[alias].locales.filter(a =>\n                                                            a.name.toLowerCase().indexOf(filter.toLowerCase()) > -1\n                                                        ).length > 0\n                                                    )\n                                                )\n                                            )\n                                        )\n                                        &&\n                                        (\n                                            (onlyEmpty\n                                                && languages[alias]\n                                                &&\n                                                (\n                                                    !languages[alias].locales\n                                                    ||\n                                                    (\n                                                        languages[alias].locales &&\n                                                        (\n                                                            (\n                                                                !languages[alias].locales.filter(lc => lc.locale === 'pt-BR').length === 0\n                                                                || (\n                                                                    languages[alias].locales.filter(lc => lc.locale === 'pt-BR').length > 0 &&\n                                                                    !languages[alias].locales.filter(lc => lc.locale === 'pt-BR')[0].name\n                                                                )\n                                                            )\n                                                            || (\n                                                                languages[alias].locales.filter(lc => lc.locale === 'en-US').length === 0\n                                                                || (\n                                                                    languages[alias].locales.filter(lc => lc.locale === 'en-US').length > 0 &&\n                                                                    !languages[alias].locales.filter(lc => lc.locale === 'en-US')[0].name\n                                                                )\n                                                            )\n                                                            || (\n                                                                languages[alias].locales.filter(lc => lc.locale === 'es-ES').length === 0\n                                                                || (\n                                                                    languages[alias].locales.filter(lc => lc.locale === 'es-ES').length > 0 &&\n                                                                    !languages[alias].locales.filter(lc => lc.locale === 'es-ES')[0].name\n                                                                )\n                                                            )\n                                                        )\n                                                    )\n                                                )\n                                            )\n                                            ||\n                                            !onlyEmpty\n                                        )\n                                    )\n                                        return true\n                                }\n                                )\n                                .sort((a, b) => {\n                                    if (a < b) {\n                                        return -1\n                                    } else if (a > b) {\n                                        return 1\n                                    } else {\n                                        return 0\n                                    }\n                                })\n                                .map((alias, i) => {\n                                    if (i <= ((page + 1) * limit) && i >= page * limit)\n                                        return (<li key={alias.trim()}>\n                                            <div className={classes.column}>\n                                                {alias}\n                                            </div>\n                                            <div className={classes.column2}>\n                                                <fieldset style={{ marginBottom: 15 }}>\n                                                    <legend>Português - Brasil</legend>\n                                                    <div style={{ position: 'relative' }}>\n                                                        <HeaderWithIcon\n                                                            key={`${alias}_pt-BR`}\n                                                            title={languages[alias].locales && languages[alias].locales.length > 0 && languages[alias].locales.filter(lc => lc.locale === 'pt-BR').length > 0 && languages[alias].locales.filter(lc => lc.locale === 'pt-BR')[0].name}\n                                                            _id={languages[alias].locales && languages[alias].locales.length > 0 && languages[alias].locales.filter(lc => lc.locale === 'pt-BR').length > 0 && languages[alias].locales.filter(lc => lc.locale === 'pt-BR')[0]._id}\n                                                            editable\n                                                            onEdit={(text, id) => {\n                                                                updateLanguage(id, alias, 'pt-BR', text.name)\n\n                                                            }\n                                                            }\n                                                            color={customApp('menu')}\n                                                            noAutoFocus={true}\n                                                            multiline\n                                                            noCancel\n                                                        />\n                                                    </div>\n                                                </fieldset>\n                                                <fieldset style={{ marginBottom: 15 }}>\n                                                    <legend>Inglês - Internacional</legend>\n                                                    <HeaderWithIcon\n                                                        key={`${alias}_en-US`}\n                                                        editable\n                                                        title={languages[alias].locales && languages[alias].locales.length > 0 && languages[alias].locales.filter(lc => lc.locale === 'en-US').length > 0 && languages[alias].locales.filter(lc => lc.locale === 'en-US')[0].name}\n                                                        _id={languages[alias].locales && languages[alias].locales.length > 0 && languages[alias].locales.filter(lc => lc.locale === 'en-US').length > 0 && languages[alias].locales.filter(lc => lc.locale === 'en-US')[0]._id}\n                                                        onEdit={(text, id) => {\n                                                            updateLanguage(id, alias, 'en-US', text.name)\n                                                        }\n                                                        }\n                                                        color={customApp('menu')}\n                                                        noAutoFocus={true}\n                                                        multiline\n                                                        noCancel\n                                                    />\n                                                </fieldset>\n                                                <fieldset style={{ marginBottom: 15 }}>\n                                                    <legend>Espanhol</legend>\n                                                    <HeaderWithIcon\n                                                        key={`${alias}_es-ES`}\n                                                        editable\n                                                        title={languages[alias].locales && languages[alias].locales.length > 0 && languages[alias].locales.filter(lc => lc.locale === 'es-ES').length > 0 && languages[alias].locales.filter(lc => lc.locale === 'es-ES')[0].name}\n                                                        _id={languages[alias].locales && languages[alias].locales.length > 0 && languages[alias].locales.filter(lc => lc.locale === 'es-ES').length > 0 && languages[alias].locales.filter(lc => lc.locale === 'es-ES')[0]._id}\n                                                        onEdit={(text, id) => {\n                                                            updateLanguage(id, alias, 'es-ES', text.name)\n                                                        }\n                                                        }\n                                                        color={customApp('menu')}\n                                                        noAutoFocus={true}\n                                                        multiline\n                                                        noCancel\n                                                    />\n                                                </fieldset>\n                                            </div>\n                                        </li>\n                                        )\n                                })}\n                    </ul>\n                </div>\n            </Paper >\n        </div>\n    );\n}\n\n//REACT\nconst mapStateToProps = (store) => ({\n    store: {\n        languages: store.languages\n    }\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","import React from \"react\"\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport LinearProgress from \"components/Progress/linear\"\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//DEPENDENCIES\nimport Resume from \"./Resume\"\nimport Accounts from \"./Accounts\"\nimport Languages from \"./Languages\"\nimport DataPicker from \"components/DataPicker\"\n\n// import DayTasks from \"./daytasks\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/dashboard\"\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\"\n\nfunction Dashboard(props) {\n  const { session } = reduxStore.getState()\n  let hashs = window.location.hash.split('/')\n  hashs[0] = hashs[0].replace('#', '')\n\n  const [sd, setSD] = React.useState(null)\n  const [ed, setED] = React.useState(null)\n\n  if (!session._access.master)\n    return (<div>ACCESS DENIED</div>)\n\n  if (!window.location.hash.split('/')[0].replace('#', '')) {\n    // history.push('masterAdmin#tab/languages')\n  }\n\n  return (\n    <div>\n      {!hashs[0] &&\n        <Resume />\n      }\n      {(hashs[0] === 'tab' && hashs[1] === 'accounts') &&\n        <Accounts />\n      }\n      {(hashs[0] === 'tab' && hashs[1] === 'languages') &&\n        <Languages />\n      }\n\n      {(hashs[0] === 'tab' && hashs[1] === 'tests') &&\n        <div style={{ width: \"300px\" }}>\n          <DataPicker\n            type=\"datetime\"\n            onChangeStartDate={(d) => {\n              console.log(moment(d).format(\"YYYY-MM-DD 23:59:59\").unix('X'))\n              setSD(moment(d).unix('X'))\n            }}\n            onChangeEndDate={(d) => {\n              setED(moment(d).unix('X'))\n            }}\n            range\n            // horizontal\n            startDate={sd ? new Date(sd * 1000) : null}\n            endDate={ed ? new Date(ed * 1000) : null}\n            onClear={() => {\n              setSD(null)\n              setED(null)\n            }}\n          />\n        </div>\n      }\n    </div >\n  )\n}\n\n//EXPORT\nconst mapStateToProps = (store) => ({\n  history: store.db.history\n})\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Dashboard))","import {\r\n  primaryColor,\r\n  warningColor,\r\n  dangerColor,\r\n  successColor,\r\n  infoColor,\r\n  roseColor,\r\n  grayColor,\r\n  whiteColor\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst badgeStyle = {\r\n  badge: {\r\n    borderRadius: \"12px\",\r\n    padding: \"5px 12px\",\r\n    textTransform: \"uppercase\",\r\n    fontSize: \"10px\",\r\n    fontWeight: \"700\",\r\n    lineHeight: \"1\",\r\n    color: whiteColor,\r\n    textAlign: \"center\",\r\n    verticalAlign: \"baseline\",\r\n    display: \"inline-block\"\r\n  },\r\n  primary: {\r\n    backgroundColor: primaryColor[0]\r\n  },\r\n  warning: {\r\n    backgroundColor: warningColor[0]\r\n  },\r\n  danger: {\r\n    backgroundColor: dangerColor[0]\r\n  },\r\n  success: {\r\n    backgroundColor: successColor[0]\r\n  },\r\n  info: {\r\n    backgroundColor: infoColor[0]\r\n  },\r\n  rose: {\r\n    backgroundColor: roseColor[0]\r\n  },\r\n  gray: {\r\n    backgroundColor: grayColor[0]\r\n  }\r\n};\r\n\r\nexport default badgeStyle;\r\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\n\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\n\nimport styles from \"assets/jss/material-dashboard-pro-react/components/badgeStyle.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function Badge(props) {\n  const { color, children } = props;\n  const classes = useStyles();\n  return (\n    <span className={`${classes.badge} ${color !== 'parent' ? classes[color] : ''} ${props.className ? props.className : ''}`}>{children}</span>\n  );\n}\n\nBadge.propTypes = {\n  color: PropTypes.oneOf([\n    \"primary\",\n    \"parent\",\n    \"warning\",\n    \"danger\",\n    \"success\",\n    \"info\",\n    \"rose\",\n    \"gray\"\n  ]),\n  children: PropTypes.node\n};\n","import {\r\n  infoColor,\r\n  primaryColor,\r\n  successColor,\r\n  dangerColor,\r\n  warningColor,\r\n  whiteColor,\r\n  blackColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport { customApp } from \"functions/\";;\r\nconst timelineStyle = theme => ({\r\n  root: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    overflowY: 'auto'\r\n  },\r\n  content: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    overflowY: 'auto',\r\n    backgroundColor: 'rgba(249,249,249,1)'\r\n  },\r\n  timeline: {\r\n    listStyle: \"none\",\r\n    padding: \"0\",\r\n    position: \"absolute\",\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    display: 'flex',\r\n    width: '100%',\r\n    '& .file-drop-target': {\r\n      width: '100%'\r\n    }\r\n  },\r\n  scrollEnd: {\r\n    marginTop: '160px',\r\n    position: 'relative',\r\n    width: '100%',\r\n    height: '0px',\r\n    marginBottom: '-100px'\r\n  },\r\n  scrollEndNoEditor: {\r\n    marginTop: '30px',\r\n    position: 'relative',\r\n    width: '100%',\r\n    height: '0px',\r\n    marginBottom: '-100px'\r\n  },\r\n  timelineSimple: {\r\n    position: 'relative',\r\n    // overflowX: 'auto',\r\n    overflow: \"hidden\",\r\n    marginTop: \"0px\",\r\n    padding: \"0 0 50px\",\r\n    width: '-webkit-fill-available',\r\n    \"&:before\": {\r\n      left: \"15px\"\r\n    },\r\n  },\r\n  timelineSimpleWithHeader: {\r\n    position: 'relative',\r\n    overflowX: 'auto',\r\n    marginTop: \"60px\",\r\n    padding: \"0 0 50px\",\r\n    width: '-webkit-fill-available',\r\n    \"&:before\": {\r\n      left: \"15px\"\r\n    },\r\n  },\r\n  item: {\r\n    marginBottom: \"5px\",\r\n    position: \"relative\",\r\n    paddingLeft: \"15px\",\r\n    width: 'calc(100% - 15px)',\r\n    \"&:before,&:after\": {\r\n      content: '\" \"',\r\n      display: \"table\"\r\n    },\r\n    \"&:after\": {\r\n      clear: \"both\"\r\n    }\r\n  },\r\n  timelineBadge: {\r\n    color: whiteColor,\r\n    width: \"30px\",\r\n    height: \"30px\",\r\n    lineHeight: \"25px\",\r\n    fontSize: \"12px\",\r\n    textAlign: \"center\",\r\n    position: \"absolute\",\r\n    bottom: \"23px\",\r\n    left: \"50%\",\r\n    marginLeft: \"-7px\",\r\n    zIndex: \"1\",\r\n    borderTopRightRadius: \"50%\",\r\n    borderTopLeftRadius: \"50%\",\r\n    borderBottomRightRadius: \"50%\",\r\n    borderBottomLeftRadius: \"50%\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\"\r\n\r\n  },\r\n  timelineSimpleBadge: {\r\n    left: \"7px\"\r\n  },\r\n  timelineBadgeInverted: {\r\n    color: whiteColor,\r\n    width: \"30px\",\r\n    height: \"30px\",\r\n    lineHeight: \"25px\",\r\n    fontSize: \"12px\",\r\n    textAlign: \"center\",\r\n    position: \"absolute\",\r\n    bottom: \"23px\",\r\n    right: \"50%\",\r\n    marginRight: \"-7px\",\r\n    zIndex: \"1\",\r\n    borderTopRightRadius: \"50%\",\r\n    borderTopLeftRadius: \"50%\",\r\n    borderBottomRightRadius: \"50%\",\r\n    borderBottomLeftRadius: \"50%\",\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    justifyContent: \"center\"\r\n\r\n  },\r\n  timelineSimpleBadgeInverted: {\r\n    right: \"7px\"\r\n  },\r\n  custom: {\r\n    backgroundColor: customApp('color'),\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.4)\"\r\n  },\r\n  info: {\r\n    backgroundColor: infoColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(infoColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  success: {\r\n    backgroundColor: successColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(successColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  danger: {\r\n    backgroundColor: dangerColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(dangerColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  warning: {\r\n    backgroundColor: warningColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(warningColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  primary: {\r\n    backgroundColor: primaryColor[0],\r\n    boxShadow:\r\n      \"0 4px 20px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 7px 10px -5px rgba(\" +\r\n      hexToRgb(primaryColor[0]) +\r\n      \", 0.4)\"\r\n  },\r\n  badgeIcon: {\r\n    width: \"14px\",\r\n    height: \"14px\"\r\n  },\r\n  timelinePanel: {\r\n    maxWidth: \"calc(100% - 70px)\",\r\n    float: \"right\",\r\n    padding: \"7px\",\r\n    marginBottom: \"5px\",\r\n    marginRight: \"40px\",\r\n    position: \"relative\",\r\n    boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n    borderRadius: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n    background: customApp('timelineMyMessage'),\r\n  },\r\n  timelinePanelInverted: {\r\n    maxWidth: \"calc(100% - 70px)\",\r\n    float: \"left\",\r\n    padding: \"7px\",\r\n    marginLeft: \"40px\",\r\n    marginBottom: \"5px\",\r\n    position: \"relative\",\r\n    boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n    borderRadius: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n    background: '#ffffff',\r\n  },\r\n\r\n\r\n  timelineHeading: {\r\n    marginBottom: \"0px\",\r\n    display: \"flex\",\r\n    alignItems: \"center\"\r\n  },\r\n  timelineDate: {\r\n    display: 'flex',\r\n    alignItems: \"center\",\r\n    padding: '5px',\r\n    backgroundColor: '#CCCCCC'\r\n  },\r\n  timelineBody: {\r\n    overflowWrap: \"anywhere\",\r\n    fontSize: \"12px\",\r\n    lineHeight: \"21px\",\r\n    position: 'relative',\r\n    width: '100%',\r\n    float: 'left',\r\n  },\r\n  timelineLog: {\r\n    fontSize: \"12px\",\r\n    lineHeight: \"21px\",\r\n    // display: 'flex',\r\n  },\r\n  timelineFooter: {\r\n    zIndex: \"1\",\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    width: '100%',\r\n    display: \"inline-flex\",\r\n    justifyContent: \"space-between\"\r\n  },\r\n  footerUser: {\r\n    display: \"flex\",\r\n    alignItems: \"center\",\r\n    fontSize: '12px',\r\n    fontWeight: 'bold',\r\n    color: customApp('medium'),\r\n    padding: '0 7px',\r\n  },\r\n  footerLine: {\r\n    position: 'relative',\r\n    marginTop: \"10px\",\r\n    marginBottom: \"5px\"\r\n  },\r\n  dropFile: {\r\n    display: 'none',\r\n  },\r\n  onDropFile: {\r\n    position: 'absolute',\r\n    top: '0px',\r\n    left: '0px',\r\n    right: '0px',\r\n    bottom: '0px',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    justifyContent: 'center',\r\n    color: '#FFFFFF',\r\n    backgroundColor: 'rgba(0,0,0,0.77)',\r\n    zIndex: 1,\r\n  },\r\n  editor: {\r\n    position: 'absolute',\r\n    bottom: '0px',\r\n    minHeight: '50px',\r\n    padding: '10px',\r\n    height: 'auto',\r\n    width: 'calc(100% - 0px)',\r\n    backgroundColor: 'rgba(240,240,240,1)',\r\n    zIndex: 10,\r\n  },\r\n  files: {\r\n    display: 'inline-table',\r\n    position: 'relative'\r\n  },\r\n  textEditor: {\r\n    //display: 'flex'\r\n  },\r\n  textEditorIcon: {\r\n    cursor: 'pointer',\r\n    color: customApp('color'),\r\n  },\r\n  progressBar: {\r\n    backgroundColor: `${customApp('color', '0.1')} !important`,\r\n    '& .MuiLinearProgress-indeterminate': {\r\n      backgroundColor: `${customApp('color')} !important`\r\n    },\r\n    '& .MuiLinearProgress-bar': {\r\n      backgroundColor: `${customApp('color')} !important`\r\n    },\r\n  },\r\n  actionButton: {\r\n    alignItems: 'center',\r\n    cursor: 'pointer',\r\n    float: 'left',\r\n    height: '30px',\r\n    position: 'relative',\r\n    textAlign: 'center',\r\n    width: '30px',\r\n  },\r\n  sendingMessage: {\r\n    width: '100%'\r\n  },\r\n  valuePositive: {\r\n    positive: 'relative',\r\n    float: 'left',\r\n    color: 'blue',\r\n  },\r\n  valueNegative: {\r\n    positive: 'relative',\r\n    float: 'left',\r\n    color: 'red',\r\n  },\r\n  lastValue: {\r\n    positive: 'relative',\r\n    float: 'right',\r\n    color: 'grey',\r\n  },\r\n  timeInfo: {\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    color: 'grey',\r\n    width: '100%',\r\n    position: 'relative',\r\n    float: 'left',\r\n    marginBottom: '7px',\r\n    '& .text': {\r\n      marginLeft: '7px',\r\n    }\r\n  },\r\n  urlPreview: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    marginBottom: '33px',\r\n    '& img': {\r\n      maxWidth: '20%',\r\n      height: 'auto',\r\n      // position: 'relative',\r\n      // float: 'left',\r\n      marginTop: '30px',\r\n      marginRight: '7px'\r\n    },\r\n    '& .data': {\r\n      // position: 'relative',\r\n      // float: 'left',\r\n      //width: '75%',\r\n      '& .title': {\r\n        fontSize: '16px',\r\n        fontWeight: 'bold',\r\n      },\r\n      '& .siteName': {\r\n        fontSize: '14px',\r\n        fontWeight: 'bold',\r\n        color: '#909090'\r\n      },\r\n      '& .contentSnippet': {\r\n        fontSize: '12px',\r\n        color: '#909090'\r\n      }\r\n    }\r\n  },\r\n  users: {\r\n    position: 'relative',\r\n    bottom: '0px',\r\n    right: '2px',\r\n    fontSize: '10px',\r\n    '& .MuiAvatarGroup-root': {\r\n      justifyContent: 'flex-end',\r\n    },\r\n    '& .MuiAvatar-root': {\r\n      width: '25px',\r\n      height: '25px',\r\n      fontSize: '10px',\r\n    }\r\n  }\r\n});\r\n\r\nexport default timelineStyle;\r\n","import React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport Badge from \"components/Badge/\"\n\n//DEPENDENCIES\nimport SendingMessage from \"./sending.js\"\nimport Message from \"./message\";\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/timelineMiniStyle.js\";\n\n//FUNCTIONS\nimport {\n  chatReaded\n} from \"functions/chat\";\n\nconst Timeline = (props) => {\n  const { classes } = props;\n  const { db, session, functions, chat, timeline } = reduxStore.getState();\n  const { socket } = functions;\n  const [stories, setStories] = React.useState(props.stories || {})\n\n  let files = []; //USED IN LIGHTBOX;\n\n  React.useEffect(() => {\n    ini()\n  }, [props.stories, props.nodeId, JSON.stringify(timeline)])\n\n  const ini = () => {\n    let userStories = {}\n    if (timeline[session._id])\n      Object.keys(timeline[session._id])\n        .filter(a =>\n          timeline[session._id][a]\n          && timeline[session._id][a].user\n          && timeline[session._id][a].user._id\n          && timeline[session._id][a].user._id === props.nodeId\n        ).map(a => {\n          userStories = {\n            ...userStories,\n            [a]: timeline[session._id][a]\n          }\n        })\n    if (timeline[props.nodeId]) {\n      Object.keys(timeline[props.nodeId])\n        .map(a => {\n          userStories = {\n            ...userStories,\n            [a]: timeline[props.nodeId][a]\n          }\n        })\n    }\n    setStories(userStories)\n  }\n\n\n  const openLightBox = (f) => {\n    props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n      open: true,\n      files: files,\n      file: f\n    })\n  }\n\n  const readMessages = async () => {\n    socket.emit(\"data\", {\n      module: \"chat\",\n      method: \"put\",\n      action: \"read\"\n    }, {\n      readedBy: session._id,\n      id: props.nodeId,\n      db: db.cards[props.nodeId] ? 'cards' : 'users',\n      type: props.type ? props.type : \"comment\"\n    })\n  }\n\n  return (\n    <div style={{ position: \"relative\", float: \"left\", width: \"100%\", marginBottom: '15px' }}>\n      <ul className={classes.timelineSimple}\n        id={`tms_${props.nodeId}`}\n        style={{ zIndex: 1 }}\n      >\n        {stories\n          && Object.keys(stories).length > 0\n          && Object.keys(stories).sort((a, b) => {\n            if (parseInt(stories[a].created_at) < parseInt(stories[b].created_at)) {\n              return -1\n            } else if (parseInt(stories[a].created_at) > parseInt(stories[b].created_at)) {\n              return 1\n            } else {\n              return 0\n            }\n          }\n          ).map((id, key) => {\n            let storie = stories[id]\n            if (!props.showUnReaded && key > Object.keys(stories).length - 4) {\n              if (storie.files && Object.keys(storie.files).length > 0)\n                Object.keys(storie.files).map((id, i) => {\n                  let file = storie.files[id]\n                  files.push(file)\n                })\n              return (\n                <li\n                  className={classes.item}\n                  key={id}\n                  style={{\n                  }}>\n                  <Message\n                    openLightBox={(e) => { openLightBox(e) }}\n                    storie={storie}\n                    reply={storie.reply ? stories[storie.reply] : null}\n                    hideCards={props.hideCards ? true : false}\n                    db={props.db}\n                    nodeId={props.nodeId}\n                  />\n                </li>\n              );\n            } else if (\n              props.showUnReaded\n              && storie\n              && storie.user\n              && storie.user._id !== session._id\n              && (\n                !storie.readedBy\n                ||\n                (\n                  storie.readedBy\n                  && !storie.readedBy[session._id]\n                )\n              )\n            ) {\n              if (storie.files && Object.keys(storie.files).length > 0)\n                Object.keys(storie.files).map((id, i) => {\n                  let file = storie.files[id]\n                  files.push(file)\n                })\n              return (\n                <li\n                  className={classes.item}\n                  key={id}\n                  style={{\n                  }}>\n                  <Message\n                    openLightBox={(e) => { openLightBox(e) }}\n                    storie={storie}\n                    reply={storie.reply ? stories[storie.reply] : null}\n                    hideCards={props.hideCards ? true : false}\n                    db={props.db}\n                    nodeId={props.nodeId}\n                  />\n                </li>\n              );\n            }\n          })}\n        <div style={{ marginBottom: '15px', clear: 'both' }}></div>\n      </ul>\n      {/* {Object.keys(stories).filter(a =>\n        stories[a]\n        && stories[a].user\n        && stories[a].user._id\n        && stories[a].user._id !== session._id\n        && (\n          !stories[a].readedBy\n          ||\n          (\n            stories[a].readedBy\n            && !stories[a].readedBy[session._id]\n          )\n        )\n      ).length > 0 &&\n        <div\n          style={{\n            // position: 'absolute',\n            // bottom: '6px',\n            // left: '-36px',\n            // zIndex: 100\n          }}>\n          <Badge\n            badgeContent={Object.keys(stories).filter(a =>\n              stories[a]\n              && stories[a].user\n              && stories[a].user._id\n              && stories[a].user._id !== session._id\n              && (\n                !stories[a].readedBy\n                ||\n                (\n                  stories[a].readedBy\n                  && !stories[a].readedBy[session._id]\n                )\n              )\n            ).length}\n            overlap=\"circular\"\n            anchorOrigin={{\n              vertical: 'top',\n              horizontal: 'right',\n            }}\n            variant={\"standard\"}\n          >\n            <Icon onClick={\n              () => {\n                readMessages()\n              }\n            }>mark_chat_read</Icon>\n          </Badge>\n        </div>\n      } */}\n      <SendingMessage nodeId={props.nodeId} onSending={() => { readMessages() }} />\n    </div >\n  );\n}\n//REACT\nconst mapStateToProps = (store, ownProps) => ({\n  store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n  mapStateToProps,\n  mapDispatchToProps\n)(withStyles(styles)(Timeline));","//CORE\nimport React from 'react';\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\nimport { bindActionCreators } from \"redux\";\nimport { connect } from \"react-redux\";\n\n//COMPONENTS\nimport Avatar from \"components/Avatar\";\nimport Card from \"components/Card\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\nimport Icon from \"components/Icon\";\nimport Message from \"components/Timeline/message\";\nimport MiniTimeline from \"components/Timeline/Mini\";\n\n//@MATERIAL\nimport { makeStyles } from '@material-ui/core/styles';\n\n//FUNCTIONS\nimport { translate, customApp } from 'functions/';\nimport { loadTimeline } from \"functions/chat\";\n\nconst useStyles = makeStyles(() => ({\n    unReaded: {\n        background: 'linear-gradient(33deg, rgba(250, 250, 250, 1), rgba(250, 250, 250, 0))',\n        padding: '7px',\n        borderBottom: 'solid 1px rgba(0,0,0,0.1)',\n        width: '100%',\n        maxWidth: '100%',\n        opacity: 1\n    },\n    Readed: {\n        padding: '7px',\n        borderBottom: 'solid 1px rgba(0,0,0,0.1)',\n        width: '100%',\n        opacity: 0.6,\n        maxWidth: '100%',\n        \"&:hover\": {\n            opacity: 1,\n        }\n    }\n}));\n\nfunction Component(props) {\n    const [mounted, setMounted] = React.useState(false)\n    const { db, chat, timeline } = reduxStore.getState()\n    const { data } = props\n    const classes = useStyles();\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true)\n        }\n    })\n\n    let dbNotify = 'cards'\n    if (data.nodeId && reduxStore.getState().db.users[data.nodeId]) {\n        dbNotify = 'users'\n    }\n\n    const openChat = async (nodeId, dbProps) => {\n        if (!reduxStore.getState().db[dbProps][nodeId]._loadTimeline) {\n            loadTimeline(\n                {\n                    ...props,\n                    fnIdentification: \"Notifications/Index/openChat()\"\n                },\n                {\n                    id: [nodeId],\n                    db: dbProps\n                })\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...chat,\n                open: true,\n                db: dbProps,\n                nodeId: nodeId,\n                loading: true,\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...chat,\n                open: true,\n                db: dbProps,\n                nodeId: nodeId,\n                loading: false,\n            })\n        }\n        props.openChat(nodeId, dbProps)\n\n    }\n\n    if (data.module === 'timeline'\n        && (!data.inNode\n            || !data.inNode.type\n            || !reduxStore.getState().db\n            || !reduxStore.getState().db[dbNotify]))\n        return (<React.Fragment></React.Fragment>)\n\n    if (\n        (\n            !data.byUser\n            ||\n            (\n                data.byUser &&\n                !db.users[data.byUser]\n            )\n        )\n        || (\n            data.inNode\n            && data.inNode.type\n            && data.inNode._id\n            && !reduxStore.getState().db[dbNotify][data.inNode._id]\n        )\n    ) {\n        return (<React.Fragment></React.Fragment>)\n    }\n\n    const Header = () => {\n        let time = ``\n        if (moment().tz('America/Sao_Paulo').format('DD/MM/YYYY') === moment(data.created_at * 1000).tz('America/Sao_Paulo').format('DD/MM/YYYY')) {\n            time = `${translate('$__today', 1)} ${moment(data.created_at * 1000).tz('America/Sao_Paulo').format('HH:MM')}`\n        } else if (moment().tz('America/Sao_Paulo').format('YYYY') === moment(data.created_at * 1000).tz('America/Sao_Paulo').format('YYYY')) {\n            time = `${moment(data.created_at * 1000).tz('America/Sao_Paulo').format('DD/MM HH:MM')}`\n        } else {\n            time = `${moment(data.created_at * 1000).tz('America/Sao_Paulo').format('YYYY/DD/MM HH:MM')}`\n        }\n        return (\n            <div style={{\n                position: 'relative',\n            }}>\n                <div style={{\n                    position: 'relative',\n                    alignItems: 'center',\n                    display: 'flex',\n                    textSize: '10px',\n                    width: '100%',\n                    color: customApp(\"medium\"),\n                    justifyContent: 'space-between'\n                }}>\n                    <Avatar alt={db.users[data.byUser].name} src={db.users[data.byUser].image || null} size={'sm'} >\n                        {db.users[data.byUser].name.substr(0, 1)}\n                    </Avatar>\n                    <div style={{ display: 'flex', alignItems: 'center' }}>\n                        {translate(data.description)} - {time}\n                        {data.readed &&\n                            <Icon\n                                icon={'done_all'}\n                                color={customApp('medium')}\n                                title=\"$__readed\"\n                            />\n                        }\n                    </div>\n                </div>\n            </div>\n        )\n    }\n\n    return (\n        <div className={data.readed ? classes.Readed : classes.unReaded} >\n            <div style={{\n                textAlign: \"center\",\n                width: '100%',\n                padding: \"7px\",\n                maxWidth: '100%',\n            }}>\n\n            </div>\n            {data.module === 'timeline' && !props.showTimeline\n                && data.inNode\n                && data.inNode.type\n                && data.inNode._id\n                && reduxStore.getState().db[dbNotify]\n                && reduxStore.getState().db[dbNotify][data.inNode._id]\n                && timeline[data.inNode._id]\n                && timeline[data.inNode._id][data.nodeId]\n                &&\n                <div\n                    style={{ display: 'flex', cursor: 'pointer' }}\n                    onClick={() => {\n                        if (data.inNode.type === 'User') {\n                            let userId\n                            if (data && data.inNode && data.inNode._id\n                                && reduxStore.getState().db\n                                && reduxStore.getState().db.users\n                                && reduxStore.getState().db.users[data.inNode._id]\n                                && timeline[data.inNode._id]\n                                && Object.keys(timeline[data.inNode._id]).length > 0\n                                && timeline[data.inNode._id][data.nodeId])\n                                userId = timeline[data.inNode._id][data.nodeId].user._id\n                            openChat(userId, 'users')\n                        }\n                        if (data.inNode.type === 'Card') {\n                            if (reduxStore.getState().db.cards[data.inNode._id].type !== 'chatGroup') {\n                                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                    ...reduxStore.getState().sideMudule,\n                                    db: 'cards',\n                                    id: data.inNode._id,\n                                    module: \"cardEdit\",\n                                    activeModule: 'timeline',\n                                    data: reduxStore.getState().db.cards[data.inNode._id],\n                                });\n                            } else {\n                                openChat(data.inNode._id, 'cards')\n                            }\n                        }\n                    }}\n                >\n                    <Message\n                        storie={data && data.inNode && data.inNode._id\n                            && reduxStore.getState().db\n                            && reduxStore.getState().db[dbNotify]\n                            && reduxStore.getState().db[dbNotify][data.inNode._id]\n                            && timeline[data.inNode._id]\n                            && Object.keys(timeline[data.inNode._id]).length > 0\n                            && timeline[data.inNode._id][data.nodeId]\n                            ? timeline[data.inNode._id][data.nodeId]\n                            : {}\n                        } boxStyle={{ width: \"calc(100% - 10px) !important\" }} db={dbNotify} />\n                </div>\n            }\n            {(\n                data.module === 'card'\n                && db[dbNotify] && db[dbNotify][data.nodeId]\n            )\n                &&\n                <div\n                    style={reduxStore.getState().db.cards[data.nodeId].type === 'chatGroup' ? { cursor: 'pointer' } : {}}\n                    onClick={(e) => {\n                        if (reduxStore.getState().db.cards[data.nodeId].type === 'chatGroup') {\n                            openChat(data.nodeId, 'cards')\n                        }\n                    }}\n                >\n                    <Header />\n                    <Card db=\"cards\" data={reduxStore.getState().db.cards[data.nodeId]} expanded\n                        onlyOption={reduxStore.getState().db.cards[data.nodeId].type === 'chatGroup' ? true : false}\n                        onClick={(e) => {\n                            if (reduxStore.getState().db.cards[data.nodeId].type === 'chatGroup') {\n                                openChat(data.nodeId, 'cards')\n                            }\n                        }}\n                    />\n\n                </div>\n            }\n\n\n            {\n                (\n                    props.showTimeline && db[dbNotify] && db[dbNotify][data.inNode._id]\n                )\n                &&\n                <GridContainer>\n                    <GridItem\n                        xs={12}\n                        sm={12}\n                        md={4}\n                        lg={4}\n                        xl={4}\n                    >\n                        <div\n                            style={reduxStore.getState().db.cards[data.inNode._id].type === 'chatGroup' ? { cursor: 'pointer' } : {}}\n                            onClick={(e) => {\n                                if (reduxStore.getState().db.cards[data.inNode._id].type === 'chatGroup') {\n                                    openChat(data.inNode._id, 'cards')\n                                }\n                            }}\n                        >\n                            <Header />\n                            <Card db=\"cards\" data={reduxStore.getState().db.cards[data.inNode._id]} expanded\n                                onlyOption={reduxStore.getState().db.cards[data.inNode._id].type === 'chatGroup' ? true : false}\n                                onClick={(e) => {\n                                    if (reduxStore.getState().db.cards[data.inNode._id].type === 'chatGroup') {\n                                        openChat(data.inNode._id, 'cards')\n                                    }\n                                }}\n                            />\n                        </div>\n                    </GridItem>\n                    <GridItem\n                        xs={12}\n                        sm={12}\n                        md={8}\n                        lg={8}\n                        xl={8}\n                    >\n                        <div style={{ position: 'relative', width: '100%', minHeight: '250px' }}>\n                            <MiniTimeline\n                                nodeId={data.inNode._id}\n                                stories={\n                                    data\n                                        && data.inNode\n                                        && data.inNode._id\n                                        && reduxStore.getState().db.cards[data.inNode._id]\n                                        && timeline[data.inNode._id]\n                                        ? timeline[data.inNode._id]\n                                        : {}\n                                }\n                                db={'cards'}\n                            />\n                        </div>\n                    </GridItem>\n                </GridContainer>\n            }\n        </div>\n    )\n}\n\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst sidebarStyle = theme => ({\r\n  bar: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '0px',\r\n    width: '147px',\r\n    height: 'calc(100vh - 0px)',\r\n    // backgroundColor: customApp('menu'),\r\n    // zIndex: '133 !important',\r\n    // boxShadow: '3px 0px 10px 0px rgb(0 0 0 / 52%)'\r\n  },\r\n  item: {\r\n    height: '47px',\r\n    alignItems: 'center',\r\n    // justifyContent: 'center',\r\n    width: '100%',\r\n    display: 'flex',\r\n    // marginBottom: '15px'\r\n  },\r\n  itemButtom: {\r\n    width: '100%',\r\n    padding: '7px',\r\n    color: customApp('menuButtonColor', 0.8),\r\n    '&:hover': {\r\n      color: customApp('menuButtonColor', 1),\r\n      backgroundColor: 'rgba(255,255,255,0.1)',\r\n      borderRadius: '0px',\r\n    },\r\n    display: 'flex',\r\n    fontSize: \"12px\",\r\n    fontWeight: \"bold\",\r\n    // justifyContent: 'center',\r\n    alignItems: 'center',\r\n    alignItems: 'center',\r\n    // flexDirection: 'column',\r\n    // textAlign: 'center',\r\n    cursor: 'pointer',\r\n  },\r\n  itemButtomActive: {\r\n    width: '100%',\r\n    padding: '7px',\r\n    color: customApp('menuButtonColor', 1),\r\n    backgroundColor: 'rgba(255,255,255,0.2)',\r\n    borderRadius: '0px',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    fontSize: \"12px\",\r\n    fontWeight: \"bold\",\r\n    // flexDirection: 'column',\r\n    // textAlign: 'center',\r\n    cursor: 'pointer',\r\n  },\r\n  themeExample: {\r\n    [theme.breakpoints.up(\"md\")]: {\r\n      left: \"auto !important\",\r\n      right: \"0 !important\"\r\n    },\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      left: \"0  !important\",\r\n      right: \"auto !important\"\r\n    }\r\n  },\r\n  module: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '147px',\r\n    width: '50px',\r\n    height: '100vh',\r\n    backgroundColor: 'rgba(246,246,246,1)',\r\n    boxShadow: 'inset 4px 0px 3px 0px rgb(0 0 0 / 17%)',\r\n    borderRight: `solid 4px ${customApp('color')}`,\r\n  },\r\n  moduleExpanded: {\r\n    position: 'fixed',\r\n    top: '0',\r\n    left: '147px',\r\n    width: '311px',\r\n    height: '100vh',\r\n    backgroundColor: 'rgba(246,246,246,1)',\r\n    zIndex: '100 !important',\r\n    boxShadow: 'inset 4px 0px 3px 0px rgb(0 0 0 / 17%)',\r\n    borderRight: `solid 4px ${customApp('color')}`,\r\n    padding: '7px',\r\n    overflowX: 'auto'\r\n  },\r\n  moduleTitle: {\r\n    width: '100%',\r\n    height: '30px',\r\n    fontSize: '18px',\r\n    color: customApp('menuButtonColor'),\r\n    fontWeight: 'bold',\r\n    paddingLeft: '7px',\r\n    marginTop: '15px'\r\n  },\r\n  sidebarWrapperWithPerfectScrollbar: {\r\n    // overflow: \"hidden !important\"\r\n  },\r\n  separator: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    padding: '7px',\r\n    borderTop: `1px solid ${customApp('medium', 0.5)}`,\r\n    marginTop: '15px',\r\n    marginBottom: '0px',\r\n    height: '1px'\r\n  },\r\n  logoImg: {\r\n    width: \"66%\",\r\n    marginTop: '15px',\r\n    justifyContent: 'center'\r\n  },\r\n  user: {\r\n    zIndex: '150 !important'\r\n  }\r\n});\r\n\r\nexport default sidebarStyle;\r\n","//CORE\nimport React from \"react\";\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\nimport history from \"store/history\"\n\n//COMPONENTS\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\nimport NotificationCard from \"components/Notifications/fullCard\";\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sidebarInteractive.js\";\n\n\n\n//FUNCTIONS\nimport { translate } from \"functions/\";\n\nrequire('dotenv').config()\n\n\nfunction Component(props) {\n    const { db, session, chat, notifications, timeline } = reduxStore.getState()\n    const { classes } = props\n    const [mounted, setMounted] = React.useState(false)\n    const [viewModule, setViewModule] = React.useState(null);\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true)\n        }\n    }, [notifications])\n\n\n\n    const openModule = async (route, vm, nodeId, dbProps = 'users') => {\n        if (route && (window.location.pathname !== route || vm === viewModule)) {\n            history.push(route)\n            // props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            //     ...reduxStore.getState().db,\n            //     history: route\n            // });\n        }\n\n        setViewModule(vm)\n\n        if (vm === 'chat' && !nodeId) {\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...chat,\n                open: true,\n            })\n        } else if (vm === 'chat' && nodeId) {\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...chat,\n                open: true,\n                db: dbProps,\n                nodeId: nodeId,\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...chat,\n                open: false,\n            })\n        }\n    }\n\n    //CARDS COLUMN\n    const cardNotifications = []\n    const cardsNotifications = []\n\n    Object.keys(notifications).sort((a, b) => {\n        if (parseInt(notifications[a].created_at) > parseInt(notifications[b].created_at))\n            return -1\n        return 1\n    })\n        .filter(fil => notifications[fil].module === 'card')\n        .sort((a, b) => notifications[a].created_at.low - notifications[b].created_at.low)\n        .map((n, i) => {\n            if (cardsNotifications.indexOf(notifications[n].nodeId) === -1) {\n                cardNotifications.push(n)\n                cardsNotifications.push(notifications[n].nodeId)\n            }\n        })\n\n    //TIMELINE COLUMN\n    const tmNotifications = []\n    const tmsNotifications = []\n\n    Object.keys(notifications).sort((a, b) => {\n        if (parseInt(notifications[a].created_at) > parseInt(notifications[b].created_at))\n            return -1\n        return 1\n    })\n        .filter(fil => notifications[fil].module === 'timeline')\n        .sort((a, b) => notifications[a].created_at.low - notifications[b].created_at.low)\n        .map((n, i) => {\n            if (notifications[n].inNode && notifications[n].inNode._id && tmsNotifications.indexOf(notifications[n].inNode._id) === -1) {\n                tmNotifications.push(n)\n                tmsNotifications.push(notifications[n].inNode._id)\n            }\n        })\n\n    const expanded = db.myTasksMenuExpanded ? true : false\n\n    return (\n        <div>\n            <GridContainer>\n                <GridItem\n                    xs={12}\n                    sm={12}\n                    md={12}\n                    lg={12}\n                    xl={12}\n                >\n                    <div className={classes.moduleTitle}>\n                        {translate('$__notifications')}\n                    </div>\n                </GridItem>\n                <GridItem\n                    xs={12}\n                    sm={6}\n                    md={4}\n                    lg={4}\n                    xl={4}\n                >\n                    <div className={classes.moduleTitle}>\n                        {translate('$__cardsUpdated')}\n                    </div>\n                    {cardNotifications.map(n => {\n                        if (\n                            !hashs[1]\n                            ||\n                            (\n                                hashs[1]\n                                &&\n                                (\n                                    hashs[1] === 'important'\n                                    || hashs[1] === 'favorite'\n                                    || hashs[1] === 'archive'\n                                    || hashs[1] === 'latest'\n                                )\n                            )\n                        ) {\n                            return (\n                                <NotificationCard\n                                    data={notifications[n]}\n                                    key={n}\n                                />\n                            )\n                        }\n                    }\n                    )}\n                </GridItem>\n                <GridItem\n                    xs={12}\n                    sm={6}\n                    md={8}\n                    lg={8}\n                    xl={8}\n                >\n                    <div className={classes.moduleTitle}>\n                        {translate('$__timelineUpdated')}\n                    </div>\n                    {tmNotifications.map(n => {\n                        if (\n                            !hashs[1]\n                            ||\n                            (\n                                hashs[1]\n                                &&\n                                (\n                                    hashs[1] === 'important'\n                                    || hashs[1] === 'favorite'\n                                    || hashs[1] === 'archive'\n                                    || hashs[1] === 'latest'\n                                )\n                            )\n                        ) {\n                            return (\n                                <NotificationCard\n                                    data={notifications[n]}\n                                    key={n}\n                                    openChat={(id, db) => openModule(null, 'chat', id, db)}\n                                    showTimeline\n                                    timeline={notifications[n]\n                                        && notifications[n].inNode\n                                        && notifications[n].inNode._id\n                                        && db.cards[notifications[n].inNode._id]\n                                        && timeline[notifications[n].inNode._id]\n                                        ? timeline[notifications[n].inNode._id]\n                                        : {}\n                                    }\n                                />\n                            )\n                        }\n                    }\n                    )}\n                </GridItem>\n\n            </GridContainer>\n        </div>\n    )\n}\n\n\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","import React from 'react';\nimport { withStyles } from '@material-ui/core/styles';\nimport LinearProgress from '@material-ui/core/LinearProgress';\n\n//FUNCTIONS\nimport { customApp } from \"functions/\";\n\nconst styles = {\n    root: {\n        position: 'relative',\n        width: `100%`,\n        backgroundColor: `${customApp('color', '0.1')} !important`,\n        '& .MuiLinearProgress-indeterminate': {\n            backgroundColor: `#FFFFFF !important`\n        },\n        '& .MuiLinearProgress-bar': {\n            backgroundColor: `${customApp('color')} !important`\n        },\n        '& .text': {\n            position: 'absolute',\n            width: '40px',\n            right: '-40px',\n            top: '-9px',\n            textAlign: 'right',\n            textSize: '11px',\n            fontWeight: 'bold',\n            color: customApp('color')\n        }\n    },\n    bar: {\n        borderRadius: 7,\n    },\n\n}\n\nfunction Component(props) {\n    const { classes } = props\n    return (\n        <div className={classes.root}>\n            <LinearProgress />\n        </div>\n    )\n}\n\nexport default withStyles(styles)(Component)","import {\r\n  primaryColor,\r\n  dangerColor,\r\n  roseColor,\r\n  grayColor,\r\n  blackColor,\r\n  whiteColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst customCheckboxRadioSwitch = {\r\n  checkRoot: {\r\n    padding: \"14px\",\r\n    \"&:hover\": {\r\n      backgroundColor: \"unset\"\r\n    }\r\n  },\r\n  radioRoot: {\r\n    padding: \"16px\",\r\n    \"&:hover\": {\r\n      backgroundColor: \"unset\"\r\n    }\r\n  },\r\n  labelRoot: {\r\n    marginLeft: \"-14px\"\r\n  },\r\n  checkboxAndRadio: {\r\n    position: \"relative\",\r\n    display: \"block\",\r\n    marginTop: \"10px\",\r\n    marginBottom: \"10px\"\r\n  },\r\n  checkboxAndRadioHorizontal: {\r\n    position: \"relative\",\r\n    display: \"block\",\r\n    \"&:first-child\": {\r\n      marginTop: \"10px\"\r\n    },\r\n    \"&:not(:first-child)\": {\r\n      marginTop: \"-14px\"\r\n    },\r\n    marginTop: \"0\",\r\n    marginBottom: \"0\"\r\n  },\r\n  checked: {\r\n    color: primaryColor[0] + \"!important\"\r\n  },\r\n  checkedIcon: {\r\n    width: \"20px\",\r\n    height: \"20px\",\r\n    border: \"1px solid rgba(\" + hexToRgb(blackColor) + \", .54)\",\r\n    borderRadius: \"3px\",\r\n    display: \"flex\",\r\n    justifyContent: \"center\",\r\n    alignItems: \"center\"\r\n  },\r\n  uncheckedIcon: {\r\n    width: \"0px\",\r\n    height: \"0px\",\r\n    padding: \"9px\",\r\n    border: \"1px solid rgba(\" + hexToRgb(blackColor) + \", .54)\",\r\n    borderRadius: \"3px\",\r\n    display: \"flex\",\r\n    justifyContent: \"center\",\r\n    alignItems: \"center\"\r\n  },\r\n  disabledCheckboxAndRadio: {\r\n    \"& $checkedIcon,& $uncheckedIcon,& $radioChecked,& $radioUnchecked\": {\r\n      borderColor: blackColor,\r\n      opacity: \"0.26\",\r\n      color: blackColor\r\n    }\r\n  },\r\n  label: {\r\n    cursor: \"pointer\",\r\n    paddingLeft: \"0\",\r\n    color: grayColor[3],\r\n    fontSize: \"12px\",\r\n    lineHeight: \"1.428571429\",\r\n    fontWeight: \"400\",\r\n    display: \"inline-flex\",\r\n    transition: \"0.3s ease all\",\r\n    letterSpacing: \"unset\"\r\n  },\r\n  labelHorizontal: {\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.26)\",\r\n    cursor: \"pointer\",\r\n    display: \"inline-flex\",\r\n    fontSize: \"12px\",\r\n    lineHeight: \"1.428571429\",\r\n    fontWeight: \"400\",\r\n    paddingTop: \"39px\",\r\n    marginRight: \"0\",\r\n    \"@media (min-width: 992px)\": {\r\n      float: \"right\"\r\n    }\r\n  },\r\n  labelHorizontalRadioCheckbox: {\r\n    paddingTop: \"22px\"\r\n  },\r\n  labelLeftHorizontal: {\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.26)\",\r\n    cursor: \"pointer\",\r\n    display: \"inline-flex\",\r\n    fontSize: \"12px\",\r\n    lineHeight: \"1.428571429\",\r\n    fontWeight: \"400\",\r\n    paddingTop: \"22px\",\r\n    marginRight: \"0\"\r\n  },\r\n  labelError: {\r\n    color: dangerColor[0]\r\n  },\r\n  radio: {\r\n    color: primaryColor[0] + \"!important\"\r\n  },\r\n  radioChecked: {\r\n    width: \"16px\",\r\n    height: \"16px\",\r\n    border: \"1px solid \" + primaryColor[0],\r\n    borderRadius: \"50%\"\r\n  },\r\n  radioUnchecked: {\r\n    width: \"0px\",\r\n    height: \"0px\",\r\n    padding: \"7px\",\r\n    border: \"1px solid rgba(\" + hexToRgb(blackColor) + \", .54)\",\r\n    borderRadius: \"50%\"\r\n  },\r\n  inlineChecks: {\r\n    marginTop: \"8px\"\r\n  },\r\n  iconCheckbox: {\r\n    height: \"116px\",\r\n    width: \"116px\",\r\n    color: grayColor[0],\r\n    padding: \"0\",\r\n    margin: \"0 auto 20px\",\r\n    \"& > span:first-child\": {\r\n      borderWidth: \"4px\",\r\n      borderStyle: \"solid\",\r\n      borderColor: grayColor[9],\r\n      textAlign: \"center\",\r\n      verticalAlign: \"middle\",\r\n      borderRadius: \"50%\",\r\n      color: \"inherit\",\r\n      transition: \"all 0.2s\"\r\n    },\r\n    \"&:hover\": {\r\n      color: roseColor[0],\r\n      \"& > span:first-child\": {\r\n        borderColor: roseColor[0]\r\n      }\r\n    }\r\n  },\r\n  iconCheckboxChecked: {\r\n    color: roseColor[0],\r\n    \"& > span:first-child\": {\r\n      borderColor: roseColor[0]\r\n    }\r\n  },\r\n  iconCheckboxIcon: {\r\n    fontSize: \"40px\",\r\n    lineHeight: \"111px\"\r\n  },\r\n  switchBase: {\r\n    color: primaryColor[0] + \"!important\"\r\n  },\r\n  switchIcon: {\r\n    boxShadow: \"0 1px 3px 1px rgba(\" + hexToRgb(blackColor) + \", 0.4)\",\r\n    color: whiteColor + \" !important\",\r\n    border: \"1px solid rgba(\" + hexToRgb(blackColor) + \", .54)\"\r\n  },\r\n  switchIconChecked: {\r\n    borderColor: primaryColor[0],\r\n    transform: \"translateX(0px)!important\"\r\n  },\r\n  switchBar: {\r\n    width: \"30px\",\r\n    height: \"15px\",\r\n    backgroundColor: \"rgb(\" + hexToRgb(grayColor[18]) + \")\",\r\n    borderRadius: \"15px\",\r\n    opacity: \"0.7!important\"\r\n  },\r\n  switchChecked: {\r\n    \"& + $switchBar\": {\r\n      backgroundColor: \"rgba(\" + hexToRgb(primaryColor[0]) + \", 1) !important\"\r\n    },\r\n    \"& $switchIcon\": {\r\n      borderColor: primaryColor[0]\r\n    }\r\n  }\r\n};\r\n\r\nexport default customCheckboxRadioSwitch;\r\n","import {\r\n  container,\r\n  cardTitle,\r\n  blackColor,\r\n  hexToRgb,\r\n  grayColor\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nimport customCheckboxRadioSwitch from \"assets/jss/material-dashboard-pro-react/customCheckboxRadioSwitch.js\";\r\n\r\nconst registerPageStyle = {\r\n  ...customCheckboxRadioSwitch,\r\n  cardTitle: {\r\n    ...cardTitle,\r\n    textAlign: \"center\"\r\n  },\r\n  container: {\r\n    ...container,\r\n    position: \"relative\",\r\n    zIndex: \"3\"\r\n    // paddingTop: \"23vh\"\r\n  },\r\n  cardSignup: {\r\n    borderRadius: \"6px\",\r\n    boxShadow:\r\n      \"0 16px 24px 2px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.14), 0 6px 30px 5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.12), 0 8px 10px -5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.2)\",\r\n    marginBottom: \"100px\",\r\n    padding: \"40px 0px\",\r\n    marginTop: \"15vh\"\r\n  },\r\n  center: {\r\n    textAlign: \"center\"\r\n  },\r\n  right: {\r\n    textAlign: \"right\"\r\n  },\r\n  left: {\r\n    textAlign: \"left\"\r\n  },\r\n  form: {\r\n    padding: \"0 20px\",\r\n    position: \"relative\"\r\n  },\r\n  socialTitle: {\r\n    fontSize: \"18px\"\r\n  },\r\n  inputAdornment: {\r\n    marginRight: \"18px\",\r\n    position: \"relative\"\r\n  },\r\n  inputAdornmentIcon: {\r\n    color: grayColor[6]\r\n  },\r\n  textFields: {\r\n    margin: \"15px 0\",\r\n  },\r\n  checkboxLabelControl: {\r\n    margin: \"0\"\r\n  },\r\n  checkboxLabel: {\r\n    fontSize: \"12px\",\r\n    marginLeft: \"6px\",\r\n    color: \"rgba(\" + hexToRgb(blackColor) + \", 0.26)\"\r\n  }\r\n};\r\n\r\nexport default registerPageStyle;\r\n","import React from \"react\"\n\n//\nimport history from \"store/history\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Password from \"components/Password/\"\nimport Button from \"components/CustomButtons/Button\"\nimport Card from \"components/Card/Card\"\nimport CardBody from \"components/Card/CardBody\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport Icon from \"components/Icon\"\nimport TextField from \"components/TextField\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport Preloader from \"components/PreLoader/linear\"\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\"\nimport Modal from '@material-ui/core/Modal'\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport Checkbox from \"@material-ui/core/Checkbox\"\nimport FormControlLabel from \"@material-ui/core/FormControlLabel\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/registerPageStyle\"\n\n//FUNCTIONS\nimport api from \"api/\"\nimport { translate, customApp, validateEmail, appAlert } from \"functions/\"\nimport { emailExistDB, validateEmailToken, emailTokenGenerate } from \"functions/users\"\n\nconst useStyles = makeStyles(styles)\n\nexport default function RegisterPage(props) {\n  const [checked, setChecked] = React.useState([])\n  const [loading, setLoading] = React.useState(false)\n  const [name, setName] = React.useState(\"\")\n  const [email, setEmail] = React.useState(\"\")\n  const [validatingEmail, setValidatingEmail] = React.useState(false)\n  const [emailError, setEmailError] = React.useState('')\n  const [token, setToken] = React.useState(\"\")\n  const [tokenError, setTokenError] = React.useState(false)\n  const [validatingToken, setValidatingToken] = React.useState(false)\n  const [termsOpen, setTermsOpen] = React.useState(false)\n  const [password, setPassword] = React.useState(null)\n\n  const handleToggle = value => {\n    const currentIndex = checked.indexOf(value)\n    const newChecked = [...checked]\n\n    if (currentIndex === -1) {\n      newChecked.push(value)\n    } else {\n      newChecked.splice(currentIndex, 1)\n    }\n    setChecked(newChecked)\n  }\n  const classes = useStyles()\n\n  const emailValidate = async (e) => {\n    setLoading(true)\n    if (validateEmail(e)) {\n      const exist = await emailExistDB(e)\n      if (exist) {\n        setEmailError(translate('$__emailAlreadyExists', 1))\n        setEmail(\"\")\n        setValidatingEmail(false)\n      } else {\n        setEmailError(null)\n        setValidatingEmail(true)\n        emailTokenGenerate(name, e)\n      }\n    } else {\n      setEmailError(translate('$__invalidEmail', 1))\n      setEmail(\"\")\n    }\n    setLoading(false)\n  }\n\n  const validateToken = async () => {\n    if (token.length >= 6) {\n      setLoading(true)\n      const exist = await validateEmailToken(token, email)\n      if (exist) {\n        setValidatingToken(true)\n        setTokenError(false)\n      } else {\n        setTokenError(true)\n      }\n      setLoading(false)\n    } else {\n      setTokenError(false)\n    }\n  }\n\n  const register = async () => {\n    setLoading(true)\n    try {\n      const res = await api.post('user/register-final-step/', {\n        name,\n        email,\n        token,\n        password,\n        login: true,\n      })\n      if (res) {\n        localStorage.setItem('TOKEN', res.data.token)\n        if (props.callback) {\n          setTimeout(() => {\n            history.push('/login')\n            // props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            //   ...reduxStore.getState().db,\n            //   history: 'login'\n            // })\n          }, 3000)\n        }\n      }\n    } catch (e) {\n      setLoading(false)\n    }\n  }\n  return (\n    <div className={classes.container}>\n      <GridContainer>\n        <GridItem xs={12} sm={10} md={6}>\n          <Card db=\"cards\" className={classes.cardSignup}>\n            <h2 className={classes.cardTitle}>{translate('$__register', 1)}</h2>\n            <CardBody>\n              <GridContainer>\n                <GridItem xs={12}>\n                  <div>\n                    <TextField\n                      className={classes.textFields}\n                      label={translate('$__fullName', 1)}\n                      variant={'standard'}\n                      name={translate('$__fullName', 1)}\n                      InputLabelProps={{\n                        shrink: true,\n                      }}\n                      InputProps={{\n                        endAdornment: (\n                          <InputAdornment position=\"end\">\n                            <Icon className={classes.inputAdornmentIcon}>account_box</Icon>\n                          </InputAdornment>\n                        ),\n                        autoComplete: 'new-password',\n                        onChange: (d) => {\n                          setName(d.target.value)\n                        },\n                      }}\n                      value={name}\n                    />\n                    <TextField\n                      label={translate('$__email', 1)}\n                      variant={customApp('fieldVariant')}\n                      name=\"email\"\n                      type=\"email\"\n                      helperText={emailError}\n                      InputLabelProps={{\n                        shrink: true,\n                      }}\n                      InputProps={{\n                        autoComplete: 'new-password',\n                        className: ((emailError || !email) || !validateEmail(email)) ? \"invalid\" : \"\",\n                        endAdornment: (\n                          <InputAdornment position=\"end\">\n                            <Icon icon='alternate_email' />\n                          </InputAdornment>\n                        ),\n                        onChange: (d) => {\n                          setValidatingEmail(false)\n                          setEmailError(null)\n                          setEmail(d.target.value)\n                        },\n                        onBlur: async (e) => {\n                          emailValidate(e.target.value)\n                        }\n                      }}\n                      value={email}\n                      placeholder={'email@domain.com'}\n                      disabled={validatingEmail}\n                    />\n                    {!validatingEmail &&\n                      <IconButton\n                        icon=\"navigate_next\"\n                        text={translate('$__continue', '*')}\n                        reverse\n                        style={{ float: 'right' }}\n                        onClick={() => {\n                          emailValidate(email)\n                        }}\n                      />\n                    }\n                    {validatingEmail && email &&\n                      <React.Fragment>\n                        <TextField\n                          label={translate('$__emailToken', 1)}\n                          variant={customApp('fieldVariant')}\n                          helperText={translate(!tokenError ? 'registerEmailTokenDescription' : 'registerEmailTokenError')}\n                          type=\"password\"\n                          name=\"emailToken\"\n                          InputLabelProps={{\n                            shrink: true,\n                          }}\n                          InputProps={{\n                            autoComplete: 'new-password',\n                            className: tokenError ? \"invalid\" : \"\",\n                            endAdornment: (\n                              <InputAdornment position=\"end\">\n                                <Icon icon='keyboard' />\n                              </InputAdornment>\n                            ),\n                            onChange: (d) => {\n                              setEmailError(null)\n                              setToken(d.target.value)\n                            }\n                          }}\n                          value={token}\n                          placeholder={'****'}\n                        />\n                        <IconButton\n                          icon=\"reply_all\"\n                          text={translate('$__resendCode', '*')}\n                          reverse\n                          style={{ float: 'right' }}\n                          onClick={() => {\n                            emailTokenGenerate(name, email)\n                          }}\n                        />\n                        {!validatingToken &&\n                          <IconButton\n                            icon=\"navigate_next\"\n                            text={translate('$__continue', '*')}\n                            reverse\n                            style={{ float: 'right' }}\n                            onClick={() => {\n                              validateToken()\n                            }}\n                          />\n                        }\n                      </React.Fragment>\n                    }\n                    {validatingEmail && validatingToken &&\n                      <React.Fragment>\n                        <Password onConfirmed={(v) => { setPassword(v) }} />\n                        <Modal\n                          open={termsOpen}\n                          onClose={() => setTermsOpen(false)}\n                          aria-labelledby=\"simple-modal-title\"\n                          aria-describedby=\"simple-modal-description\"\n                        >\n                          <div\n                            style={{\n                              position: 'absolute',\n                              top: '0px',\n                              left: '0px',\n                              right: '0px',\n                              bottom: '0px',\n                              display: 'flex',\n                              justifyContent: \"center\",\n                              alignItems: \"center\"\n                            }}\n                          >\n                            <div style={{\n                              position: \"relative\",\n                              width: '80vw',\n                              maxHeight: '80vh',\n                              overflowY: \"auto\",\n                              backgroundColor: '#FFFFFF',\n                              padding: '15px',\n                              margin: 'auto'\n                            }}>\n                              <div style={{\n                                position: 'absolute',\n                                right: '3px',\n                                top: '3px'\n                              }}><Icon size='33px' color=\"black\" onClick={() => { setTermsOpen(false) }}>close</Icon></div>\n                              <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. In nisl sapien, scelerisque non enim quis, mollis euismod ante. Nunc facilisis quam ullamcorper, interdum ante non, congue magna. Maecenas euismod nisl sed risus pretium placerat. Nulla dictum dolor sed tincidunt mollis. Nam elit urna, elementum at mattis fringilla, pharetra sed ipsum. Ut eleifend ullamcorper nulla, consequat cursus arcu efficitur eget. Ut et leo sed lacus molestie aliquam. In molestie cursus est vel luctus. Aliquam ut vehicula augue, vitae venenatis ligula. Sed lobortis velit quis quam rutrum, ut pretium arcu semper. Proin a fermentum sem. Phasellus nec auctor elit. Nullam auctor quam ut ullamcorper mattis.</p>\n                              <p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Integer et enim congue, pulvinar elit facilisis, sollicitudin neque. Nulla interdum justo arcu, eu tincidunt arcu suscipit at. Vestibulum quis elementum ante. Mauris et odio in mi ornare tincidunt. Nulla mattis ex vitae magna hendrerit, non interdum dui lobortis. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Sed pretium lorem a orci tempor convallis. Aliquam nec dapibus dolor. Nulla arcu lacus, posuere dictum risus sed, volutpat aliquet nibh. Cras tincidunt viverra finibus.</p>\n                              <p>Nam in scelerisque lectus, nec aliquam mauris. Ut id nisl sit amet lectus posuere placerat quis vel odio. Fusce ultrices ultricies lobortis. Proin sodales sit amet lorem vel viverra. Donec ac libero quis leo malesuada faucibus. Phasellus eu placerat purus. Suspendisse lectus dolor, consectetur sit amet pretium sed, luctus non nulla. In sed pulvinar est. Fusce vitae ligula quis quam tempus tincidunt. Ut congue faucibus mollis. Vestibulum ac diam id metus rhoncus bibendum non quis leo. Donec tempus non ligula sit amet vehicula. Phasellus id lectus ac neque maximus ullamcorper vel non massa.</p>\n                              <p>Donec augue lorem, bibendum vitae egestas sit amet, placerat eu elit. In sapien neque, volutpat sit amet sagittis quis, rutrum sit amet turpis. Quisque cursus ligula at mattis blandit. Donec erat arcu, pellentesque eu odio at, blandit viverra nisl. In sagittis felis nec enim facilisis, dapibus commodo enim feugiat. Proin volutpat elit id sem malesuada euismod. Morbi pulvinar tristique diam non luctus. Aliquam ligula enim, efficitur non nunc ac, vestibulum convallis diam. Quisque varius metus a dui ultricies sagittis.</p>\n                              <p>Quisque vitae convallis arcu, vel convallis leo. Sed in pellentesque tortor. Nulla tristique lacinia tempus. Pellentesque ut neque elementum, accumsan ante sit amet, malesuada nulla. Nam ac vulputate leo. Vestibulum leo mi, consectetur id odio eu, vulputate tincidunt quam. Maecenas finibus purus eget tincidunt vulputate. Etiam a semper felis, et varius lacus. Pellentesque condimentum sollicitudin magna et mollis. Nam sit amet elit rhoncus, pretium enim sed, fringilla sapien. Proin convallis sed velit quis imperdiet. Sed iaculis, velit in tempus mattis, ante neque aliquam augue, ac porttitor nulla tellus in mauris. In elementum lobortis turpis et imperdiet. Praesent auctor placerat ullamcorper. Donec eu facilisis justo.</p>\n                            </div>\n                          </div>\n                        </Modal>\n                        <FormControlLabel\n                          classes={{\n                            root: classes.checkboxLabelControl,\n                            label: classes.checkboxLabel\n                          }}\n                          control={\n                            <Checkbox\n                              tabIndex={-1}\n                              onClick={() => handleToggle(1)}\n                              checkedIcon={\n                                <div className={classes.checkedIcon}><Icon size='16px' >check</Icon></div>\n                              }\n                              icon={<div className={classes.uncheckedIcon}><Icon size='16px' color=\"red\">remove</Icon></div>}\n                              classes={{\n                                checked: classes.checked,\n                                root: classes.checkRoot\n                              }}\n                            />\n                          }\n                          label={\n                            <span>\n                              {translate('$__iAgreeToThe', 1)} <span onClick={() => setTermsOpen(true)} style={{ color: 'blue' }}>terms and conditions</span>.\n                            </span>\n                          }\n                        />\n                        <div className={classes.center}>\n                          {checked.indexOf(1) > -1 && password &&\n                            <Button round color=\"custom_color\" onClick={() => register()}>\n                              Get started\n                            </Button>\n                          }\n                        </div>\n                      </React.Fragment>\n                    }\n                  </div>\n                </GridItem>\n              </GridContainer>\n            </CardBody>\n            {loading &&\n              <div style={{ position: 'absolute', bottom: '0px', width: '100%' }}>\n                <Preloader />\n              </div>\n            }\n          </Card>\n        </GridItem>\n      </GridContainer>\n    </div>\n  )\n}\n","// \r\nimport AutoSizer from \"react-virtualized-auto-sizer\"\r\nimport React, { useState, useLayoutEffect, useRef } from \"react\"\r\nimport { DragDropContext, Droppable, Draggable } from \"react-beautiful-dnd\"\r\nimport { VariableSizeList, areEqual } from \"react-window\"\r\nimport moment from \"moment-timezone\"\r\n\r\n//COMPONENTS\r\nimport Card from \"components/Card\";\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport HeaderWithIcon from \"components/Header/withIcon\"\r\nimport IconButton from \"components/CustomButtons/IconButton\";\r\nimport QuickCardAdd from \"components/Quick/card\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n\r\n//STYLE\r\nimport \"./style.css\"\r\n\r\n\r\n//FUNCTIONS\r\nimport { getKanbanData, addColumn, reorder, automation } from \"functions/kanban\"\r\nimport { customApp, translate } from \"functions\"\r\nimport {\r\n    cardsAccess,\r\n    isResponsible as setResponsible\r\n} from \"functions/users\"\r\nimport api from \"api\"\r\n\r\nfunction reorderList(list, startIndex, endIndex) {\r\n    const result = Array.from(list);\r\n    const [removed] = result.splice(startIndex, 1);\r\n    result.splice(endIndex, 0, removed);\r\n\r\n    return result;\r\n}\r\n\r\nfunction getStyle({ draggableStyle, virtualStyle, isDragging }) {\r\n    const combined = {\r\n        ...virtualStyle,\r\n        ...draggableStyle\r\n    }\r\n\r\n    const grid = 8\r\n\r\n    const result = {\r\n        ...combined,\r\n        height: isDragging ? combined.height : combined.height - grid,\r\n        left: isDragging ? combined.left : combined.left + grid,\r\n        width: isDragging\r\n            ? draggableStyle.width\r\n            : `calc(${combined.width} - ${grid * 2}px)`,\r\n        marginBottom: grid\r\n    }\r\n\r\n    return result\r\n}\r\n\r\nconst Item = (props) => {\r\n    const { provided, item, style, isDragging } = props\r\n    return (\r\n        <div\r\n            {...provided.draggableProps}\r\n            {...provided.dragHandleProps}\r\n            style={getStyle({\r\n                draggableStyle: provided.draggableProps.style,\r\n                virtualStyle: style,\r\n                isDragging\r\n            })}\r\n            className={`item ${isDragging ? \"is-dragging\" : \"\"}`}\r\n            ref={provided.innerRef}\r\n        >\r\n            <Card\r\n                data={item}\r\n                db={'cards'}\r\n                isDragging={isDragging}\r\n                manualExpanded={props.manualExpanded || false}\r\n                onResize={(size, expanded) => {\r\n                    if (props.onResize) props.onResize(size)\r\n                }}\r\n                onExpand={(expanded) => {\r\n                    if (props.onExpand) props.onExpand(expanded)\r\n                }}\r\n            />\r\n        </div>\r\n    )\r\n}\r\n\r\nconst ItemList = React.memo(function ItemList(props) {\r\n    const { index, column } = props\r\n\r\n    const listRef = useRef()\r\n    const rowHeights = useRef({})\r\n    const rowExpandeds = useRef({});\r\n\r\n    useLayoutEffect(() => {\r\n        const list = listRef.current\r\n        if (list) {\r\n            list.scrollTo(0)\r\n        }\r\n    }, [index])\r\n\r\n    function getRowHeight(id) {\r\n        return rowHeights.current[id] + 7 || 67\r\n    }\r\n\r\n    function setRowHeight(index, size) {\r\n        if (listRef?.current?.resetAfterIndex)\r\n            listRef.current.resetAfterIndex(0)\r\n        rowHeights.current = {\r\n            ...rowHeights.current, [index]: size\r\n        }\r\n    }\r\n\r\n    function setRowExpanded(index, expanded) {\r\n        if (String(expanded) !== 'undefined' && String(expanded) !== 'null') {\r\n            if (listRef?.current?.resetAfterIndex)\r\n                listRef.current.resetAfterIndex(0);\r\n            rowExpandeds.current = {\r\n                ...rowExpandeds.current, [index]: expanded\r\n            }\r\n        }\r\n    }\r\n\r\n    const Row = (RowProps) => {\r\n        const { data: items, index, style } = RowProps\r\n        const item = items[index]\r\n\r\n        if (!item) {\r\n            return null\r\n        }\r\n\r\n        return (\r\n            <Draggable draggableId={item._id} index={index} key={item._id}>\r\n                {provided => <Item\r\n                    provided={provided}\r\n                    item={item}\r\n                    style={style}\r\n                    manualExpanded={props.cardsExpanded || rowExpandeds?.current[item._id] || false}\r\n                    onResize={(size) => {\r\n                        setRowHeight(item._id, size)\r\n                    }}\r\n                    onExpand={(expanded) => {\r\n                        setRowExpanded(item._id, expanded)\r\n                    }}\r\n                />}\r\n            </Draggable>\r\n        )\r\n    }\r\n\r\n    let itens = column.items //Aqui colocar todos os cards da coluna\r\n\r\n\r\n    return (\r\n        <Droppable\r\n            droppableId={column.id}\r\n            mode=\"virtual\"\r\n            renderClone={(provided, snapshot, rubric) => {\r\n                let card = itens[rubric.source.index]\r\n                return (\r\n                    <Item\r\n                        provided={provided}\r\n                        isDragging={snapshot.isDragging}\r\n                        item={card}\r\n                        manualExpanded={props.cardsExpanded || rowExpandeds?.current[card._id] || false}\r\n                        snapshot={snapshot}\r\n\r\n                    />\r\n                )\r\n            }}\r\n        >\r\n            {(provided, snapshot) => {\r\n                const itemCount = snapshot.isUsingPlaceholder\r\n                    ? itens.length + 1\r\n                    : itens.length\r\n\r\n                return (\r\n                    <AutoSizer style={{\r\n                        width: \"100%\",\r\n                        height: \"100%\"\r\n                    }}\r\n                    >\r\n                        {({ height, width }) => (\r\n                            <VariableSizeList\r\n                                width={279}\r\n                                height={height}\r\n                                itemCount={itemCount}\r\n                                itemSize={(index) => {\r\n                                    return getRowHeight(column.items[index]?._id || null)\r\n                                }}\r\n                                itemData={column.items}\r\n                                className=\"task-list\"\r\n                                ref={listRef}\r\n                                style={{\r\n                                    ...props.style ? props.style : {}\r\n                                }}\r\n                                outerRef={provided.innerRef}\r\n                            >\r\n                                {Row}\r\n                            </VariableSizeList>\r\n                        )}\r\n                    </AutoSizer>\r\n                )\r\n            }}\r\n        </Droppable>\r\n    )\r\n})\r\n\r\nconst Column = React.memo(function Column(props) {\r\n    const { column, index } = props\r\n    const [add, setAdd] = React.useState(false)\r\n\r\n    return (\r\n        <Draggable draggableId={column.id} index={index}>\r\n            {provided => (\r\n                <div\r\n                    className=\"column\"\r\n                    {...provided.draggableProps}\r\n                    ref={provided.innerRef}\r\n                >\r\n                    <div                        {...provided.dragHandleProps}>\r\n                        <HeaderWithIcon\r\n                            title={column.name}\r\n                            icon={column.icon || null}\r\n                            // permitIcon\r\n                            // editable\r\n                            // onEdit={(e) => {\r\n                            //     console.log(e)\r\n                            // }}\r\n                            color={customApp('menu')}\r\n                            style={{\r\n                                padding: '7px',\r\n                                width: \"100%\"\r\n                            }}\r\n                            placeholder={translate(\"$__columnName\")}\r\n                            customButtons={[\r\n                                {\r\n                                    name: translate(\"$__columnSettings\", 1),\r\n                                    icon: \"more_horiz\",\r\n                                    color: customApp('menu'),\r\n                                    onClick: () => {\r\n                                        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\r\n                                            ...reduxStore.getState().sideModule,\r\n                                            db: 'cards',\r\n                                            id: column.id,\r\n                                            module: \"columnEdit\",\r\n                                            activeModule: \"columnEdit\",\r\n                                            data: reduxStore.getState().db.cards[column.id],\r\n                                        })\r\n                                    },\r\n                                    show: 'hover'\r\n                                },\r\n                            ]}\r\n                        />\r\n                    </div>\r\n                    <ItemList column={column} index={index} {...props} />\r\n                    {!add ?\r\n                        <div style={{ position: 'relative', float: 'left', width: '100%', padding: '7px' }}>\r\n                            <IconButton\r\n                                text={translate(\"$__add\", '*')}\r\n                                icon=\"add_box\"\r\n                                iconColor={customApp('medium')}\r\n                                onClick={() => {\r\n                                    setAdd(!add);\r\n                                }}\r\n                            />\r\n                        </div>\r\n                        :\r\n                        <QuickCardAdd\r\n                            nodeId={column.id}\r\n                            onCancel={() => setAdd(false)}\r\n                            rows={column.items.length}\r\n                        />\r\n                    }\r\n                </div>\r\n            )}\r\n        </Draggable>\r\n    )\r\n})\r\n\r\nfunction App(props) {\r\n    const [state, setState] = useState(getKanbanData(props.nodeId))\r\n    const [addColumnActive, setAddColumn] = useState(false)\r\n    const [dragActive, setDragActive] = useState(false)\r\n\r\n    React.useEffect(() => {\r\n        setState(getKanbanData(props.nodeId))\r\n    }, [props.cards, props.nodeId])\r\n\r\n    async function onDragEnd(result) {\r\n        setDragActive(false)\r\n        if (!result.destination) {\r\n            return\r\n        }\r\n        if (result.type === \"column\") {\r\n            const columnOrder = reorderList(\r\n                state.columnOrder,\r\n                result.source.index,\r\n                result.destination.index\r\n            )\r\n            let newColumnOrder = {}\r\n            columnOrder.map((id, orderI) => {\r\n                newColumnOrder = {\r\n                    ...newColumnOrder,\r\n                    [id]: {\r\n                        ...reduxStore.getState().db.cards[id],\r\n                        step: `${(orderI)}`\r\n                    }\r\n                }\r\n            })\r\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                ...reduxStore.getState().db,\r\n                cards: {\r\n                    ...reduxStore.getState().db.cards,\r\n                    ...newColumnOrder\r\n                }\r\n            })\r\n            if (JSON.stringify(columnOrder) !== JSON.stringify(state.columnOrder))\r\n                reorder(columnOrder, 'step')\r\n            return\r\n        }\r\n\r\n        if (result.source.droppableId === result.destination.droppableId) {\r\n            const column = state.columns[result.source.droppableId]\r\n            const items = reorderList(\r\n                column.items,\r\n                result.source.index,\r\n                result.destination.index\r\n            )\r\n\r\n            let newCardsOrder = {}\r\n            let cardsOrder = []\r\n            items.map((card, orderI) => {\r\n                newCardsOrder = {\r\n                    ...newCardsOrder,\r\n                    [card._id]: {\r\n                        ...reduxStore.getState().db.cards[card._id],\r\n                        order: `${(orderI + 1)}`\r\n                    }\r\n                }\r\n                if (cardsOrder.indexOf(card._id) === -1)\r\n                    cardsOrder.push(card._id)\r\n            })\r\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                ...reduxStore.getState().db,\r\n                cards: {\r\n                    ...reduxStore.getState().db.cards,\r\n                    ...newCardsOrder\r\n                }\r\n            })\r\n\r\n            reorder(cardsOrder, 'order')\r\n\r\n            return\r\n        }\r\n\r\n        const sourceColumn = state.columns[result.source.droppableId]\r\n        const item = sourceColumn.items[result.source.index]\r\n\r\n        //LINK\r\n        let parentCard = reduxStore.getState().db.cards[result.destination.droppableId]\r\n        let card = reduxStore.getState().db.cards[sourceColumn.items[result.source.index]._id]\r\n\r\n        let dataUpdate = automation(props, card._id, parentCard._id)\r\n\r\n        if (parentCard.requireApproval) {\r\n            dataUpdate = {\r\n                ...dataUpdate,\r\n                _requireApproval: true\r\n            }\r\n        } else if (!parentCard.requireApproval && item._requireApproval) {\r\n            dataUpdate = {\r\n                ...dataUpdate,\r\n                _requireApproval: null\r\n            }\r\n        }\r\n\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...reduxStore.getState().db,\r\n            cards: {\r\n                ...reduxStore.getState().db.cards,\r\n                [item._id]: {\r\n                    ...reduxStore.getState().db.cards[item._id],\r\n                    ...dataUpdate,\r\n                    _parent: result.destination.droppableId,\r\n                }\r\n            }\r\n        })\r\n    }\r\n\r\n    const newColumn = async (data) => {\r\n        let response = await addColumn(data)\r\n        if (response) {\r\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                ...reduxStore.getState().db,\r\n                cards: {\r\n                    ...reduxStore.getState().db.cards,\r\n                    ...response\r\n                }\r\n            })\r\n        }\r\n    }\r\n\r\n\r\n    return (\r\n        <DragDropContext\r\n            onDragEnd={onDragEnd}\r\n            onDragStart={() => {\r\n                setDragActive(true)\r\n            }}>\r\n            <div\r\n                className=\"app\"\r\n                style={{\r\n                    display: \"flex\",\r\n                    overflowY: \"auto\"\r\n                }}\r\n            >\r\n                <Droppable\r\n                    // className=\"app\"\r\n                    droppableId=\"all-droppables\"\r\n                    direction=\"horizontal\"\r\n                    // isDropDisabled\r\n                    type=\"column\"\r\n                // ignoreContainerClipping\r\n                >\r\n                    {provided => (\r\n                        <div\r\n                            {...provided.droppableProps}\r\n                            className=\"columns\"\r\n                            ref={provided.innerRef}\r\n                        >\r\n                            {state.columnOrder.map((columnId, index) => (\r\n                                <Column\r\n                                    {...props}\r\n                                    key={columnId}\r\n                                    column={state.columns[columnId]}\r\n                                    index={index}\r\n                                    {...props.columProps ? props.columProps : {}}\r\n                                />\r\n                            ))}\r\n                            <div className=\"column\"\r\n                                style={{\r\n                                    display: dragActive ? \"none\" : \"flex\",\r\n                                    justifyContent: \"center\",\r\n                                    height: \"100%\",\r\n                                }}\r\n                            >\r\n                                {!addColumnActive ?\r\n                                    <div\r\n                                        style={{\r\n                                            display: \"flex\",\r\n                                            alignItems: \"center\",\r\n                                            justifyContent: \"center\",\r\n                                            backgroundColor: \"#FFFFFF\",\r\n                                            color: \"black\",\r\n                                            padding: 15,\r\n                                            width: 279\r\n                                        }}\r\n                                    >\r\n                                        <CustomButton\r\n                                            title={translate(\"$__addColumn\")}\r\n                                            text={translate(\"$__addColumn\")}\r\n                                            color={\"lightgrey\"}\r\n                                            textColor={\"lightgrey\"}\r\n                                            icon={\"add_box\"}\r\n                                            onClick={() => {\r\n                                                setAddColumn(true)\r\n                                            }}\r\n\r\n                                            size={\"25px\"}\r\n                                        />\r\n                                    </div>\r\n                                    :\r\n                                    <div\r\n                                        style={{\r\n                                            display: \"flex\",\r\n                                            alignItems: \"center\",\r\n                                            justifyContent: \"center\",\r\n                                            backgroundColor: \"#FFFFFF\",\r\n                                            width: 279,\r\n                                            padding: 7\r\n                                        }}\r\n                                    >\r\n                                        <HeaderWithIcon\r\n                                            style={{\r\n                                                width: \"100%\",\r\n                                            }}\r\n                                            title={null}\r\n                                            color={customApp('menu')}\r\n                                            editable\r\n                                            permitIcon\r\n                                            onEdit={(e) => {\r\n                                                setAddColumn(false)\r\n                                                newColumn({\r\n                                                    ...e,\r\n                                                    _parent: props.nodeId,\r\n                                                    type: \"step\",\r\n                                                    step: String(state.columnOrder.length),\r\n                                                    checklist: true\r\n                                                })\r\n                                            }}\r\n                                            placeholder={translate(\"$__columnName\")}\r\n                                            onCancel={() => { setAddColumn(false) }}\r\n                                        />\r\n                                    </div>\r\n                                }\r\n                            </div>\r\n                            {provided.placeholder}\r\n                        </div>\r\n                    )}\r\n                </Droppable>\r\n            </div>\r\n        </DragDropContext>\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    cards: store.db.cards,\r\n    cardsExpanded: store.db.cardsExpanded,\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(App)","import {\r\n  defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = {\r\n  container: {\r\n    ...defaultFont,\r\n    position: 'relative',\r\n    border: `0.5px solid ${customApp('light')}`,\r\n    borderRadius: '2px',\r\n    padding: '0px',\r\n    display: 'block',\r\n    minWidth: '240px !important',\r\n    backgroundColor: '#FFFFFF',\r\n    boxShadow: '0px 0px 10px rgba(0,0,0,0.1)',\r\n    overflow: 'hidden',\r\n    minHeight: '50px',\r\n  },\r\n  parent: {\r\n    width: '100%',\r\n    padding: '0 5px',\r\n    '& .title': {\r\n      color: customApp('medium'),\r\n      fontSize: '10px',\r\n      textTransform: 'uppercase'\r\n    },\r\n    '& .info': {\r\n      marginTop: '-8px',\r\n      color: customApp('color'),\r\n      fontWeight: '500'\r\n    }\r\n  },\r\n  indicators: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    padding: '0 5px',\r\n    height: 'auto',\r\n    display: 'flex',\r\n  },\r\n  indicatorsIcon: {\r\n    margin: '0px 0px',\r\n  },\r\n  image: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    maxWidth: '100%',\r\n    // paddingBottom: '48%',\r\n    backgroundColor: 'rgb(0,0,0)',\r\n    backgroundSize: 'cover',\r\n    backgroundPosition: 'center',\r\n  },\r\n  progress: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    padding: '0 12px',\r\n    width: 'calc(100% - 15x)'\r\n  },\r\n  description: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    padding: '5px',\r\n  },\r\n  dates: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    marginTop: '7px',\r\n    padding: '0 5px',\r\n    marginRight: '15px',\r\n    color: customApp('medium'),\r\n    fontSize: '10px',\r\n    display: 'flex',\r\n  },\r\n  dateInfo: {\r\n    marginRight: '15px',\r\n    display: 'flex',\r\n    alignItems: 'center'\r\n  },\r\n  users: {\r\n    position: 'absolute',\r\n    bottom: '2px',\r\n    right: '2px',\r\n    fontSize: '10px',\r\n    '& .MuiAvatarGroup-root': {\r\n      justifyContent: 'flex-end',\r\n    },\r\n    '& .MuiAvatar-root': {\r\n      width: '25px',\r\n      height: '25px',\r\n      fontSize: '10px',\r\n    }\r\n  }\r\n};\r\n\r\nexport default style;\r\n","import React, { memo } from \"react\";\nimport { Draggable } from \"react-beautiful-dnd\";\n\n//REDUX\nimport reduxStore from \"store\";\n\n//COMPONENTS\nimport Card from \"components/Card\";\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Agile-Card.js\";\nimport { customApp } from \"functions\";\n\nfunction Component(props) {\n    const { data } = props\n    const { db } = reduxStore.getState()\n    let indicators = []\n\n    let cards = db.cards\n\n    const getStyle = (style, snapshot) => {\n        if (!snapshot.isDropAnimating) {\n            return {\n                ...style,\n            };\n        }\n        const { moveTo, curve, duration } = snapshot.dropAnimation;\n        // move to the right spot\n        const translate = `translate(${moveTo.x}px, ${moveTo.y}px)`;\n        const rotate = ``;\n        return {\n            ...style,\n            clear: 'both',\n            transition: `all 0.1s ease`,\n            transform: `${translate} ${rotate}`,\n            border: `solid 3px ${customApp('color')}`,\n            backgroundColor: customApp('color'),\n            padding: '3px'\n        };\n\n\n    }\n\n    Object.keys(cards).map(a => {\n        if (cards[a]._parent === data._id) {\n            indicators[cards[a].type] = indicators[cards[a].type] == null ? 1 : indicators[cards[a].type] + 1\n        }\n        return false\n    })\n    return (\n        <Draggable\n            draggableId={data.id ? data.id : data._id ? data._id : null}\n            index={Math.floor(Math.random() * 10)}\n            key={data.id ? data.id : data._id ? data._id : null}\n            isDragDisable={data.isDragDisable || props.isDragDisable || false}\n        >\n            {(provided, snapshot) => (\n                <div\n                    ref={provided.innerRef}\n                    {...provided.draggableProps}\n                    {...provided.dragHandleProps}\n                    style={getStyle(provided.draggableProps.style, snapshot)}>\n                    <Card\n                        data={props.data}\n                        db={props.db}\n                        showOrder={props.showOrder || false}\n                        showSelected={props.showSelected || false}\n                        locked={props.locked || false}\n                        viewButton={props.viewButton || false}\n                        showConnectedIn={props.showConnectedIn ? true : false}\n                        isDragging={snapshot.isDragging && !snapshot.isDropAnimating}\n                        snapshot={snapshot}\n                        cardColorPicker={props.cardColorPicker ? true : false}\n                    />\n                </div>\n            )}\n        </Draggable>\n    )\n}\n\nexport default withStyles(styles)(memo(Component))","import React from 'react';\nimport styled from 'styled-components';\nimport { Droppable, Draggable } from 'react-beautiful-dnd';\nimport cx from \"classnames\";\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport HeaderWithIcon from \"components/Header/withIcon\";\nimport Icon from \"components/Icon\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport TextField from \"components/TextField\";\n\n//DEPENDENCIES\nimport CardItem from './Card';\n\n//FUNCTIONS\nimport api from \"api/\";\nimport { translate, customApp } from \"functions/\";\nimport { sortList, updateCardData, cardStatus, getCardColor } from \"functions/cards\";\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Agile-Column.js\";\n\n\n\nfunction Column(props) {\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\n    const { search, session, db } = reduxStore.getState()\n    const { classes } = props\n    const [name, setName] = React.useState('')\n    const [add, setAdd] = React.useState(false)\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace('#', '')\n    if (hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n\n    let filtered = props.cards\n\n    if (search && search.cards && (search.cards.startDate || search.cards.endDate))\n        filtered = filtered.filter(fil => {\n            if (\n                fil\n\n                && (\n                    (\n                        search.cards.startDate\n                        && fil.startDate\n                        && fil.startDate >= search.cards.startDate\n                    )\n                    && (\n                        search.cards.endDate\n                        && fil.endDate\n                        && fil.endDate <= search.cards.endDate\n                    )\n                ))\n                return true\n            return false\n        }).map(res => res)\n    if (search.text)\n        filtered = filtered.filter(fil => {\n            if (fil && fil.name && fil.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n                return true\n            return false\n        }).map(res => res)\n\n    filtered = filtered.filter(fil => {\n        if (!fil.status || (fil && fil.status && search.cards.status[fil.status]))\n            return true\n        return false\n    }).map(res => res)\n\n    filtered = filtered.filter(fil => {\n        if ((fil && fil.priority && search.cards.priority[fil.priority]) || (search.cards.priority['null'] && !fil.priority))\n            return true\n        return false\n    }).map(res => res)\n\n    if (search.users.selected && Object.keys(search.users.selected).length > 0)\n        filtered = filtered.filter(fil => {\n            // if(fil._users && )\n            // console.log(Object.keys(fil._users).filter(uf => search.users.selected[uf]).length)\n            if (fil && fil._users && Object.keys(fil._users).filter(uf => search.users.selected[uf]).length > 0)\n                return true\n        }).map(res => res)\n\n    if (Object.keys(search.units.selected).length > 0) {\n        if (search.units.selected['unassigned']) {\n            filtered = filtered.filter(fil => {\n                if (!fil._planId || (\n                    fil._planId\n                    && db.cards[fil._planId]\n                    && !db.cards[fil._planId].client\n                ))\n                    return true\n            }).map(res => res)\n        } else {\n            filtered = filtered.filter(fil => {\n                let result = false\n                Object.keys(db.cards).filter(plan => {\n                    if (db.cards[plan].client && search.units.selected[db.cards[plan].client])\n                        return true\n                }).map(plan => {\n                    if (fil._planId && fil._planId === db.cards[plan]._id)\n                        result = true\n                })\n                return result\n            }).map(res => res)\n        }\n    }\n\n    if (Object.keys(search.groups.selected).length > 0) {\n        if (search.groups.selected['unassigned']) {\n            filtered = filtered.filter(fil => {\n                if (!fil._planId || (\n                    fil._planId\n                    && db.cards[fil._planId]\n                    && !db.cards[fil._planId].client\n                ))\n                    return true\n            }).map(res => res)\n        } else {\n            filtered = filtered.filter(fil => {\n                let result = false\n                Object.keys(db.cards).filter(plan => {\n                    if (db.cards[plan].client && search.groups.selected[db.cards[plan].client])\n                        return true\n                }).map(plan => {\n                    if (fil._planId && fil._planId === db.cards[plan]._id)\n                        result = true\n                })\n                return result\n            }).map(res => res)\n        }\n    }\n\n    if (Object.keys(search.plans.selected).filter(a => a).length > 0) {\n        filtered = filtered.filter(fil => {\n            if (search.plans.selected[fil._planId]) return true\n        }).map(res => res)\n    }\n\n    if (search.tags.length > 0) {\n        filtered = filtered.filter(fil =>\n            fil._tags && fil._tags.length > 0 && fil._tags.filter(tag => {\n                let result = false\n                search.tags.map(tagFilter => {\n                    if (tagFilter.value === tag.value)\n                        result = true\n                })\n                return result\n            }\n            ).length > 0\n        ).map(res => res)\n    }\n\n    let subtractDays = String(session.dashboard.period).replace('$__last', '')\n    subtractDays = subtractDays.replace('Days', '')\n\n    const startDate = moment(new Date()).tz('America/Sao_Paulo').subtract(parseInt(subtractDays), 'd').format('YYYY-MM-DDT00:00')\n    const endDate = moment(new Date()).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59')\n\n    if (props && props.periodFilter)\n        filtered = filtered.filter(fil => {\n            if (\n                (fil.status === 'completed'\n                    && fil.completed_at\n                    && (\n                        (fil.completed_at.low\n                            && moment(new Date(fil.completed_at.low * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59') <= endDate\n                            && moment(new Date(fil.completed_at.low * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT00:00') >= startDate)\n                        || (fil.completed_at && !fil.completed_at.low\n                            && moment(new Date(fil.completed_at * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59') <= endDate\n                            && moment(new Date(fil.completed_at * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT00:00') >= startDate)\n                    )\n                )\n                ||\n                (\n                    fil.status !== 'completed'\n                    && fil.updated_at\n                    && (\n                        (fil.updated_at.low\n                            && moment(new Date(fil.updated_at.low * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59') <= endDate\n                            && moment(new Date(fil.updated_at.low * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT00:00') >= startDate)\n                        || (fil.updated_at && !fil.updated_at.low\n                            && moment(new Date(fil.updated_at * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT23:59') <= endDate\n                            && moment(new Date(fil.updated_at * 1000)).tz('America/Sao_Paulo').format('YYYY-MM-DDT00:00') >= startDate)\n                    )\n                )\n            )\n                return true\n        }\n        ).map(res => res)\n\n    // console.log(props.showDeleted,)\n    if (!props.showDeleted && !reduxStore.getState().controls.deleted) {\n        filtered = filtered.filter(fil => !fil.deleted).map(res => res)\n    }\n    // setFiltered(filtered)\n    // }\n\n    const list =\n        classes.cardList +\n        \" \" +\n        cx({\n            [classes.mainPanelWithPerfectScrollbar]:\n                navigator.platform.indexOf(\"Win\") > -1\n        });\n\n    const addCard = async () => {\n        const { socket } = reduxStore.getState().functions\n        socket.emit(\"data\", {\n            module: \"cards\",\n            method: \"post\",\n            action: \"add\"\n        }, {\n            _parent: props.selectedParent ? props.selectedParent : hashs[0] ? hashs[0] : null,\n            _planId: hashs[0] && hashs[0].length === 36 ? hashs[0] : null,\n            name,\n            type: props.typeAdd ? props.typeAdd : props.columnId.length < 36 ? props.columnId : null,\n            status: 'notStarted',\n        }, async (response) => {\n            // socket.emit('card.UPD', {\n            //     cardId: response.id,\n            //     cardData: {\n            //         name,\n            //         type: props.columnId,\n            //         order: response.order,\n            //         _planId: hashs[0] && hashs[0].length === 36 ? hashs[0] : null,\n            //         ...response.data,\n            //         // _loaded: true,\n            //         _parent: props.selectedParent ? props.selectedParent : hashs[0] ? hashs[0] : null,\n            //         _timeline: {\n            //             [response.log._id]: {\n            //                 ...response.log,\n            //                 _parent: [response.id],\n            //             }\n            //         },\n            //         _users: {\n            //             [session._id]: {\n            //                 name: reduxStore.getState().db.users[session._id].name ? reduxStore.getState().db.users[session._id].name : null,\n            //                 displayName: reduxStore.getState().db.users[session._id].displayName ? reduxStore.getState().db.users[session._id].displayName : null,\n            //                 image: reduxStore.getState().db.users[session._id].image ? reduxStore.getState().db.users[session._id].image : null,\n            //                 access: 5,\n            //                 _id: session._id\n            //             }\n            //         }\n            //     },\n            // })\n        })\n        setName('')\n    }\n    let columnName = translate(props.column.name, 1)\n    let customColumns = {}\n    if (reduxStore.getState().db.cards[hashs[0]] && reduxStore.getState().db.cards[hashs[0]].customColumns)\n        customColumns = JSON.parse(reduxStore.getState().db.cards[hashs[0]].customColumns)\n\n    if (\n        customColumns\n        && customColumns[props.column.name.replace(\"$__\", \"\")]\n        && customColumns[props.column.name.replace(\"$__\", \"\")].name\n    )\n        columnName = translate(customColumns[props.column.name.replace(\"$__\", \"\")].name, 1)\n\n    let cardbyGroup = []\n\n    return (\n        <Draggable draggableId={props.columnId ? String(props.columnId) : 'NOT_ID_SENDED'} index={props.index} >\n            {provided => (\n                <Container\n                    {...!props.isDropDisabled && provided.draggableProps}\n                    {...props}\n                    ref={provided.innerRef}\n                >\n                    <div {...provided.draggableProps}{...provided.dragHandleProps} style={{ display: 'none' }}></div>\n                    <div {...!props.isDropDisabled && provided.dragHandleProps}>\n                        <HeaderWithIcon\n                            title={columnName}\n                            icon={customColumns[props.column.name.replace(\"$__\", \"\")]?.icon ? customColumns[props.column.name.replace(\"$__\", \"\")]?.icon : props.column.icon || \"topic\"}\n                            color={customApp('menu')}\n                            style={{\n                                padding: '7px'\n                            }}\n                            {...hashs.length > 0\n                                && hashs[1]\n                                && hashs[1] === 'overview'\n                                && reduxStore.getState().db.cards[hashs[0]]\n                                && reduxStore.getState().db.cards[hashs[0]].planType\n                                && reduxStore.getState().db.cards[hashs[0]].planType === 'operational'\n                                && reduxStore.getState().db.cards[hashs[0]]._users\n                                && reduxStore.getState().db.cards[hashs[0]]._users[session._id]\n                                && reduxStore.getState().db.cards[hashs[0]]._users[session._id].access\n                                && parseInt(reduxStore.getState().db.cards[hashs[0]]._users[session._id].access) > 3\n                                ? {\n                                    editable: true,\n                                    onEdit: (x) => {\n                                        updateCardData(\n                                            {\n                                                ...props,\n                                                data: { _id: hashs[0] }\n                                            }, {\n                                            customColumns: JSON.stringify({\n                                                ...reduxStore.getState().db.cards[hashs[0]] && reduxStore.getState().db.cards[hashs[0]].customColumns ? JSON.parse(reduxStore.getState().db.cards[hashs[0]].customColumns) : {},\n                                                [props.column.name.replace(\"$__\", \"\")]: x\n                                            })\n                                        })\n                                    },\n                                    placeholder: translate(\"$__columnName\")\n                                } : {}}\n                            customButtons={[\n                                props.columnsSettings &&\n                                {\n                                    name: \"settings\",\n                                    icon: \"more_horiz\",\n                                    color: customApp('color'),\n                                    onClick: () => console.log('s'),\n                                    show: 'hover'\n                                },\n                            ]}\n\n                            periodFilter={props && props.periodFilter ? true : false}\n                        />\n                    </div>\n                    <Droppable\n                        droppableId={props.columnId ? String(props.columnId) : 'NOT_ID_SENDED'}\n                        type=\"card\"\n                        isDropDisabled={props.column.isDropDisabled}\n                        direction={`${props.inLine ? 'horizontal' : 'vertical'}`}\n                        isCombineEnabled={props.isCombineEnabled}\n                    >\n                        {(provided, snapshot) => (\n                            <CardList\n                                className={list}\n                                ref={provided.innerRef}\n                                {...provided.droppableProps}\n                                isDraggingOver={snapshot.isDraggingOver}\n                                inLine={props.inLine}\n                                {...props}\n                            >\n                                {filtered.sort((a, b) => {\n                                    let orderA = props.orderByTitlePosition === \"ASC\" ? a.name.toLowerCase() : b.name.toLowerCase()\n                                    let orderB = props.orderByTitlePosition === \"ASC\" ? b.name.toLowerCase() : a.name.toLowerCase()\n\n                                    if (props.groupByColor) {\n                                        if (a && a._parent) {\n                                            let ac = getCardColor(a)\n                                            if (ac.parentId && reduxStore.getState().db.cards[ac.parentId])\n                                                orderA = `${reduxStore.getState().db.cards[ac.parentId].name.toLowerCase()} - ${a.name.toLowerCase()}`\n                                        }\n                                        if (b && b._parent) {\n                                            let bc = getCardColor(b)\n                                            if (bc.parentId && reduxStore.getState().db.cards[bc.parentId])\n                                                orderB = `${reduxStore.getState().db.cards[bc.parentId].name.toLowerCase()} - ${b.name.toLowerCase()}`\n                                        }\n                                    }\n                                    if (orderA < orderB)\n                                        return -1\n                                    if (orderA > orderB)\n                                        return 1\n                                    return 0\n\n                                }).map((card) => {\n                                    let separatorTitle = ``\n                                    let separatorColor = ``\n                                    if (props.groupByColor && !card.color) {\n                                        let a = getCardColor(card)\n                                        if (a && a.parentId && cardbyGroup.indexOf(a.parentId) === -1) {\n                                            separatorTitle = reduxStore.getState().db.cards[a.parentId].name\n                                            separatorColor = a.color\n                                            cardbyGroup.push(a.parentId)\n                                        }\n\n                                    }\n                                    if (card) {\n                                        return (\n                                            <div\n                                                key={card._id ? card._id : card.id ? card._id : null}\n                                            >\n                                                {separatorTitle ?\n                                                    <div style={{\n                                                        width: \"100%\",\n                                                        padding: 3,\n                                                        color: \"gray\",\n                                                        marginTop: 17,\n                                                        borderBottom: `solid 3px ${separatorColor}`\n                                                    }}>{separatorTitle}</div>\n                                                    : <React.Fragment></React.Fragment>\n                                                }\n                                                <CardItem\n                                                    data={card}\n                                                    inLine={props.inLine}\n                                                    isDragDisable={props.column.isDragDisable}\n                                                    db={props.db}\n                                                    showOrder={props.showOrder || false}\n                                                    showSelected={props.showSelected || false}\n                                                    locked={props.locked || false}\n                                                    inLineAdd={props.inLineAdd || false}\n                                                    viewButton={props.viewButton || false}\n                                                    cardColorPicker={props.cardColorPicker ? true : false}\n                                                />\n                                            </div>\n                                        )\n                                    }\n                                    return\n                                })}\n                                {props.inLineAdd && !add &&\n                                    <div style={{ position: 'relative', float: 'left', width: '100%', padding: '7px' }}>\n                                        <IconButton\n                                            text={translate(\"$__add\", '*')}\n                                            icon=\"add_box\"\n                                            iconColor={customApp('medium')}\n                                            onClick={() => {\n                                                setAdd(!add);\n                                            }}\n                                        />\n                                    </div>\n                                }\n                                {props.inLineAdd && add &&\n                                    <div className={classes.cardAdd} style={{ position: 'relative', float: 'left', width: '100%', padding: '7px', display: 'flex', alignItems: 'center' }}>\n                                        <div style={{ width: 'calc(100% - 50px)', display: 'flex' }}>\n                                            <TextField\n                                                label={translate('$__nameOfCard')}\n                                                variant={customApp('fieldVariant')}\n                                                name={'name'}\n                                                InputLabelProps={{\n                                                    shrink: true,\n                                                }}\n                                                InputProps={{\n                                                    autoComplete: 'new-password',\n                                                    onChange: (d) => {\n                                                        setName(d.target.value)\n                                                    },\n                                                    onBlur: (d) => {\n                                                        if (d.target.value === '')\n                                                            setAdd(!add)\n                                                    },\n                                                    onKeyDown: (e) => {\n                                                        if (e.keyCode === 13 && name)\n                                                            addCard()\n                                                        if (e.keyCode === 27) {\n                                                            setAdd(!add)\n                                                            setName('')\n                                                        }\n                                                    }\n                                                }}\n                                                autoFocus\n                                                value={name}\n                                                placeholder={translate('$__titleOfCard_placeholder')}\n                                            />\n                                        </div>\n                                        <div style={{ display: 'flex' }}>\n                                            <div className={classes.button}\n                                                onClick={() => addCard()}\n                                            >\n                                                <Icon color='green' icon={'save'} title={translate('$__save', '*')} size={props.actionsSize || '25px'} />\n                                            </div>\n                                            <div className={classes.button}\n                                                onClick={() => {\n                                                    setAdd(!add)\n                                                    setName('')\n                                                }}\n                                            >\n                                                <Icon color={customApp('medium')} icon={'cancel'} title={translate(\"$__cancel\", \"*\")} size={props.actionsSize || '25px'} />\n                                            </div>\n                                        </div>\n                                    </div>\n                                }\n                                {provided.placeholder}\n                                <div style={{ clear: 'both' }}></div>\n                            </CardList>\n                        )\n                        }\n                    </Droppable>\n                </Container>\n            )\n            }\n        </Draggable>\n    )\n}\n\nconst Container = styled.div`\n    margin:0 7px;\n    min-width:180px;\n    ${props => props.columnStyle && props.columnStyle.width ? `width:calc(${props.columnStyle.width} - 14px);` : `width:calc(100% - 14px);`}\n    @media(min-width: 960px) {\n        position:relative;\n        max-height:${props => props.columnStyle && props.columnStyle.maxHeight ? props.columnStyle.maxHeight : 'calc(100% - 0px)'};\n       \n        ${props => props.inLine\n        ? `display:block;\n           `\n        : `margin-bottom:0px !important;\n            ${props => props.columnStyle && props.columnStyle.width ? `width:${props.columnStyle.width};` : `width:100%;`}\n                `\n    }\n      }\n    @media(max-width: 959px) {\n        float:left;\n        position: relative;\n      }\n      @media(max-width: 599px) {\n        float:left;\n        position: relative;\n      }\n    `\n\n\nconst CardList = styled.div`\nposition:relative;\nheight:100%;\nwidth:100%;\nmax-height:${props => props.columnStyle && props.columnStyle.maxHeight ? props.columnStyle.maxHeight : 'calc(100% - 30px)'};\n${props => props.columnStyle && props.columnStyle.maxWidth ? props.columnStyle.maxWidth : '250px'};\n ${props =>\n        props.isDraggingOver\n            ? `background-color:${customApp('color')}; opacity:0.5;`\n            : ''};\n${props =>\n        props.inLine ? `\n                display:table;\n                margin-bottom:33px`\n            : `display:block;\n                min-height: 150px !important;\n                padding-bottom:15px;\n                overflow-y: auto;\n                `\n    }\n`;\n\n//REACT\nconst mapStateToProps = (store) => ({\n    search: store.search,\n    dbCards: store.db.cards,\n    groupByColor: store.db.groupByColor,\n    orderByTitle: store.db.orderByTitle,\n    orderByTitlePosition: store.db.orderByTitlePosition,\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Column));","import React from \"react\";\r\nimport { DragDropContext, Droppable } from \"react-beautiful-dnd\";\r\nimport styled from \"styled-components\";\r\nimport moment from \"moment-timezone\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store\";\r\n\r\n//DEPENDENCIES\r\nimport Column from \"./Column\";\r\n\r\nfunction App(props) {\r\n    const { db } = reduxStore.getState()\r\n\r\n    React.useEffect(() => {\r\n\r\n    }, [])\r\n\r\n    const onDragEnd = async result => {\r\n        const { socket } = reduxStore.getState().functions\r\n        const { destination, source, draggableId } = result\r\n        let newCardsOrder = db.cards\r\n        if (result.combine) {\r\n            return;\r\n        }\r\n\r\n\r\n        if (!destination) return false\r\n\r\n        if (destination.droppableId === source.droppableId && destination.id === source.index) return false\r\n\r\n        const sourceColumn = source.droppableId\r\n        const destinationColumn = destination.droppableId\r\n\r\n        const sourceCardIds = Array.from(props.cards.filter(c => c.status === sourceColumn).sort((a, b) => {\r\n            if (a.order && b.order && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low))\r\n                return -1\r\n            return 1\r\n        }\r\n        ).map(a => a._id))\r\n\r\n        //When move Card in single Column\r\n\r\n        if (sourceColumn === destinationColumn && !reduxStore.getState().db.orderByTitle) {\r\n            const newCardsIds = Array.from(props.cards.filter(c => c.status === sourceColumn).sort((a, b) => {\r\n                if (a.order && b.order && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low))\r\n                    return -1\r\n                return 1\r\n            }\r\n            ).map(a => a._id))\r\n\r\n            newCardsIds.splice(source.index, 1)\r\n            newCardsIds.splice(destination.index, 0, draggableId)\r\n            newCardsIds.map((card, i) => {\r\n                newCardsOrder[card] = {\r\n                    ...newCardsOrder[card],\r\n                    order: {\r\n                        low: i\r\n                    }\r\n                }\r\n            })\r\n\r\n            const newState = {\r\n                ...reduxStore.getState().db,\r\n                cards: {\r\n                    ...db.cards,\r\n                    ...newCardsOrder,\r\n                }\r\n            }\r\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                ...newState,\r\n            });\r\n\r\n            socket.emit(\"data\", {\r\n                module: \"cards\",\r\n                method: \"put\",\r\n                action: \"inColumn\",\r\n            }, {\r\n                node: draggableId,\r\n                source: source.droppableId,\r\n                destination: destination.droppableId,\r\n                destinationCards: newCardsIds,\r\n                sourceCards: [],\r\n                columnName: 'status',\r\n            })\r\n            return\r\n        }\r\n\r\n        //When move Card in mult Column\r\n        sourceCardIds.splice(source.index, 1)\r\n\r\n        const destinationCardIds = Array.from(props.cards.filter(c => c.status === destinationColumn).sort((a, b) => {\r\n            if (a.order && b.order && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low))\r\n                return -1\r\n            return 1\r\n        }\r\n        ).map(a => a._id))\r\n        destinationCardIds.splice(destination.index, 0, draggableId)\r\n\r\n        sourceCardIds.map((a, i) => {\r\n            if (!db.cards[a].order || !db.cards[a].order.low) {\r\n                db.cards[a] = {\r\n                    ...db.cards[a],\r\n                    ['order']: {\r\n                        ['low']: parseInt(i)\r\n                    }\r\n                }\r\n            } else {\r\n                db.cards[a].order.low = parseInt(i)\r\n            }\r\n        })\r\n\r\n        destinationCardIds.map((a, i) => {\r\n            if (!db.cards[a].order || !db.cards[a].order.low) {\r\n                db.cards[a] = {\r\n                    ...db.cards[a],\r\n                    ['order']: {\r\n                        ['low']: parseInt(i)\r\n                    }\r\n                }\r\n            } else {\r\n                db.cards[a].order.low = parseInt(i)\r\n            }\r\n        })\r\n\r\n        const newState = {\r\n            ...db,\r\n            cards: {\r\n                ...db.cards,\r\n                [draggableId]: {\r\n                    ...db.cards[draggableId],\r\n                    status: destinationColumn,\r\n                    completed_at: destinationColumn === 'completed' ? {\r\n                        low: moment().tz('America/Sao_Paulo').unix('x'),\r\n                    } : null,\r\n                    updated_at: {\r\n                        low: moment().tz('America/Sao_Paulo').unix('x'),\r\n                    },\r\n                    order: {\r\n                        low: destination.index\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...newState,\r\n        });\r\n\r\n        socket.emit(\"data\", {\r\n            module: \"cards\",\r\n            method: \"put\",\r\n            action: \"inColumn\",\r\n        }, {\r\n            node: draggableId,\r\n            source: source.droppableId,\r\n            destination: destination.droppableId,\r\n            destinationCards: destinationCardIds,\r\n            columnName: 'status',\r\n            sourceCards: sourceCardIds,\r\n        })\r\n\r\n    }\r\n    const onDragStart = async result => {\r\n    }\r\n    const onDragUpdate = async result => {\r\n    }\r\n\r\n    return (\r\n        <DragDropContext\r\n            onDragEnd={onDragEnd}\r\n            onDragStart={onDragStart}\r\n            onDragUpdate={onDragUpdate}\r\n        >\r\n            <Droppable\r\n                droppableId=\"ALL-COLUMNS-STATUS\"\r\n                type=\"column\"\r\n                direction={`${props.inLine ? 'vertical' : 'horizontal'}`}\r\n                isDropDisabled={true}\r\n            >\r\n                {provided => (\r\n                    <Container\r\n                        {...props}\r\n                        ref={provided.innerRef}\r\n                    >\r\n                        {reduxStore.getState().db.status.map((st, index) => {\r\n                            const theColumn = {\r\n                                name: st.label,\r\n                                icon: st.icon,\r\n                                cards: [],\r\n                                emptyHide: false,\r\n                            }\r\n                            // console.log(st.value)\r\n                            return <Column\r\n                                {...props}\r\n                                key={`${st.value}`}\r\n                                columnId={`${st.value}`}\r\n                                isDropDisabled\r\n                                column={theColumn}\r\n                                cards={props.cards.filter(c => c.status === st.value || (st.value === 'notStarted' && !c.status)).map(a => {\r\n                                    return {\r\n                                        ...a,\r\n                                        id: a._id\r\n                                    }\r\n                                })}\r\n                                index={index}\r\n                                columnsSettings={false}\r\n                                locked={false}\r\n                                columnStyle={{\r\n                                    flex: index,\r\n                                    width: \"25%\",\r\n                                    ...props.columnStyle ? props.columnStyle : {}\r\n\r\n                                }}\r\n                                viewButton={props.viewButton || false}\r\n                                periodFilter={st.props && st.props.periodFilter ? true : false}\r\n                            />\r\n                        })}\r\n                        {provided.placeholder}\r\n                        <div style={{ clear: 'both' }}></div>\r\n                    </Container>\r\n                )}\r\n            </Droppable>\r\n        </DragDropContext>\r\n    )\r\n}\r\n\r\n//STYLEDS\r\nconst Container = styled.div`\r\nheight:100%;\r\n${props =>\r\n        props.inLine ?\r\n            `display: block;\r\n                width: -webkit-fill-available;\r\n                position:relative;\r\n                ${props.style}`\r\n            :\r\n            `   display: flex;\r\n                width: 100%;\r\n                ${props.style}\r\n                @media(min-width: 960px) {\r\n                    display: flex;\r\n                }\r\n                `\r\n    }\r\n    @media(max-width: 959px) {\r\n        display: contents !important;\r\n        width: -webkit-fill-available;\r\n        height:auto;\r\n      }\r\n    `\r\n\r\n//REACT\r\nconst mapStateToProps = (store, props) => ({})\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch);\r\n\r\nexport default connect(\r\n    mapStateToProps,\r\n    mapDispatchToProps\r\n)(App);","//CORE\r\nimport React from \"react\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store/\";\r\n\r\n//COMPONENTS\r\nimport GridContainer from \"components/Grid/GridContainer\";\r\nimport GridItem from \"components/Grid/GridItem\";\r\nimport HeaderWithIcon from \"components/Header/withIcon\";\r\nimport AgileStatus from \"components/Agile/status\";\r\n\r\n\r\n//FUNCTIONS\r\nimport { translate, customApp } from \"functions/\";\r\n\r\nfunction Component(props) {\r\n    const { db } = props\r\n    const { dataType } = db\r\n    // const [chartBarKpiType, setCharKpiType] = React.useState('currency')\r\n\r\n    // let cards = {}\r\n\r\n    let hashs = window.location.hash.split('/')\r\n    hashs[0] = hashs[0].replace('#', '')\r\n\r\n    if (!db.cards) {\r\n        return (<div></div>)\r\n    }\r\n\r\n    let myCards = Object.keys(db.cards).filter(a => {\r\n        if (\r\n            !db.cards[a].checklist\r\n            && db.cards[a]._planId === hashs[0]\r\n            &&\r\n            (\r\n                (\r\n                    props.type === 'actions'\r\n                    && db.cards[a]\r\n                    && db.cards[a].type\r\n                    && db.cards[a].type !== 'objective'\r\n                    && db.cards[a].type !== 'goal'\r\n                    && db.cards[a].type !== 'plan'\r\n                    && db.cards[a].type !== 'link'\r\n                    && db.cards[a].type !== 'insight'\r\n                    && db.cards[a].type !== 'chatGroup'\r\n                    && db.cards[a].type.indexOf('guideline') === -1\r\n                    && dataType.filter(f => f.name === db.cards[a].type)[0].module !== 'swot'\r\n                )\r\n                ||\r\n                (\r\n                    props.type === 'guidelines'\r\n                    && db.cards[a].type.indexOf('guideline') > -1\r\n                )\r\n                ||\r\n                (\r\n                    props.type === 'objectives'\r\n                    && db.cards[a].type.indexOf('objective') > -1\r\n                )\r\n                ||\r\n                (\r\n                    props.type === 'goals'\r\n                    && db.cards[a].type.indexOf('goal') > -1\r\n                )\r\n            )\r\n        )\r\n            return true\r\n    }).map(c => db.cards[c])\r\n\r\n    // /** GRAPH STATUS ******INI*****/\r\n    // let statusChart = {}\r\n    // db.status.map(st => {\r\n    //     Object.keys(cards).map(type => {\r\n    //         if (st.value !== 'notStarted') {\r\n    //             statusChart = {\r\n    //                 ...statusChart,\r\n    //                 [type]: {\r\n    //                     ...statusChart[type],\r\n    //                     [st.value]: cards[type].filter(action =>\r\n    //                         action.status && action.status === st.value\r\n    //                     )\r\n    //                 }\r\n    //             }\r\n    //         } else {\r\n    //             statusChart = {\r\n    //                 ...statusChart,\r\n    //                 [type]: {\r\n    //                     ...statusChart[type],\r\n    //                     [st.value]: cards[type].filter(action =>\r\n    //                         !action.status || (action.status && action.status === st.value)\r\n    //                     )\r\n    //                 }\r\n    //             }\r\n    //         }\r\n    //     })\r\n    // })\r\n\r\n    // let total = {}\r\n    // let statusLenghtChartData = [[`${translate('$__status', 1)}`, `${translate('$__cards', 1)}`]]\r\n\r\n    // Object.keys(statusChart).map(tp => {\r\n    //     Object.keys(statusChart[tp]).map(st => {\r\n    //         total = {\r\n    //             ...total,\r\n    //             [[st][0]]: total[[st][0]] ? parseFloat(total[[st][0]]) + parseFloat(statusChart[tp][st].length) : parseFloat(statusChart[tp][st].length)\r\n    //         }\r\n    //     })\r\n    // })\r\n    // Object.keys(total).map(a => {\r\n    //     statusLenghtChartData.push([a, total[a]])\r\n    // })\r\n\r\n    // /** GRAPH STATUS ******FIN*****/\r\n\r\n    // /** GRAPH KPIS ******INI*****/\r\n    // let kpisChart = {}\r\n\r\n    // //'time', deverá ser contado de outra forma, pois não se trata de meta e sim de mínimo e máximo\r\n    // let kpiTypes = ['currency', 'decimal', 'percent', 'time']\r\n\r\n    // kpiTypes.map(kpiType => {\r\n    //     /**Inicialization JSON variables */\r\n    //     if (!kpisChart[kpiType])\r\n    //         kpisChart[kpiType] = {}\r\n\r\n    //     if (!kpisChart[kpiType].asc)\r\n    //         kpisChart[kpiType]['asc'] = {}\r\n\r\n    //     if (!kpisChart[kpiType].asc.goal)\r\n    //         kpisChart[kpiType].asc['goal'] = 0\r\n\r\n    //     if (!kpisChart[kpiType].asc.distributed)\r\n    //         kpisChart[kpiType].asc['distributed'] = 0\r\n\r\n    //     if (!kpisChart[kpiType].asc.accomplished)\r\n    //         kpisChart[kpiType].asc['accomplished'] = 0\r\n\r\n    //     if (!kpisChart[kpiType].desc)\r\n    //         kpisChart[kpiType]['desc'] = {}\r\n\r\n    //     if (!kpisChart[kpiType].desc.goal)\r\n    //         kpisChart[kpiType].desc['goal'] = 0\r\n\r\n    //     if (!kpisChart[kpiType].desc.distributed)\r\n    //         kpisChart[kpiType].desc['distributed'] = 0\r\n\r\n    //     if (!kpisChart[kpiType].desc.accomplished)\r\n    //         kpisChart[kpiType].desc['accomplished'] = 0\r\n\r\n    //     /**Inicialization JSON variables */\r\n\r\n    //     Object.keys(cards).map(cardType => {\r\n    //         let sum = 0\r\n    //         let sumMinimal = 0\r\n    //         let sumMaximum = 0\r\n\r\n    //         //FILL KPI GOAL AND DISTRIBUTED\r\n    //         cards[cardType].filter(a => !a.kpi_useParent && a.kpi_type === kpiType).map(async a => {\r\n    //             let kpi_ini = a.kpi_ini || 0\r\n    //             let kpi_fin = a.kpi_fin || 0\r\n    //             if (kpiType === 'time') {\r\n    //                 Object.keys(myCards).filter(fil => myCards[fil]._parent === a._id && myCards[fil].kpi_useParent === true && myCards[fil].kpi_type === a.kpi_type).map(mp => {\r\n    //                     sumMinimal = sumMinimal + parseFloat(parseFloat(myCards[mp].kpi_ini))\r\n    //                     sumMaximum = sumMaximum + parseFloat(parseFloat(myCards[mp].kpi_fin))\r\n    //                     kpisChart[kpiType].desc.goal = parseFloat(kpi_fin) + parseFloat(kpisChart[kpiType].desc.goal)\r\n    //                     kpisChart[kpiType].desc.distributed = parseFloat(sumMaximum) + parseFloat(kpisChart[kpiType].desc.distributed)\r\n    //                 })\r\n    //             } else {\r\n    //                 if (a.kpi_ini || a.kpi_fin) {\r\n    //                     Object.keys(myCards).filter(fil => myCards[fil]._parent === a._id && myCards[fil].kpi_useParent === true && myCards[fil].kpi_type === a.kpi_type).map(mp => {\r\n    //                         sum = sum + parseFloat(parseFloat(myCards[mp].kpi_ini) > parseFloat(myCards[mp].kpi_fin) ? myCards[mp].kpi_ini : myCards[mp].kpi_fin)\r\n    //                     })\r\n    //                     if (parseFloat(kpi_ini) > parseFloat(kpi_fin)) {\r\n    //                         kpisChart[kpiType].desc.goal = parseFloat(kpisChart[kpiType].desc.goal) + (parseFloat(kpi_ini) - parseFloat(kpi_fin))\r\n    //                         kpisChart[kpiType].desc.distributed = parseFloat(sum) + parseFloat(\r\n    //                             kpisChart[kpiType].desc.distributed ? parseFloat(kpisChart[kpiType].desc.distributed) + parseFloat(sum) : 0\r\n    //                         )\r\n\r\n    //                     } else {\r\n    //                         kpisChart[kpiType].asc.goal = parseFloat(kpisChart[kpiType].asc.goal) + (parseFloat(kpi_fin) - parseFloat(kpi_ini))\r\n    //                         kpisChart[kpiType].asc.distributed = sum + parseFloat(\r\n    //                             kpisChart[kpiType].asc.distributed ? parseFloat(kpisChart[kpiType].asc.distributed) + parseFloat(sum) : 0\r\n    //                         )\r\n\r\n    //                     }\r\n    //                 }\r\n    //                 //FILL KPI GOAL AND ACCOMPLISHED\r\n    //                 cards[cardType].filter(a => a.kpi_type === kpiType).map(async a => {\r\n    //                     if (a._timeline && Object.keys(a._timeline).length > 0) {\r\n    //                         Object.keys(a._timeline).map(flow => {\r\n    //                             if (a._timeline[flow].type === 'kpi')\r\n    //                                 kpisChart[kpiType][parseFloat(a.kpi_ini) > parseFloat(a.kpi_fin) ? 'desc' : 'asc'].accomplished = parseFloat(kpisChart[kpiType][parseFloat(a.kpi_ini) > parseFloat(a.kpi_fin) ? 'desc' : 'asc'].accomplished) + parseFloat(a._timeline[flow].value)\r\n    //                         })\r\n    //                     }\r\n    //                 })\r\n    //             }\r\n    //         })\r\n\r\n    //     })\r\n    // })\r\n\r\n    // /** GRAPH KPIS ******FIN*****/\r\n\r\n    // /** TIMELINE ******INI*****/\r\n    // let timelines = {}\r\n\r\n\r\n    return (\r\n        <div>\r\n            <HeaderWithIcon\r\n                title={null}\r\n                icon={null}\r\n                color={customApp('menu')}\r\n                style={{\r\n                    background: 'transparent',\r\n                    padding: '7px'\r\n                }}\r\n\r\n                customButtons={[\r\n                    {\r\n                        title: db.orderByTitle ? \"$__orderByName\" : \"$__orderByManualOrder\",\r\n                        icon: db.orderByTitle ? \"sort\" : \"format_list_numbered\",\r\n                        onClick: () => {\r\n                            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                                ...reduxStore.getState().db,\r\n                                orderByTitle: !db.orderByTitle\r\n                            });\r\n                        },\r\n                    },\r\n                    db.orderByTitle &&\r\n                    {\r\n                        title: db.orderByTitlePosition === 'ASC' ? \"$__asc\" : \"$__desc\",\r\n                        icon: db.orderByTitlePosition === 'ASC' ? \"text_rotation_down\" : \"text_rotate_up\",\r\n                        onClick: () => {\r\n                            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                                ...reduxStore.getState().db,\r\n                                orderByTitlePosition: db.orderByTitlePosition === 'ASC' ? 'DESC' : 'ASC'\r\n                            });\r\n                        },\r\n                    },\r\n                ]}\r\n            />\r\n            <AgileStatus cards={myCards} />\r\n        </div>\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store, ownProps) => ({\r\n    db: store.db\r\n});\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","import React from \"react\"\nimport moment from \"moment-timezone\"\nimport { ResponsiveCirclePackingCanvas } from '@nivo/circle-packing'\nimport { ResponsivePie } from '@nivo/pie'\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Card from \"components/Card\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport HeaderWithMenu from \"components/Header/card\"\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport Icon from \"components/Icon\"\nimport MatrixIcon from \"assets/icons/Matrix\"\nimport QuickUsers from \"components/User/quick\"\nimport Timesheet from \"components/Timer/chart\"\nimport UiCard from \"components/Card/Card\"\nimport UiCardBody from \"components/Card/CardBody\"\nimport UiCardHeader from \"components/Card/CardHeader\"\nimport Timeline from \"components/Timeline\"\n\n//@MATERIAL\nimport Pagination from '@material-ui/lab/Pagination'\nimport TextareaAutosize from '@material-ui/core/TextareaAutosize'\n\nimport { translate, customApp, appAlert, nl2br, getAppAccess } from \"functions\"\nimport { saveCard, getUserAccess, countNotifications } from \"functions/cards\"\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\n\nfunction Dashboard(props) {\n    const { db, session } = reduxStore.getState()\n    const [mounted, setMounted] = React.useState(false)\n    const [lastCompletedCards_page, setlastCompletedCards_page] = React.useState(1)\n    const [nextActivities_page, setNextActivities_page] = React.useState(1)\n    const [dueActivities_page, setDueActivities_page] = React.useState(1)\n    const [planNote, setPlanNote] = React.useState({ editor: false, text: '', height: 'auto' })\n    const [planNoteSave, setPlanNoteSave] = React.useState(false)\n    const [timelineParams, setTimelineParams] = React.useState({\n        type: 'comment',\n        disabledSend: false\n    })\n\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace('#', '')\n\n    if (hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n\n    let AppAccess = getAppAccess()\n    let CardAccess = getUserAccess(hashs[0])\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setPlanNote(db.cards[hashs[0]] && db.cards[hashs[0]].note ? {\n                ...planNote,\n                text: db.cards[hashs[0]].note ? db.cards[hashs[0]].note : '',\n            } : {\n                ...planNote,\n            })\n            setMounted(true)\n            // init()\n        }\n    }\n    )\n\n    const saveNote = async (clean) => {\n        if (planNote.text || clean) {\n            const request = await saveCard(props, false, {\n                ...db.cards[hashs[0]],\n                note: clean ? null : planNote.text\n            });\n            if (request) {\n                appAlert({\n                    message: translate('$__noteSaved', 1),\n                    variant: null,\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n            }\n            setPlanNote(\n                { editor: false, text: clean ? '' : planNote.text, height: 'auto' }\n            )\n        }\n        setPlanNoteSave(false)\n    }\n\n    if (!hashs[0] || !(hashs[0] && db.cards[hashs[0]])) {\n        return (<React.Fragment></React.Fragment>)\n    }\n\n    let notifications = countNotifications(hashs[0])\n\n    let titles = {}\n    if (db.cards[hashs[0]]?.customColumns)\n        titles = JSON.parse(db.cards[hashs[0]].customColumns)\n\n\n    return (\n        <div style={{ width: 'calc(100% + 30px)', paddingBottom: '30px', marginLeft: \"-15px\" }}>\n            <GridContainer>\n                <GridItem xs={12} sm={6} md={6} lg={6} style={{ padding: 0 }}>\n                    <div style={{ width: \"100%\" }}>\n                        <UiCard style={{ marginTop: '0' }}>\n                            <HeaderWithMenu\n                                title={translate(`$__planResume`, 1)}\n                                icon={'blur_on'}\n                                color={customApp('colorText')}\n                                style={{\n                                    background: customApp('ColumnTitleColor'),\n                                    padding: '7px'\n                                }}\n                                moreButton\n                                optionsProps={{ transparent: true, btColor: customApp('colorText') }}\n                                options={((CardAccess && parseInt(CardAccess) > 3) || AppAccess.owner || AppAccess.planAdmin || AppAccess.planEdit || AppAccess.planModerate) ? [\n                                    {\n                                        name: \"$__edit\",\n                                        icon: \"edit\",\n                                        onClick: () => {\n                                            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                ...reduxStore.getState().sideModule,\n                                                db: 'cards',\n                                                id: hashs[0],\n                                                module: \"cardEdit\",\n                                                activeModule: 'cardEdit',\n                                                data: db.cards[hashs[0]],\n                                            });\n                                        },\n                                    }\n                                ] : []}\n                                actionButtonsStyle={{\n                                    top: '-9px !important'\n                                }}\n\n                            />\n                            <UiCardBody>\n                                <div style={{ width: '100%', color: customApp('menu') }}><span style={{ fontWeight: 'bold' }}>{translate('$__name', 1)}:</span> {db.cards[hashs[0]].name}</div>\n                                <div style={{ width: '100%', color: customApp('menu') }}><span style={{ fontWeight: 'bold' }}>{translate('$__description', 1)}:</span> {db.cards[hashs[0]].description}</div>\n                                {!db.cards[hashs[0]].isTemplate && db.cards[hashs[0]] && db.cards[hashs[0]]._users &&\n                                    <React.Fragment>\n                                        <div style={{ width: '100%', marginTop: '15px', color: customApp('menu'), fontWeight: 'bold' }}>{translate('$__users', '*')}:</div>\n                                        <QuickUsers _id={hashs[0]} noLimit avatarSize=\"33px\"\n                                            permission={true}\n                                        />\n                                    </React.Fragment>\n                                }\n                            </UiCardBody>\n                        </UiCard>\n                    </div>\n                    <div style={{ width: \"100%\" }}>\n                        <div>\n                            <UiCard style={{ marginTop: '0' }}>\n                                <HeaderWithIcon\n                                    title={translate(`$__notes`, 1)}\n                                    icon={'note'}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                    customButtons={[\n                                        ...planNote.text && !planNote.editor ? [\n                                            {\n                                                title: \"$__cleanNote\",\n                                                icon: \"clear_all\",\n                                                onClick: () => {\n                                                    saveNote(true)\n                                                },\n                                            },\n                                            {\n                                                title: \"$__edit\",\n                                                icon: \"edit\",\n                                                onClick: () => {\n                                                    setPlanNote({\n                                                        ...planNote,\n                                                        editor: true,\n                                                    })\n                                                },\n                                            }] : [],\n                                        planNoteSave &&\n                                        {\n                                            title: \"$__saveNote\",\n                                            icon: \"save\",\n                                            onClick: () => {\n                                                saveNote()\n                                            },\n                                        },\n                                        planNote.editor &&\n                                        {\n                                            title: \"$__cancel\",\n                                            icon: \"cancel\",\n                                            onClick: () => {\n                                                setPlanNote({\n                                                    ...planNote,\n                                                    text: db.cards[hashs[0]].note,\n                                                    editor: false\n                                                })\n                                                setPlanNoteSave(false)\n                                            },\n                                        },\n                                    ]}\n                                />\n                                <UiCardBody style={{ display: 'flex', justifyContent: 'center' }}>\n                                    {(!planNote.text && !planNote.editor) ?\n                                        <div style={{\n                                            display: 'flex',\n                                            alignItems: 'center',\n                                            userSelect: 'none',\n                                            cursor: 'pointer'\n                                        }}\n                                            onClick={\n                                                () => {\n                                                    setPlanNote({\n                                                        ...planNote,\n                                                        editor: true\n                                                    })\n                                                }\n                                            }\n                                        >\n                                            <div style={{ padding: '7px', border: 'dotted 1px rgba(0,0,0,0.2)', borderRadius: '7px' }}>\n                                                <Icon size={'33px'} color={\"rgba(0,0,0,0.2)\"}>add</Icon>\n                                            </div>\n                                            <div style={{ color: 'rgba(0,0,0,0.2)', fontSize: '22px', fontWeight: 'bold', marginLeft: '15px' }}>\n                                                {translate('$__addNote')}\n                                            </div>\n                                        </div>\n                                        : planNote.editor ?\n                                            <TextareaAutosize\n                                                style={{\n                                                    borderRadius: '7px',\n                                                    border: '0px',\n                                                    padding: '7px',\n                                                    fontFamily: '\"Soleto\", \"Roboto\", \"Helvetica\", \"Arial\", sans-serif',\n                                                    fontSize: '16px',\n                                                    minWidth: 'calc(100% - 0px)',\n                                                    maxWidth: 'calc(100% - 0px)',\n                                                }}\n                                                placeholder={translate('$__planNotePlaceholder')}\n                                                onChange={(e) => {\n                                                    setPlanNoteSave(true)\n                                                    setPlanNote({\n                                                        ...planNote,\n                                                        text: e.target.value\n                                                    })\n                                                }}\n                                                onBlur={(e) => {\n                                                    if (e.target.value === '' || e.target.value === db.cards[hashs[0]].note) {\n                                                        setPlanNoteSave(false)\n                                                        setPlanNote({\n                                                            ...planNote,\n                                                            editor: false\n                                                        })\n                                                    }\n                                                }}\n                                                autoFocus\n                                                spellcheck={false}\n                                            >\n                                                {planNote.text}\n                                            </TextareaAutosize>\n                                            :\n                                            <div\n                                                style={{\n                                                    fontSize: '16px',\n                                                    width: '100%',\n                                                }}\n                                                onClick={() => {\n                                                    setPlanNote({\n                                                        ...planNote,\n                                                        editor: true\n                                                    })\n                                                }}\n                                                dangerouslySetInnerHTML={{\n                                                    __html: nl2br(planNote.text)\n                                                }}\n                                            >\n                                            </div>\n                                    }\n                                </UiCardBody>\n                            </UiCard>\n                        </div>\n                    </div>\n                </GridItem>\n                <GridItem xs={12} sm={6} md={6} lg={6}>\n                    <div>\n                        <UiCard style={{ marginTop: '0', height: '500px' }}>\n                            <HeaderWithIcon\n                                title={translate(`$__timeline`, 1)}\n                                icon={'blur_on'}\n                                color={customApp('colorText')}\n                                style={{\n                                    background: customApp('ColumnTitleColor'),\n                                    padding: '7px'\n                                }}\n\n                                // moreButton\n                                // optionsProps={{ transparent: true, btColor: customApp('color') }}\n                                customButtons={[\n                                    {\n                                        name: \"$__timeline\",\n                                        icon: \"timeline\",\n                                        actionsSize: '22px',\n                                        count: notifications.comment,\n                                        onClick: () => {\n                                            setTimelineParams({\n                                                type: 'comment',\n                                                disabledSend: false\n                                            })\n                                        },\n                                    },\n                                    {\n                                        name: \"$__log\",\n                                        icon: \"history\",\n                                        actionsSize: '22px',\n                                        count: notifications.log,\n                                        onClick: () => {\n                                            setTimelineParams({\n                                                type: 'log',\n                                                disabledSend: true\n                                            })\n                                        },\n                                    },\n                                    {\n                                        name: \"$__timer\",\n                                        icon: \"timer\",\n                                        actionsSize: '22px',\n                                        count: notifications.timer,\n                                        onClick: () => {\n                                            setTimelineParams({\n                                                type: 'timer',\n                                                disabledSend: true\n                                            })\n                                        },\n                                    },\n                                    {\n                                        name: \"$__kpi\",\n                                        icon: \"analytics\",\n                                        actionsSize: '22px',\n                                        count: notifications.kpi,\n                                        onClick: () => {\n                                            setTimelineParams({\n                                                type: 'kpi',\n                                                disabledSend: true\n                                            })\n                                        },\n                                    }\n                                ]}\n                                actionButtonsStyle={{\n                                    top: '-9px !important'\n                                }}\n\n                            />\n                            <UiCardBody>\n                                <Timeline {...{\n                                    nodeId: hashs[0],\n                                    db: 'cards',\n                                    loadTimeline: true,\n                                    ...timelineParams,\n                                }} />\n                            </UiCardBody>\n                        </UiCard>\n                    </div>\n                </GridItem>\n\n                {/* {props.plans && props.plans.length > 0 &&\n                    <GridItem xs={12} sm={6} md={6} lg={6}>\n                    <UiCard style={{ marginTop: '0' }}>\n                    <HeaderWithIcon\n                    title={translate(`$__linkedPlans`, 1)}\n                    icon={'view_comfy'}\n                    color={customApp('colorText')}\n                    style={{\n                                    background: customApp('ColumnTitleColor'),\n                                    padding: '7px'\n                                }}\n                                moreButton\n                                optionsProps={{ transparent: true, btColor: customApp('color') }}\n                                options={[\n                                    planNoteSave &&\n                                    {\n                                        title: \"$__saveNote\",\n                                        icon: \"save\",\n                                        onClick: () => {\n                                            saveNote()\n                                        },\n                                    },\n                                    planNoteSave &&\n                                    {\n                                        title: \"$__cancel\",\n                                        icon: \"cancel\",\n                                        onClick: () => {\n                                            setPlanNote({\n                                                ...planNote,\n                                                text: db.cards[hashs[0]].note,\n                                                editor: false\n                                            })\n                                            setPlanNoteSave(false)\n                                        },\n                                    },\n                                ]}\n                            />\n                            <UiCardBody style={{ display: 'flex', justifyContent: 'center' }}>\n                                <GridContainer>\n                                    {props.plans.map((a) => (\n                                        <GridItem\n                                            key={a._id}\n                                            xs={12}\n                                            sm={12}\n                                            md={6}\n                                            lg={6}\n                                            xl={6}\n                                        >\n                                            <Card db=\"cards\" data={a} db='cards' Avatar expanded ignoreList />\n                                        </GridItem>\n                                    ))\n                                    }\n                                </GridContainer>\n                            </UiCardBody>\n                        </UiCard>\n                    </GridItem>\n                } */}\n\n                <GridItem xs={12} sm={12} md={12} lg={12}>\n                    <GridContainer>\n                        {db.cards[hashs[0]] && db.cards[hashs[0]].planType !== \"\"\n                            && (\n                                db.cards[hashs[0]].planType === \"operational\"\n                                ||\n                                db.cards[hashs[0]].planType === \"flow\"\n                            ) ?\n                            <GridItem xs={12} sm={6} md={6} lg={3}>\n                                <UiCard>\n                                    <HeaderWithMenu\n                                        title={titles?.guidelines?.name ? titles.guidelines.name : translate(`$__guidelines`, 1)}\n                                        icon={titles?.guidelines?.icon ? titles.guidelines.icon : MatrixIcon}\n                                        color={customApp('colorText')}\n                                        style={{\n                                            background: customApp('ColumnTitleColor'),\n                                            padding: '7px'\n                                        }}\n                                    />\n                                    <UiCardHeader style={{ height: '300px', display: 'flex' }}>\n                                        <ResponsivePie\n                                            data={[\n                                                ...db.status.map((st, index) => {\n                                                    return {\n                                                        id: translate(st.label, 1),\n                                                        label: translate(st.label, 1),\n                                                        value: Object.keys(db.cards).filter(fil =>\n                                                            db.cards[fil]._planId === hashs[0]\n                                                            && !db.cards[fil].deleted\n                                                            && db.cards[fil].type.indexOf('guideline') > -1\n                                                            && db.cards[fil].status && db.cards[fil].status === st.value).length,\n                                                        color: st.color\n                                                    }\n                                                }),\n                                                {\n                                                    id: translate('$__late', 1),\n                                                    label: translate('$__late', 1),\n                                                    value: Object.keys(db.cards).filter(fil =>\n                                                        db.cards[fil]._planId === hashs[0]\n                                                        && !db.cards[fil].deleted\n                                                        && db.cards[fil].type.indexOf('guideline') > -1\n                                                        && db.cards[fil].endDate && moment(new Date(db.cards[fil].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                                    ).length,\n                                                    color: 'red'\n                                                }\n                                            ]}\n                                            colors={['#929497', '#011E41', '#EBA900', '#5A7F71', 'red']}\n                                            margin={{ top: 17, right: 17, bottom: 17, left: 17 }}\n                                            arcLabelsTextColor={{ from: 'color', modifiers: [['brighter', 3]] }}\n                                            innerRadius={0.5}\n                                            padAngle={3}\n                                            cornerRadius={3}\n                                            activeOuterRadiusOffset={8}\n                                            borderWidth={1}\n                                            borderColor={{ from: 'color', modifiers: [['darker', 0.2]] }}\n                                            enableArcLinkLabels={false}\n                                        />\n                                    </UiCardHeader>\n                                    <UiCardBody>\n                                        <h3>\n                                            <small>{translate('$__total', 1)}: {Object.keys(db.cards).filter(fil => db.cards[fil]._planId === hashs[0] && !db.cards[fil].deleted && db.cards[fil].type.indexOf('guideline') > -1).length}</small>\n                                        </h3>\n                                        {db.status.map((st, index) => {\n                                            return (\n                                                <div key={`${index}_${st.value}`} style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                                    <div style={{ display: 'flex' }}>\n                                                        <Icon color={st.color}>{st.icon}</Icon>\n                                                        <span style={{ marginLeft: '15px' }} >{translate(st.label, 1)}</span>\n                                                    </div>\n                                                    <div>\n                                                        {Object.keys(db.cards).filter(fil => db.cards[fil]._planId === hashs[0] && !db.cards[fil].deleted && db.cards[fil].type.indexOf('guideline') > -1 && db.cards[fil].status && db.cards[fil].status === st.value).length}\n                                                    </div>\n                                                </div>\n                                            )\n                                        })}\n                                        <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                            <div style={{ display: 'flex' }}>\n                                                <Icon color={'red'}>assignment_late</Icon>\n                                                <span style={{ marginLeft: '15px' }} >{translate('$__late', 1)}</span>\n                                            </div>\n                                            <div>\n                                                {Object.keys(db.cards).filter(fil =>\n                                                    db.cards[fil]._planId === hashs[0]\n                                                    && !db.cards[fil].deleted\n                                                    && db.cards[fil].type.indexOf('guideline') > -1\n                                                    && db.cards[fil].endDate && moment(new Date(db.cards[fil].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                                ).length}\n                                            </div>\n                                        </div>\n                                    </UiCardBody>\n                                </UiCard>\n                            </GridItem>\n                            :\n                            <GridItem xs={12} sm={6} md={6} lg={3}>\n                                <UiCard>\n                                    <HeaderWithMenu\n                                        title={translate(`$__matrix`, 1)}\n                                        icon={MatrixIcon}\n                                        color={customApp('colorText')}\n                                        style={{\n                                            background: customApp('ColumnTitleColor'),\n                                            padding: '7px'\n                                        }}\n                                    />\n\n                                    <UiCardHeader style={{ height: '300px', display: 'flex' }}>\n                                        <ResponsiveCirclePackingCanvas\n                                            data={{\n                                                \"name\": \"root\",\n                                                \"children\": [\n                                                    {\n                                                        name: translate(\"$__guidelines\", 1),\n                                                        value: Object.keys(db.cards).filter(fil => db.cards[fil]._planId === hashs[0] && db.cards[fil].type.indexOf('guideline') > -1).length\n                                                    },\n                                                    {\n                                                        name: translate(\"$__strength\", 1),\n                                                        value: Object.keys(db.cards)\n                                                            .filter(fil =>\n                                                                db.cards[fil]._planId === hashs[0]\n                                                                && db.cards[fil].type === 'strength'\n                                                            ).length\n                                                    },\n                                                    {\n                                                        name: translate(\"$__weakness\", 1),\n                                                        value: Object.keys(db.cards)\n                                                            .filter(fil =>\n                                                                db.cards[fil]._planId === hashs[0]\n                                                                && db.cards[fil].type === 'weakness'\n                                                            ).length\n                                                    },\n                                                    {\n                                                        name: translate(\"$__opportunity\", 1),\n                                                        value: Object.keys(db.cards)\n                                                            .filter(fil =>\n                                                                db.cards[fil]._planId === hashs[0]\n                                                                && db.cards[fil].type === 'opportunity'\n                                                            ).length\n                                                    },\n                                                    {\n                                                        name: translate(\"$__threat\", 1),\n                                                        value: Object.keys(db.cards)\n                                                            .filter(fil =>\n                                                                db.cards[fil]._planId === hashs[0]\n                                                                && db.cards[fil].type === 'threat'\n                                                            ).length\n                                                    }\n                                                ]\n                                            }}\n                                            margin={{ top: 20, right: 20, bottom: 20, left: 20 }}\n                                            id=\"name\"\n                                            colors={{ scheme: 'purpleRed_green' }}\n                                            colorBy=\"id\"\n                                            childColor={{ from: 'color', modifiers: [['brighter', 0.4]] }}\n                                            padding={1}\n                                            leavesOnly={true}\n                                            enableLabels={true}\n                                            label=\"value\"\n                                            labelTextColor={\"#FFFFFF\"}\n                                            borderColor={{ from: 'color', modifiers: [['darker', 0.3]] }}\n                                            animate={false}\n                                        />\n                                    </UiCardHeader>\n                                    <UiCardBody>\n                                        <h3>\n                                            <small>{translate('$__total', 1)}: {Object.keys(db.cards)\n                                                .filter(fil =>\n                                                    db.cards[fil]._planId === hashs[0]\n                                                    && (\n                                                        db.cards[fil].type.indexOf('guideline') > -1\n                                                        || db.cards[fil].type === 'strength'\n                                                        || db.cards[fil].type === 'weakness'\n                                                        || db.cards[fil].type === 'opportunity'\n                                                        || db.cards[fil].type === 'threat'\n                                                    )\n                                                ).length}</small>\n                                        </h3>\n                                        <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                            <div style={{ display: 'flex' }}>\n                                                <Icon icon={MatrixIcon}></Icon>\n                                                <span style={{ marginLeft: '15px' }} >{translate('$__guidelines', 1)}</span>\n                                            </div>\n                                            <div>\n                                                {Object.keys(db.cards)\n                                                    .filter(fil =>\n                                                        db.cards[fil]._planId === hashs[0]\n                                                        && db.cards[fil].type.indexOf('guideline') > -1\n                                                    ).length}\n                                            </div>\n                                        </div>\n                                        <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                            <div style={{ display: 'flex' }}>\n                                                <Icon >arrow_upward</Icon>\n                                                <span style={{ marginLeft: '15px' }} >{translate('$__strength', 1)}</span>\n                                            </div>\n                                            <div>\n                                                {Object.keys(db.cards)\n                                                    .filter(fil =>\n                                                        db.cards[fil]._planId === hashs[0]\n                                                        && !db.cards[fil].checklist\n                                                        && !db.cards[fil].deleted\n                                                        && db.cards[fil].type === 'strength'\n                                                    ).length}\n                                            </div>\n                                        </div>\n                                        <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                            <div style={{ display: 'flex' }}>\n                                                <Icon >arrow_downward</Icon>\n                                                <span style={{ marginLeft: '15px' }} >{translate('$__weakness', 1)}</span>\n                                            </div>\n                                            <div>\n                                                {Object.keys(db.cards)\n                                                    .filter(fil =>\n                                                        db.cards[fil]._planId === hashs[0]\n                                                        && !db.cards[fil].checklist\n                                                        && !db.cards[fil].deleted\n                                                        && db.cards[fil].type === 'weakness'\n                                                    ).length}\n                                            </div>\n                                        </div>\n                                        <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                            <div style={{ display: 'flex' }}>\n                                                <Icon>trending_up</Icon>\n                                                <span style={{ marginLeft: '15px' }} >{translate('$__opportunity', 1)}</span>\n                                            </div>\n                                            <div>\n                                                {Object.keys(db.cards)\n                                                    .filter(fil =>\n                                                        db.cards[fil]._planId === hashs[0]\n                                                        && !db.cards[fil].checklist\n                                                        && !db.cards[fil].deleted\n                                                        && db.cards[fil].type === 'opportunity'\n                                                    ).length}\n                                            </div>\n                                        </div>\n                                        <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                            <div style={{ display: 'flex' }}>\n                                                <Icon >trending_down</Icon>\n                                                <span style={{ marginLeft: '15px' }} >{translate('$__threat', 1)}</span>\n                                            </div>\n                                            <div>\n                                                {Object.keys(db.cards)\n                                                    .filter(fil =>\n                                                        db.cards[fil]._planId === hashs[0]\n                                                        && !db.cards[fil].checklist\n                                                        && !db.cards[fil].deleted\n                                                        && db.cards[fil].type === 'threat'\n                                                    ).length}\n                                            </div>\n                                        </div>\n                                    </UiCardBody>\n                                </UiCard>\n                            </GridItem>\n                        }\n\n                        <GridItem xs={12} sm={6} md={6} lg={3}>\n                            <UiCard>\n                                <HeaderWithMenu\n                                    title={titles?.objectives?.name ? titles.objectives.name : translate(`$__objectives`, 1)}\n                                    icon={titles?.objectives?.icon ? titles.objectives.icon : \"gps_fixed\"}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <UiCardHeader style={{ height: '300px', display: 'flex' }}>\n                                    <ResponsivePie\n                                        data={[\n                                            ...db.status.map((st, index) => {\n                                                return {\n                                                    id: translate(st.label, 1),\n                                                    label: translate(st.label, 1),\n                                                    value: Object.keys(db.cards).filter(fil =>\n                                                        db.cards[fil]._planId === hashs[0]\n                                                        && !db.cards[fil].checklist\n                                                        && !db.cards[fil].deleted\n                                                        && db.cards[fil].type === 'objective'\n                                                        && db.cards[fil].status && db.cards[fil].status === st.value).length,\n                                                    color: st.color\n                                                }\n                                            }),\n                                            {\n                                                id: translate('$__late', 1),\n                                                label: translate('$__late', 1),\n                                                value: Object.keys(db.cards).filter(fil =>\n                                                    db.cards[fil]._planId === hashs[0]\n                                                    && !db.cards[fil].checklist\n                                                    && !db.cards[fil].deleted\n                                                    && db.cards[fil].status !== 'completed'\n                                                    && db.cards[fil].type === 'objective'\n                                                    && db.cards[fil].endDate && moment(new Date(db.cards[fil].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                                ).length,\n                                                color: 'red'\n                                            }\n                                        ]}\n                                        colors={['#929497', '#011E41', '#EBA900', '#5A7F71', 'red']}\n                                        margin={{ top: 17, right: 17, bottom: 17, left: 17 }}\n                                        arcLabelsTextColor={{ from: 'color', modifiers: [['brighter', 3]] }}\n                                        innerRadius={0.5}\n                                        padAngle={3}\n                                        cornerRadius={3}\n                                        activeOuterRadiusOffset={8}\n                                        borderWidth={1}\n                                        borderColor={{ from: 'color', modifiers: [['darker', 0.2]] }}\n                                        enableArcLinkLabels={false}\n                                    />\n                                </UiCardHeader>\n                                <UiCardBody>\n                                    <h3>\n                                        <small>{translate('$__total', 1)}: {Object.keys(db.cards).filter(fil => db.cards[fil]._planId === hashs[0] && !db.cards[fil].deleted && !db.cards[fil].checklist && db.cards[fil].type === 'objective').length}</small>\n                                    </h3>\n                                    {db.status.map((st, index) => {\n                                        return (\n                                            <div key={`${index}_${st.value}`} style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                                <div style={{ display: 'flex' }}>\n                                                    <Icon color={st.color}>{st.icon}</Icon>\n                                                    <span style={{ marginLeft: '15px' }} >{translate(st.label, 1)}</span>\n                                                </div>\n                                                <div>\n                                                    {Object.keys(db.cards).filter(fil => db.cards[fil]._planId === hashs[0] && db.cards[fil].type === 'objective' && db.cards[fil].status && !db.cards[fil].checklist && db.cards[fil].status === st.value).length}\n                                                </div>\n                                            </div>\n                                        )\n                                    })}\n                                    <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                        <div style={{ display: 'flex' }}>\n                                            <Icon color={'red'}>assignment_late</Icon>\n                                            <span style={{ marginLeft: '15px' }} >{translate('$__late', 1)}</span>\n                                        </div>\n                                        <div>\n                                            {Object.keys(db.cards).filter(fil =>\n                                                db.cards[fil]._planId === hashs[0]\n                                                && !db.cards[fil].checklist\n                                                && !db.cards[fil].deleted\n                                                && db.cards[fil].status !== 'completed'\n                                                && db.cards[fil].type === 'objective'\n                                                && db.cards[fil].endDate && moment(new Date(db.cards[fil].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                            ).length}\n                                        </div>\n                                    </div>\n                                </UiCardBody>\n                            </UiCard>\n                        </GridItem>\n                        <GridItem xs={12} sm={6} md={6} lg={3}>\n                            <UiCard>\n                                <HeaderWithMenu\n                                    title={titles?.goals?.name ? titles.goals.name : translate(`$__goals`, 1)}\n                                    icon={titles?.goals?.icon ? titles.goals.icon : \"flag\"}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <UiCardHeader style={{ height: '300px', display: 'flex' }}>\n                                    <ResponsivePie\n                                        data={[\n                                            ...db.status.map((st, index) => {\n                                                return {\n                                                    id: translate(st.label, 1),\n                                                    label: translate(st.label, 1),\n                                                    value: Object.keys(db.cards).filter(fil => db.cards[fil]._planId === hashs[0] && db.cards[fil].type === 'goal' && !db.cards[fil].checklist && !db.cards[fil].deleted && db.cards[fil].status && db.cards[fil].status === st.value).length,\n                                                    color: st.color\n                                                }\n                                            }),\n                                            {\n                                                id: translate('$__late', 1),\n                                                label: translate('$__late', 1),\n                                                value: Object.keys(db.cards).filter(fil =>\n                                                    db.cards[fil]._planId === hashs[0]\n                                                    && !db.cards[fil].checklist\n                                                    && !db.cards[fil].deleted\n                                                    && db.cards[fil].status !== 'completed'\n                                                    && db.cards[fil].type === 'goal'\n                                                    && db.cards[fil].endDate && moment(new Date(db.cards[fil].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                                ).length,\n                                                color: 'red'\n                                            }\n                                        ]}\n                                        colors={['#929497', '#011E41', '#EBA900', '#5A7F71', 'red']}\n                                        margin={{ top: 17, right: 17, bottom: 17, left: 17 }}\n                                        arcLabelsTextColor={{ from: 'color', modifiers: [['brighter', 3]] }}\n                                        innerRadius={0.5}\n                                        padAngle={3}\n                                        cornerRadius={3}\n                                        activeOuterRadiusOffset={8}\n                                        borderWidth={1}\n                                        borderColor={{ from: 'color', modifiers: [['darker', 0.2]] }}\n                                        enableArcLinkLabels={false}\n                                    />\n                                </UiCardHeader>\n                                <UiCardBody>\n                                    <h3>\n                                        <small>{translate('$__total', 1)}: {Object.keys(db.cards).filter(fil => db.cards[fil]._planId === hashs[0] && !db.cards[fil].checklist && !db.cards[fil].deleted && db.cards[fil].type === 'goal').length}</small>\n                                    </h3>\n                                    {db.status.map((st, index) => {\n                                        return (\n                                            <div key={`${index}_${st.value}`} style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                                <div style={{ display: 'flex' }}>\n                                                    <Icon color={st.color}>{st.icon}</Icon>\n                                                    <span style={{ marginLeft: '15px' }} >{translate(st.label, 1)}</span>\n                                                </div>\n                                                <div>\n                                                    {Object.keys(db.cards).filter(fil => db.cards[fil]._planId === hashs[0] && db.cards[fil].type === 'goal' && !db.cards[fil].checklist && !db.cards[fil].deleted && db.cards[fil].status && db.cards[fil].status === st.value).length}\n                                                </div>\n                                            </div>\n                                        )\n                                    })}\n                                    <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                        <div style={{ display: 'flex' }}>\n                                            <Icon color={'red'}>assignment_late</Icon>\n                                            <span style={{ marginLeft: '15px' }} >{translate('$__late', 1)}</span>\n                                        </div>\n                                        <div>\n                                            {Object.keys(db.cards).filter(fil =>\n                                                db.cards[fil]._planId === hashs[0]\n                                                && !db.cards[fil].checklist\n                                                && !db.cards[fil].deleted\n                                                && db.cards[fil].status !== 'completed'\n                                                && db.cards[fil].type === 'goal'\n                                                && db.cards[fil].endDate && moment(new Date(db.cards[fil].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                            ).length}\n                                        </div>\n                                    </div>\n                                </UiCardBody>\n                            </UiCard>\n                        </GridItem>\n                        <GridItem xs={12} sm={6} md={6} lg={3}>\n                            <UiCard>\n                                <HeaderWithMenu\n                                    title={titles?.actions?.name ? titles.actions.name : translate(`$__actions`, 1)}\n                                    icon={titles?.actions?.icon ? titles.actions.icon : \"play_arrow\"}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <UiCardHeader style={{ height: '300px', display: 'flex' }}>\n                                    <ResponsivePie\n                                        data={[\n                                            ...db.status.map((st, index) => {\n                                                return {\n                                                    id: translate(st.label, 1),\n                                                    label: translate(st.label, 1),\n                                                    value: Object.keys(db.cards).filter(fil =>\n                                                        db.cards[fil]._planId === hashs[0]\n                                                        && !db.cards[fil].deleted\n                                                        && db.cards[fil].status\n                                                        && db.cards[fil].status === st.value\n                                                        && (\n                                                            db.cards[fil].type === 'iniciative'\n                                                            || db.cards[fil].type === 'task'\n                                                            || db.cards[fil].type === 'meeting'\n                                                            || db.cards[fil].type === 'iniciative'\n                                                            || db.cards[fil].type === 'myTask'\n                                                            || (\n                                                                !db.cards[fil].checklist\n                                                                || (\n                                                                    db.cards[fil].checklist\n                                                                    && db.cards[fil].showCard\n                                                                )\n                                                            )\n                                                        )\n                                                    ).length,\n                                                    color: st.color\n                                                }\n                                            }),\n                                            {\n                                                id: translate('$__late', 1),\n                                                label: translate('$__late', 1),\n                                                value: Object.keys(db.cards).filter(fil =>\n                                                    db.cards[fil]._planId === hashs[0]\n                                                    && !db.cards[fil].deleted\n                                                    && db.cards[fil].status !== 'completed'\n                                                    && (\n                                                        db.cards[fil].type === 'iniciative'\n                                                        || db.cards[fil].type === 'task'\n                                                        || db.cards[fil].type === 'meeting'\n                                                        || db.cards[fil].type === 'iniciative'\n                                                        || db.cards[fil].type === 'myTask'\n                                                        || (\n                                                            !db.cards[fil].checklist\n                                                            || (\n                                                                db.cards[fil].checklist\n                                                                && db.cards[fil].showCard\n                                                            )\n                                                        )\n                                                    )\n                                                    && db.cards[fil].endDate && moment(new Date(db.cards[fil].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                                ).length,\n                                                color: 'red'\n                                            }\n                                        ]}\n                                        colors={['#929497', '#011E41', '#EBA900', '#5A7F71', 'red']}\n                                        margin={{ top: 17, right: 17, bottom: 17, left: 17 }}\n                                        arcLabelsTextColor={{ from: 'color', modifiers: [['brighter', 3]] }}\n                                        innerRadius={0.5}\n                                        padAngle={3}\n                                        cornerRadius={3}\n                                        activeOuterRadiusOffset={8}\n                                        borderWidth={1}\n                                        borderColor={{ from: 'color', modifiers: [['darker', 0.2]] }}\n                                        enableArcLinkLabels={false}\n                                    />\n                                </UiCardHeader>\n                                <UiCardBody>\n\n                                    <h3>\n                                        <small>{translate('$__total', 1)}: {Object.keys(db.cards)\n                                            .filter(fil =>\n                                                db.cards[fil]._planId === hashs[0]\n                                                && !db.cards[fil].deleted\n                                                && (\n                                                    db.cards[fil].type === 'iniciative'\n                                                    || db.cards[fil].type === 'task'\n                                                    || db.cards[fil].type === 'meeting'\n                                                    || db.cards[fil].type === 'iniciative'\n                                                    || db.cards[fil].type === 'myTask'\n                                                    || (\n                                                        !db.cards[fil].checklist\n                                                        || (\n                                                            db.cards[fil].checklist\n                                                            && db.cards[fil].showCard\n                                                        )\n                                                    )\n                                                )\n                                            ).length}</small>\n                                    </h3>\n                                    {db.status.map((st, index) => {\n                                        return (\n                                            <div key={`${index}_${st.value}`} style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                                <div style={{ display: 'flex' }}>\n                                                    <Icon color={st.color}>{st.icon}</Icon>\n                                                    <span style={{ marginLeft: '15px' }} >{translate(st.label, 1)}</span>\n                                                </div>\n                                                <div>\n                                                    {Object.keys(db.cards)\n                                                        .filter(fil =>\n                                                            db.cards[fil]._planId === hashs[0]\n                                                            && !db.cards[fil].deleted\n                                                            && (\n                                                                db.cards[fil].type === 'iniciative'\n                                                                || db.cards[fil].type === 'task'\n                                                                || db.cards[fil].type === 'meeting'\n                                                                || db.cards[fil].type === 'iniciative'\n                                                                || db.cards[fil].type === 'myTask'\n                                                                || (\n                                                                    !db.cards[fil].checklist\n                                                                    || (\n                                                                        db.cards[fil].checklist\n                                                                        && db.cards[fil].showCard\n                                                                    )\n                                                                )\n                                                            )\n                                                            && db.cards[fil].status && db.cards[fil].status === st.value\n                                                        ).length}\n                                                </div>\n                                            </div>\n                                        )\n                                    })}\n                                    <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                        <div style={{ display: 'flex' }}>\n                                            <Icon color={'red'}>assignment_late</Icon>\n                                            <span style={{ marginLeft: '15px' }} >{translate('$__late', 1)}</span>\n                                        </div>\n                                        <div>\n                                            {Object.keys(db.cards).filter(fil =>\n                                                db.cards[fil]._planId === hashs[0]\n                                                && !db.cards[fil].deleted\n                                                && db.cards[fil].status !== 'completed'\n                                                && (\n                                                    db.cards[fil].type === 'iniciative'\n                                                    || db.cards[fil].type === 'task'\n                                                    || db.cards[fil].type === 'meeting'\n                                                    || db.cards[fil].type === 'iniciative'\n                                                    || db.cards[fil].type === 'myTask'\n                                                    || (\n                                                        !db.cards[fil].checklist\n                                                        || (\n                                                            db.cards[fil].checklist\n                                                            && db.cards[fil].showCard\n                                                        )\n                                                    )\n                                                )\n                                                && db.cards[fil].endDate && moment(new Date(db.cards[fil].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                            ).length}\n                                        </div>\n                                    </div>\n                                </UiCardBody>\n                                {/* <UiCardFooter stats>\n                            <div className={classes.stats}>\n                                <Danger>\n                                    <Warning />\n                                </Danger>\n                                <a href=\"#pablo\" onClick={e => e.preventDefault()}>\n                                    {translate('$__updatePlan', 1)}\n                                </a>\n                            </div>\n                        </UiCardFooter> */}\n                            </UiCard>\n                        </GridItem>\n                    </GridContainer>\n                </GridItem>\n            </GridContainer>\n            <GridContainer>\n                {Object.keys(db.cards)\n                    .filter(card =>\n                        db.cards[card]._planId === hashs[0]\n                        && db.cards[card].status !== 'completed'\n                        && (\n                            db.cards[card].startDate\n                            && moment(new Date(db.cards[card].startDate * 1000)).tz('America/Sao_Paulo').format() >= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                        )\n                    ).length > 0\n                    &&\n                    <GridItem md={6} xs={12}>\n                        <UiCard>\n                            <HeaderWithMenu\n                                title={translate(`$__nextActivities`, 1)}\n                                icon={'pending_actions'}\n                                color={customApp('colorText')}\n                                style={{\n                                    background: customApp('ColumnTitleColor'),\n                                    padding: '7px'\n                                }}\n                            />\n                            <UiCardBody>\n                                <GridContainer>\n                                    {Object.keys(db.cards)\n                                        .filter(card =>\n                                            db.cards[card]._planId === hashs[0]\n                                            && !db.cards[card].deleted\n                                            && db.cards[card].status !== 'completed'\n                                            && (\n                                                db.cards[card].startDate\n                                                && moment(new Date(db.cards[card].startDate * 1000)).tz('America/Sao_Paulo').format() >= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                            )\n                                        )\n                                        .sort((a, b) => {\n                                            let completeA = db.cards[a].completed_at && db.cards[a].completed_at.low ? parseInt(db.cards[a].completed_at.low) : typeof db.cards[a].completed_at === 'string' ? db.cards[a].completed_at : 0\n                                            let completeB = db.cards[b].completed_at && db.cards[b].completed_at.low ? parseInt(db.cards[b].completed_at.low) : typeof db.cards[b].completed_at === 'string' ? db.cards[b].completed_at : 0\n                                            if (completeA > completeB) {\n                                                return -1\n                                            } else if (completeA < completeB) {\n                                                return 1\n                                            } else {\n                                                return 0\n                                            }\n                                        })\n                                        .map((card, i) => {\n                                            if (i >= (nextActivities_page - 1) * 7 && i < nextActivities_page * 7)\n                                                return (<Card\n                                                    db=\"cards\"\n                                                    key={card}\n                                                    data={db.cards[card]}\n                                                    inLine={true}\n                                                />)\n                                        }\n                                        )}\n                                    {Math.ceil(Object.keys(db.cards).filter(card =>\n                                        db.cards[card]._planId === hashs[0]\n                                        && db.cards[card].status !== 'completed'\n                                        && (db.cards[card].startDate && moment(new Date(db.cards[card].startDate * 1000)).tz('America/Sao_Paulo').format() >= moment(new Date(today)).tz('America/Sao_Paulo').format())\n                                    ).length / 7) > 1 &&\n                                        <div style={{ width: '100%', display: 'flex', justifyContent: 'center' }} >\n                                            <Pagination\n                                                page={nextActivities_page}\n                                                count={Math.ceil(Object.keys(db.cards).filter(card =>\n                                                    db.cards[card]._planId === hashs[0]\n                                                    && db.cards[card].status !== 'completed'\n                                                    && (db.cards[card].startDate && moment(new Date(db.cards[card].startDate * 1000)).tz('America/Sao_Paulo').format() >= moment(new Date(today)).tz('America/Sao_Paulo').format())\n                                                ).length / 7)}\n                                                onChange={(e, p) => {\n                                                    setNextActivities_page(p)\n                                                }}\n                                            />\n                                        </div>\n                                    }\n                                </GridContainer>\n                            </UiCardBody>\n                        </UiCard>\n                    </GridItem>\n                }\n                {Object.keys(db.cards)\n                    .filter(card =>\n                        db.cards[card]._planId === hashs[0]\n                        && db.cards[card].status !== 'completed'\n                        && db.cards[card].endDate && moment(new Date(db.cards[card].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                    ).length > 0\n                    &&\n                    <GridItem md={6} xs={12}>\n                        <UiCard>\n                            <HeaderWithMenu\n                                title={translate(`$__lateActivities`, 1)}\n                                icon={'pending_actions'}\n                                color={customApp('colorText')}\n                                style={{\n                                    background: customApp('ColumnTitleColor'),\n                                    padding: '7px'\n                                }}\n                            />\n                            <UiCardBody>\n                                <GridContainer>\n                                    {Object.keys(db.cards)\n                                        .filter(card =>\n                                            db.cards[card]._planId === hashs[0]\n                                            && !db.cards[card].deleted\n                                            && db.cards[card].status !== 'completed'\n                                            && db.cards[card].endDate && moment(new Date(db.cards[card].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                        )\n                                        .sort((a, b) => {\n                                            let completeA = db.cards[a].completed_at && db.cards[a].completed_at.low ? parseInt(db.cards[a].completed_at.low) : typeof db.cards[a].completed_at === 'string' ? db.cards[a].completed_at : 0\n                                            let completeB = db.cards[b].completed_at && db.cards[b].completed_at.low ? parseInt(db.cards[b].completed_at.low) : typeof db.cards[b].completed_at === 'string' ? db.cards[b].completed_at : 0\n                                            if (completeA > completeB) {\n                                                return -1\n                                            } else if (completeA < completeB) {\n                                                return 1\n                                            } else {\n                                                return 0\n                                            }\n                                        })\n                                        .map((card, i) => {\n                                            if (i >= (dueActivities_page - 1) * 7 && i < dueActivities_page * 7)\n                                                return (<Card\n                                                    db=\"cards\"\n                                                    key={card}\n                                                    data={db.cards[card]}\n                                                    inLine={true}\n                                                />)\n                                        }\n                                        )}\n                                    {Math.ceil(Object.keys(db.cards).filter(card =>\n                                        db.cards[card]._planId === hashs[0]\n                                        && db.cards[card].status !== 'completed'\n                                        && db.cards[card].endDate && moment(new Date(db.cards[card].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                    ).length / 7) > 1 &&\n                                        <div style={{ width: '100%', display: 'flex', justifyContent: 'center' }} >\n                                            <Pagination\n                                                page={dueActivities_page}\n                                                count={Math.ceil(Object.keys(db.cards).filter(card =>\n                                                    db.cards[card]._planId === hashs[0]\n                                                    && db.cards[card].status !== 'completed'\n                                                    && db.cards[card].endDate && moment(new Date(db.cards[card].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment(new Date(today)).tz('America/Sao_Paulo').format()\n                                                ).length / 7)}\n                                                onChange={(e, p) => {\n                                                    setDueActivities_page(p)\n                                                }}\n                                            />\n                                        </div>\n                                    }\n                                </GridContainer>\n                            </UiCardBody>\n                        </UiCard>\n                    </GridItem>\n                }\n                {Object.keys(db.cards).filter(card => db.cards[card]._planId === hashs[0] && db.cards[card].status === 'completed').length > 0 &&\n                    <GridItem md={6} xs={12}>\n                        <UiCard>\n                            <HeaderWithMenu\n                                title={translate(`$__lastCompletedCards`, 1)}\n                                icon={'pending_actions'}\n                                color={customApp('colorText')}\n                                style={{\n                                    background: customApp('ColumnTitleColor'),\n                                    padding: '7px'\n                                }}\n                            />\n                            <UiCardBody>\n                                <GridContainer>\n                                    {Object.keys(db.cards)\n                                        .filter(card =>\n                                            db.cards[card]._planId === hashs[0]\n                                            && !db.cards[card].deleted\n                                            && (\n                                                !db.cards[card].checklist\n                                                ||\n                                                (\n                                                    db.cards[card].checklist\n                                                    && db.cards[card].showCard\n                                                )\n                                            )\n                                            && db.cards[card].status === 'completed'\n                                        )\n                                        .sort((a, b) => {\n                                            let completeA = db.cards[a].completed_at && db.cards[a].completed_at.low ? parseInt(db.cards[a].completed_at.low) : typeof db.cards[a].completed_at === 'string' ? db.cards[a].completed_at : 0\n                                            let completeB = db.cards[b].completed_at && db.cards[b].completed_at.low ? parseInt(db.cards[b].completed_at.low) : typeof db.cards[b].completed_at === 'string' ? db.cards[b].completed_at : 0\n                                            if (completeA > completeB) {\n                                                return -1\n                                            } else if (completeA < completeB) {\n                                                return 1\n                                            } else {\n                                                return 0\n                                            }\n                                        })\n                                        .map((card, i) => {\n                                            if (i >= (lastCompletedCards_page - 1) * 7 && i < lastCompletedCards_page * 7) {\n                                                return (<Card\n                                                    db=\"cards\"\n                                                    key={card}\n                                                    data={db.cards[card]}\n                                                    inLine={true}\n                                                />)\n                                            }\n                                        }\n                                        )}\n                                    {Math.ceil(Object.keys(db.cards).filter(card => db.cards[card]._planId === hashs[0] && db.cards[card].status === 'completed').length / 7) > 1 &&\n                                        <div style={{ width: '100%', display: 'flex', justifyContent: 'center' }} >\n                                            <Pagination\n                                                page={lastCompletedCards_page}\n                                                count={Math.ceil(Object.keys(db.cards).filter(card => db.cards[card]._planId === hashs[0] && db.cards[card].status === 'completed').length / 7)}\n                                                onChange={(e, p) => {\n                                                    setlastCompletedCards_page(p)\n                                                }}\n                                            />\n                                        </div>\n                                    }\n                                </GridContainer>\n                            </UiCardBody>\n                        </UiCard>\n                    </GridItem>\n                }\n                {Object.keys(db.cards).filter(a => {\n                    if (\n                        db.cards[a]._planId === hashs[0]\n                        && db.cards[a]._users\n                        && (\n                            Object.keys(db.cards[a]._users).filter(user => db.cards[a]._users[user].myDay\n                                && moment(new Date(db.cards[a]._users[user].myDay * 1000)).tz('America/Sao_Paulo').format('YYYY/MM/DD') === today\n                            ).length > 0\n                        )\n                    )\n                        return true\n                }\n                ).length > 0 &&\n                    <GridItem md={6} xs={12}>\n                        <UiCard>\n                            <HeaderWithMenu\n                                title={translate(`$__todayTasks`, 1)}\n                                icon={'today'}\n                                color={customApp('colorText')}\n                                style={{\n                                    background: customApp('ColumnTitleColor'),\n                                    padding: '7px'\n                                }}\n                            />\n                            <UiCardBody>\n                                <GridContainer>\n                                    {Object.keys(db.cards).filter(a => {\n                                        if (\n                                            db.cards[a]._planId === hashs[0]\n                                            && !db.cards[a].deleted\n                                            && db.cards[a]._users\n                                            && (\n                                                Object.keys(db.cards[a]._users).filter(user => db.cards[a]._users[user].myDay\n                                                    && moment(new Date(db.cards[a]._users[user].myDay * 1000)).tz('America/Sao_Paulo').format('YYYY/MM/DD') === today\n                                                ).length > 0\n                                            )\n                                        )\n                                            return true\n                                    }\n                                    ).map(card =>\n                                        <Card\n                                            db=\"cards\"\n                                            key={card}\n                                            data={db.cards[card]}\n                                        />\n                                    )}\n                                </GridContainer>\n                            </UiCardBody>\n                        </UiCard>\n                    </GridItem>\n                }\n                <GridItem md={6} xs={12}>\n                    <ErrorBoundary>\n                        <Timesheet\n                            nodeId={hashs[0]}\n                        />\n                    </ErrorBoundary>\n                </GridItem>\n            </GridContainer>\n        </div >\n    );\n}\nconst mapStateToProps = (store) => ({\n    store: { cards: store.db.cards }\n}\n)\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(Dashboard);","import React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\n\n//COMPONENTS\nimport Card from \"components/Card\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\nimport HeaderWithIcon from \"components/Header/withIcon\";\n\n//@MATERIAL\nimport TablePagination from '@material-ui/core/TablePagination';\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/InsightBoards.js\";\nimport InsightsIcon from \"assets/icons/Ideas\";\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp\n} from \"functions/\";\n\nfunction Component(props) {\n    const { classes } = props\n    const { db, search } = reduxStore.getState()\n    const [page, setPage] = React.useState(0)\n    const [limit, setLimit] = React.useState(25)\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    let insightsCards = {}\n\n    if (hashs[0].length === 36) {\n        insightsCards = Object.keys(db.cards)\n            .filter(a => db.cards[a]._parent && db.cards[a]._parent === hashs[0] && db.cards[a].type === 'insight' && !db.cards[a].deleted)\n            .sort((a, b) => {\n                if (db.cards[a].created_at > db.cards[b].created_at)\n                    return -1\n                return 0\n            })\n            .map(a => db.cards[a])\n        insightsCards = insightsCards.filter(a =>\n        ((a.description && a.description.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n            || (a.name && a.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n        )).map(a => a)\n    } else {\n        insightsCards = Object.keys(db.cards)\n            .filter(a => !db.cards[a]._parent && db.cards[a].type === 'insight')\n            .sort((a, b) => {\n                if (db.cards[a].created_at > db.cards[b].created_at)\n                    return -1\n                return 0\n            })\n            .map(a => db.cards[a])\n        insightsCards = insightsCards.filter(a =>\n        ((a.description && a.description.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n            || (a.name && a.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n        )).map(a => a)\n    }\n\n    return (\n        <div style={{ position: 'relative', justifyContent: 'space-between', margin: 'auto', width: '100%' }}>\n            {/* <HeaderWithIcon\n                title={`insights`}\n                icon={InsightsIcon}\n                fontSize='20px'\n                color={customApp('menu')}\n            /> */}\n            {Object.keys(insightsCards).length > 25 &&\n                <div style={{\n                    position: \"relative\",\n                    float: 'left',\n                    width: '100%',\n                    left: '0px',\n                    right: '0px',\n                    padding: '15px',\n                    display: 'flex',\n                    alignItems: 'center',\n                    justifyContent: 'center'\n                }}>\n                    {/* PAGINATION */}\n                    {translate('$__page')} {page + 1} {translate('$__of')} {Math.ceil(Object.keys(insightsCards).length / limit)}\n                    <div style={{ display: 'flex', alignItems: 'center' }}>\n                        <TablePagination\n                            component=\"div\"\n                            count={Object.keys(insightsCards).length}\n                            page={page}\n                            onChangePage={(event, newPage) => {\n                                setPage(newPage)\n                            }}\n                            rowsPerPage={limit}\n                            onChangeRowsPerPage={(event) => {\n                                setLimit(parseInt(event.target.value, 10))\n                            }}\n                            labelRowsPerPage={translate('$__insightsPerPage')}\n                        />\n                    </div>\n                </div>\n            }\n            <GridContainer>\n                {Object.keys(insightsCards).map((card, i) => {\n                    if (i <= ((page + 1) * limit) && i >= page * limit)\n                        return (\n                            <GridItem\n                                key={insightsCards[card]._id}\n                                xs={12}\n                                sm={6}\n                                md={4}\n                                lg={3}\n                                xl={2}\n                            >\n                                <Card db=\"cards\" data={insightsCards[card]} expanded Avatar Resume />\n                            </GridItem>\n                        )\n                }\n                )\n                }\n            </GridContainer>\n            {Object.keys(insightsCards).length > 25 &&\n                <div style={{\n                    position: \"relative\",\n                    float: 'left',\n                    width: '100%',\n                    left: '0px',\n                    right: '0px',\n                    padding: '15px',\n                    display: 'flex',\n                    alignItems: 'center',\n                    justifyContent: 'center'\n                }}>\n                    {/* PAGINATION */}\n                    {translate('$__page')} {page + 1} {translate('$__of')} {Math.ceil(Object.keys(insightsCards).length / limit)}\n                    <div style={{ display: 'flex', alignItems: 'center' }}>\n                        <TablePagination\n                            component=\"div\"\n                            count={Object.keys(insightsCards).length}\n                            page={page}\n                            onChangePage={(event, newPage) => {\n                                setPage(newPage)\n                            }}\n                            rowsPerPage={limit}\n                            onChangeRowsPerPage={(event) => {\n                                setLimit(parseInt(event.target.value, 10))\n                            }}\n                            labelRowsPerPage={translate('$__insightsPerPage')}\n                        />\n                    </div>\n                </div>\n            }\n        </div>\n    )\n}\n\nconst mapStateToProps = (store, ownProps) => {\n    return {\n        store: store,\n        ownProps: ownProps\n    };\n};\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","import React from 'react';\nimport PropTypes from 'prop-types';\n\n//@MATERIAL\nimport { makeStyles } from '@material-ui/core/styles';\nimport Button from '@material-ui/core/Button';\nimport List from '@material-ui/core/List';\nimport ListItem from '@material-ui/core/ListItem';\nimport ListItemAvatar from '@material-ui/core/ListItemAvatar';\nimport ListItemText from '@material-ui/core/ListItemText';\nimport DialogTitle from '@material-ui/core/DialogTitle';\nimport Dialog from '@material-ui/core/Dialog';\nimport Typography from '@material-ui/core/Typography';\nimport { blue } from '@material-ui/core/colors';\n\n//COMPONENTS\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport Icon from \"components/Icon\";\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\";\n\nconst useStyles = makeStyles({\n    avatar: {\n        backgroundColor: blue[100],\n        color: blue[600],\n    },\n});\n\nfunction SimpleDialog(props) {\n    const classes = useStyles();\n    const { open, selectedValue, onClose } = props;\n\n    const handleClose = () => {\n        onClose();\n    };\n\n    return (\n        <Dialog onClose={handleClose} aria-labelledby=\"simple-dialog-title\" open={open}>\n            {props && props.title &&\n                <DialogTitle id=\"simple-dialog-title\">{props.title}</DialogTitle>\n            }\n            <List>\n                {props.options.map((option, index) => {\n                    return (\n                        <ListItem\n                            button\n                            onClick={() => {\n                                if (option.onClick)\n                                    option.onClick()\n                                onClose()\n                            }}\n                            key={index}>\n                            <ListItemAvatar>\n                                <Icon icon={option.icon} />\n                            </ListItemAvatar>\n                            <ListItemText primary={translate(option.name, 1)} />\n                        </ListItem>\n                    )\n                })\n                }\n            </List>\n        </Dialog>\n    );\n}\n\nexport default function Component(props) {\n    const [open, setOpen] = React.useState(false);\n    const [selectedValue, setSelectedValue] = React.useState(null);\n\n    const handleClickOpen = () => {\n        setOpen(true);\n    };\n\n    const handleClose = (value) => {\n        setOpen(false);\n        setSelectedValue(value);\n    };\n\n    return (\n        <React.Fragment>\n            <IconButton\n                text={props.text ? props.text : null}\n                icon={props.icon ? props.icon : \"add_box\"}\n                size={props.iconSize ? props.iconSize : null}\n                iconColor={props.iconColor ? props.iconColor : customApp('medium')}\n                onClick={handleClickOpen}\n            />\n            <SimpleDialog selectedValue={selectedValue} open={open} onClose={() => { handleClose() }} options={props.options} />\n        </React.Fragment>\n    );\n}","//CORE\r\nimport React from \"react\";\r\nimport styled from \"styled-components\";\r\nimport { DragDropContext, Droppable, Draggable } from \"react-beautiful-dnd\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store/\";\r\n\r\n//COMPONENTS\r\nimport Card from \"components/Card/\";\r\nimport Icon from \"components/Icon\";\r\nimport IconButton from \"components/CustomButtons/IconButton\";\r\nimport TextField from \"components/TextField\";\r\n\r\n//FUNCTIONS\r\nimport api from \"api/\";\r\nimport { translate, customApp } from \"functions/\"\r\n\r\nfunction Component(props) {\r\n    const { db, session } = reduxStore.getState()\r\n    const { socket } = reduxStore.getState().functions\r\n    const [name, setName] = React.useState(props.defaultName ? props.defaultName : '')\r\n    const [add, setAdd] = React.useState(false)\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace('#', '')\r\n    if (hashs[0].length !== 36) {\r\n        hashs[0] = null\r\n    }\r\n\r\n    const addCard = async () => {\r\n        const { socket } = reduxStore.getState().functions\r\n\r\n        socket.emit(\"data\", {\r\n            module: \"cards\",\r\n            method: \"post\",\r\n            action: \"add\"\r\n        }, {\r\n            _parent: hashs[0],\r\n            planId: hashs[0] && hashs[0].length === 36 ? hashs[0] : null,\r\n            name,\r\n            type: props.cardType,\r\n            status: 'notStarted'\r\n        }, async (response) => {\r\n            socket.emit('card.UPD', {\r\n                cardId: response.id,\r\n                cardData: {\r\n                    ...response.data,\r\n                    // _loaded: true,\r\n                    _parent: hashs[0],\r\n                    _timeline: {\r\n                        [response.log._id]: {\r\n                            ...response.log,\r\n                            _parent: [response.id],\r\n                        }\r\n                    },\r\n                    _users: {\r\n                        [session._id]: {\r\n                            name: reduxStore.getState().db.users[session._id].name ? reduxStore.getState().db.users[session._id].name : null,\r\n                            displayName: reduxStore.getState().db.users[session._id].displayName ? reduxStore.getState().db.users[session._id].displayName : null,\r\n                            image: reduxStore.getState().db.users[session._id].image ? reduxStore.getState().db.users[session._id].image : null,\r\n                            access: 5,\r\n                            _id: session._id\r\n                        }\r\n                    },\r\n                },\r\n            })\r\n        })\r\n        setName('')\r\n    }\r\n\r\n\r\n    const onDragEnd = async result => {\r\n        const { destination, source, draggableId } = result\r\n\r\n        if (!destination) return false\r\n\r\n        if (destination.droppableId === source.droppableId && destination.id === source.index) return false\r\n\r\n        const itemOrderIds = props.cards\r\n        itemOrderIds.splice(source.index, 1)\r\n        itemOrderIds.splice(destination.index, 0, draggableId)\r\n\r\n        api.put(\"cards/reorder\", {\r\n            cards: itemOrderIds\r\n        })\r\n\r\n        let cards = {}\r\n\r\n        itemOrderIds.map((a, i) => {\r\n            cards = {\r\n                ...cards,\r\n                [a]: db.cards[a]\r\n            }\r\n            if (!cards[a].order)\r\n                cards[a]['order']['low'] = i\r\n            cards[a].order.low = i\r\n            return true\r\n        })\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...reduxStore.getState().db,\r\n            cards: {\r\n                ...reduxStore.getState().db.cards,\r\n                ...cards\r\n            }\r\n        });\r\n        socket.emit(\"card.UPD\", cards)\r\n        return\r\n\r\n    }\r\n    const onDragStart = async result => {\r\n    }\r\n    const onDragUpdate = async result => {\r\n    }\r\n\r\n    return (\r\n        <React.Fragment>\r\n            <DragDropContext\r\n                onDragEnd={onDragEnd}\r\n                onDragStart={onDragStart}\r\n                onDragUpdate={onDragUpdate}\r\n            >\r\n                <Droppable\r\n                    droppableId={`Drop_${props.cardType || ''}`} //ID OF BOARD\r\n                    type=\"column\"\r\n                    direction={\"vertical\"}\r\n                >\r\n                    {(provided, snapshot) => (\r\n                        <Container\r\n                            ref={provided.innerRef}\r\n                            {...provided.droppableProps}\r\n                            isDraggingOver={snapshot.isDraggingOver}\r\n                        >\r\n                            {props.cards.map((card, index) => (\r\n                                <Draggable\r\n                                    draggableId={card}\r\n                                    index={index}\r\n                                    key={card}\r\n                                >\r\n                                    {(provided, snapshot) => (\r\n                                        <Card\r\n                                            provided={provided}\r\n                                            snapshot={snapshot}\r\n                                            data={db.cards[card]}\r\n                                            db={'cards'}\r\n                                            viewButton\r\n                                            selectOption\r\n                                        // selectable\r\n                                        />\r\n                                    )}\r\n                                </Draggable>\r\n                            ))}\r\n                            {provided.placeholder}\r\n                        </Container>\r\n                    )}\r\n                </Droppable>\r\n            </DragDropContext>\r\n            {!add &&\r\n                <div style={{ position: 'relative', float: 'left', width: '100%', padding: '7px' }}>\r\n                    <IconButton\r\n                        text={translate(\"$__add\", '*')}\r\n                        icon=\"add_box\"\r\n                        iconColor={customApp('medium')}\r\n                        onClick={() => {\r\n                            setAdd(!add);\r\n                        }}\r\n                    />\r\n                </div>\r\n            }\r\n            {add &&\r\n                <React.Fragment>\r\n                    <div\r\n                        style={{ position: 'relative', float: 'left', width: '100%', padding: '7px', display: 'flex', alignItems: 'center' }}>\r\n                        <div style={{ width: 'calc(100% - 50px)', display: 'flex' }}>\r\n                            <TextField\r\n                                label={translate('$__nameOfCard')}\r\n                                variant={customApp('fieldVariant')}\r\n                                name={'name'}\r\n                                InputLabelProps={{\r\n                                    shrink: true,\r\n                                }}\r\n                                InputProps={{\r\n                                    autoComplete: 'new-password',\r\n                                    onChange: (d) => {\r\n                                        setName(d.target.value)\r\n                                    },\r\n                                    onBlur: (d) => {\r\n                                        if (d.target.value === '')\r\n                                            setAdd(!add)\r\n                                    },\r\n                                    onKeyDown: (e) => {\r\n                                        if (e.keyCode === 13 && name)\r\n                                            addCard()\r\n                                        if (e.keyCode === 27) {\r\n                                            setAdd(!add)\r\n                                            setName('')\r\n                                        }\r\n                                    }\r\n                                }}\r\n                                autoFocus\r\n                                value={name}\r\n                                placeholder={translate('$__titleOfCard_placeholder')}\r\n                            />\r\n                        </div>\r\n                        <div style={{ display: 'flex' }}>\r\n                            <div\r\n                                onClick={() => addCard()}\r\n                            >\r\n                                <Icon color='green' icon={'save'} title={translate('$__save', '*')} size={props.actionsSize || '25px'} />\r\n                            </div>\r\n                            <div\r\n                                onClick={() => {\r\n                                    setAdd(!add)\r\n                                    setName('')\r\n                                }}\r\n                            >\r\n                                <Icon color={customApp('medium')} icon={'cancel'} title={translate(\"$__cancel\", \"*\")} size={props.actionsSize || '25px'} />\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </React.Fragment>\r\n            }\r\n        </React.Fragment>\r\n    )\r\n}\r\n\r\nconst Container = styled.div`\r\n                    background-color:none;\r\n                    `;\r\n\r\nconst mapStateToProps = store => ({\r\n    store\r\n});\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","import React from \"react\";\r\nimport { DragDropContext, Droppable } from \"react-beautiful-dnd\";\r\nimport styled from \"styled-components\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store\";\r\n\r\n//DEPENDENCIES\r\nimport Column from \"./Column\";\r\n\r\n//FUNCTIONS\r\nimport { selectSWOT } from \"functions/cards\";\r\n\r\nfunction App(props) {\r\n    const { db } = reduxStore.getState()\r\n    const [mounted, setMounted] = React.useState(false)\r\n\r\n    React.useEffect(() => {\r\n        if (!mounted) {\r\n            setMounted(true)\r\n            selectSWOT(props)\r\n        }\r\n    })\r\n\r\n    const onDragEnd = async result => {\r\n        const { socket } = reduxStore.getState().functions\r\n        const { destination, source, draggableId } = result\r\n\r\n        if (result.combine) {\r\n            return;\r\n        }\r\n\r\n\r\n        if (!destination) return false\r\n\r\n        if (destination.droppableId === source.droppableId && destination.id === source.index) return false\r\n\r\n        const sourceColumn = source.droppableId\r\n        const destinationColumn = destination.droppableId\r\n\r\n        const sourceCardIds = Array.from(props.cards.filter(c => c.type === sourceColumn && !c.deleted).sort((a, b) => {\r\n            if (a.order && b.order && a.order.low && b.order.low && parseInt(a.order.low) < parseInt(b.order.low)) {\r\n                return -1\r\n            } else if (a.order && b.order && a.order.low && b.order.low && parseInt(a.order.low) > parseInt(b.order.low)) {\r\n                return 1\r\n            }\r\n            return 0\r\n        }\r\n        ).map(a => a._id))\r\n\r\n\r\n        //When move Card in single Column\r\n        if (sourceColumn === destinationColumn) {\r\n            const newCardsIds = Array.from(props.cards.filter(c => c.type === sourceColumn && !c.deleted).sort((a, b) => {\r\n                if (a.order && b.order && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low)) {\r\n                    return -1\r\n                } else if (a.order && b.order && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) > parseInt(b.order.low)) {\r\n                    return 1\r\n                } else {\r\n                    return 0\r\n                }\r\n            }\r\n            ).map(a => a._id))\r\n            newCardsIds.splice(source.index, 1)\r\n            newCardsIds.splice(destination.index, 0, draggableId)\r\n\r\n            let newCardsOrder = {}\r\n            newCardsIds.map((card, i) => {\r\n                newCardsOrder[card] = {\r\n                    ...db.cards[card],\r\n                    order: {\r\n                        low: i\r\n                    }\r\n                }\r\n            })\r\n\r\n            const newState = {\r\n                ...reduxStore.getState().db,\r\n                cards: {\r\n                    ...db.cards,\r\n                    ...newCardsOrder,\r\n                }\r\n            }\r\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                ...newState,\r\n            });\r\n            socket.emit(\"data\", {\r\n                module: \"cards\",\r\n                method: \"put\",\r\n                action: \"inColumn\",\r\n            }, {\r\n                node: draggableId,\r\n                source: source.droppableId,\r\n                destination: destination.droppableId,\r\n                destinationCards: newCardsIds,\r\n                columnName: 'type',\r\n                sourceCards: [],\r\n            })\r\n            return\r\n        }\r\n\r\n        //When move Card in mult Column\r\n        sourceCardIds.splice(source.index, 1)\r\n\r\n\r\n        const destinationCardIds = Array.from(props.cards.filter(c => c.type === destinationColumn).sort((a, b) => {\r\n            if (a.order && b.order && a.order.low && b.order.low && parseInt(a.order.low) < parseInt(b.order.low))\r\n                return -1\r\n            return 1\r\n        }\r\n        ).map(a => a._id))\r\n\r\n        console.log(destinationCardIds)\r\n        destinationCardIds.splice(destination.index, 0, draggableId)\r\n\r\n        let cards = {\r\n            ...db.cards\r\n        }\r\n        sourceCardIds.map((a, i) => {\r\n            cards = {\r\n                ...cards,\r\n                [a]: {\r\n                    ...cards[a] ? cards[a] : {},\r\n                    order: {\r\n                        low: i\r\n                    }\r\n                }\r\n            }\r\n            //cards[a].order.low = i\r\n        })\r\n\r\n        destinationCardIds.map((a, i) => {\r\n            cards = {\r\n                ...cards,\r\n                [a]: {\r\n                    ...cards[a] ? cards[a] : {},\r\n                    order: {\r\n                        low: i\r\n                    }\r\n                }\r\n            }\r\n        })\r\n\r\n        const newState = {\r\n            ...reduxStore.getState().db,\r\n            cards: {\r\n                ...cards,\r\n                [draggableId]: {\r\n                    ...cards[draggableId],\r\n                    type: destinationColumn,\r\n                    order: {\r\n                        low: destination.index\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        // console.log({\r\n        //     [draggableId]: {\r\n        //         ...db.cards[draggableId],\r\n        //         type: destinationColumn,\r\n        //         order: {\r\n        //             low: destination.index\r\n        //         }\r\n        //     }\r\n        // })\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...newState,\r\n        });\r\n\r\n\r\n        socket.emit(\"data\", {\r\n            module: \"cards\",\r\n            method: \"put\",\r\n            action: \"inColumn\",\r\n        }, {\r\n            node: draggableId,\r\n            source: source.droppableId,\r\n            destination: destination.droppableId,\r\n            destinationCards: destinationCardIds,\r\n            columnName: 'type',\r\n            sourceCards: sourceCardIds,\r\n        })\r\n    }\r\n\r\n    return (\r\n        <DragDropContext\r\n            onDragEnd={onDragEnd}\r\n        >\r\n            <Droppable\r\n                droppableId=\"ALL-COLUMNS-STATUS\"\r\n                type=\"column\"\r\n                direction={`${props.inLine ? 'vertical' : 'horizontal'}`}\r\n            >\r\n                {provided => (\r\n                    <Container\r\n                        {...props}\r\n                        ref={provided.innerRef}\r\n                    >\r\n                        {db.swot.map((st, index) => {\r\n                            const theColumn = {\r\n                                name: st.label,\r\n                                icon: st.icon,\r\n                                cards: [],\r\n                                emptyHide: false,\r\n                            }\r\n\r\n                            return <Column\r\n                                {...props}\r\n                                key={`${st.value}`}\r\n                                columnId={`${st.value}`}\r\n                                column={theColumn}\r\n                                cards={props.cards.filter(c => c.type === st.value).sort((a, b) => {\r\n                                    let orderA = 0\r\n                                    let orderB = 0\r\n                                    if (a.order && String(a.order.low))\r\n                                        orderA = a.order.low\r\n                                    if (b.order && String(b.order.low))\r\n                                        orderB = b.order.low\r\n                                    if (parseInt(orderA) < parseInt(orderB)) {\r\n                                        return -1\r\n                                    } else if (parseInt(orderA) > parseInt(orderB)) {\r\n                                        return 1\r\n                                    } else {\r\n                                        return 0\r\n                                    }\r\n                                }\r\n                                ).map(a => {\r\n                                    return {\r\n                                        ...a,\r\n                                        id: a._id\r\n                                    }\r\n                                })}\r\n                                index={index}\r\n                                columnsSettings={false}\r\n                                columnStyle={{\r\n                                    minWidth: '300px'\r\n                                }}\r\n                                viewButton={props.viewButton || false}\r\n                                locked={props.lockColumns && props.lockColumns.indexOf(st.value) === -1 ? true : false}\r\n                                manualOrder\r\n                                isDropDisabled\r\n                            />\r\n                        })}\r\n                        {provided.placeholder}\r\n\r\n                    </Container>\r\n                )}\r\n            </Droppable>\r\n        </DragDropContext>\r\n    )\r\n}\r\n\r\n//STYLEDS\r\nconst Container = styled.div`\r\n${props =>\r\n        !props.inLine && props.styles && props.styles.discountHeight && `height:calc(100vh - ${props.styles.discountHeight}px);`\r\n    }\r\n${props =>\r\n        props.inLine ?\r\n            `display: block;\r\n                width: -webkit-fill-available;\r\n                ${props.style}`\r\n            :\r\n            `   display: flex;\r\n                width: 100%;\r\n                ${props.style}\r\n                @media(min-width: 960px) {\r\n                    display: flex;\r\n                }\r\n                `\r\n    }\r\n    @media(max-width: 959px) {\r\n        display: contents !important;\r\n        width: -webkit-fill-available;\r\n        height:auto;\r\n      }\r\n    `\r\n\r\n//REACT\r\nconst mapStateToProps = (store) => ({\r\n    store: {\r\n        cards: store.db.cards,\r\n    }\r\n});\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch);\r\n\r\nexport default connect(\r\n    mapStateToProps,\r\n    mapDispatchToProps\r\n)(App);","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport AgileStatus from \"components/Agile/status\"\nimport Card from \"components/Card\"\nimport DialogButtons from \"components/DialogButtons\"\nimport DragDropCards from \"components/DragDrop/cards\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport Icon from \"components/Icon\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport Swot from \"components/Agile/swot\"\n\n//@MATERIAL\nimport Hidden from \"@material-ui/core/Hidden\"\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\"\n\n//ICONS\nimport MatrixIcon from \"assets/icons/Matrix.js\"\n\nfunction Component(props) {\n    const { db } = reduxStore.getState()\n    const { dataType } = db\n    const [mounted, setMounted] = React.useState(false)\n    let cards = db.cards\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n    if (hashs[0] && hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true)\n            backToMatrix()\n        }\n    })\n\n    let activeCards = {}\n\n    Object.keys(db.cards).filter(a =>\n        db.cards[a]\n        && !db.cards[a].deleted\n        && (\n            db.cards[a]._planId === hashs[0]\n            || db.cards[a]._parent === hashs[0]\n        )\n    ).map(a => {\n        activeCards = {\n            ...activeCards,\n            [a]: db.cards[a]\n        }\n    })\n\n    const selectedGuideline = Object.keys(activeCards).filter(a => activeCards[a]._selected === true && activeCards[a].type && activeCards[a].type.indexOf('guideline') > -1 && activeCards[a]._parent === hashs[0])[0] || null\n    const selectedObjective = Object.keys(activeCards).filter(a => activeCards[a]._selected === true && activeCards[a].type && activeCards[a].type === 'objective')[0] || null\n    const selectedGoal = Object.keys(activeCards).filter(a => activeCards[a]._selected === true && activeCards[a].type && activeCards[a].type === 'goal')[0] || null\n\n    const cardsGuidelineR = Object.keys(activeCards).filter(a => activeCards[a].type === 'guidelineR' && activeCards[a]._parent === hashs[0] && !activeCards[a].deleted).sort((a, b) => {\n        if (activeCards[a].order\n            && String(activeCards[a].order.low)\n            && activeCards[b].order\n            && String(activeCards[b].order.low) &&\n            parseInt(activeCards[a].order.low) > parseInt(activeCards[b].order.low)\n        )\n            return 1\n        return -1\n    })\n    const cardsGuidelineC = Object.keys(activeCards).filter(a => activeCards[a].type === 'guidelineC' && activeCards[a]._parent === hashs[0] && !activeCards[a].deleted).sort((a, b) => {\n        if (activeCards[a].order\n            && String(activeCards[a].order.low)\n            && activeCards[b].order\n            && String(activeCards[b].order.low) &&\n            parseInt(activeCards[a].order.low) > parseInt(activeCards[b].order.low)\n        )\n            return 1\n        return -1\n    })\n    const cardsGuidelineE = Object.keys(activeCards).filter(a => activeCards[a].type === 'guidelineE' && activeCards[a]._parent === hashs[0] && !activeCards[a].deleted).sort((a, b) => {\n        if (activeCards[a].order\n            && String(activeCards[a].order.low)\n            && activeCards[b].order\n            && String(activeCards[b].order.low) &&\n            parseInt(activeCards[a].order.low) > parseInt(activeCards[b].order.low)\n        )\n            return 1\n        return -1\n    })\n    const cardsGuidelineD = Object.keys(activeCards).filter(a => activeCards[a].type === 'guidelineD' && activeCards[a]._parent === hashs[0] && !activeCards[a].deleted).sort((a, b) => {\n        if (activeCards[a].order\n            && String(activeCards[a].order.low)\n            && activeCards[b].order\n            && String(activeCards[b].order.low) &&\n            parseInt(activeCards[a].order.low) > parseInt(activeCards[b].order.low)\n        )\n            return 1\n        return -1\n    })\n\n    const backToMatrix = () => {\n        let cards = { ...reduxStore.getState().db.cards }\n\n        Object.keys(activeCards).map(a => {\n            if (activeCards[a] && activeCards[a]._selected) {\n                activeCards[a]._selected = false\n            }\n        })\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...cards,\n                ...activeCards\n            }\n        })\n    }\n\n    let actions\n    if (selectedGoal) {\n        actions = Object.keys(activeCards).filter(a => activeCards[a]._parent === selectedGoal && !activeCards[a].checklist)\n    } else if (selectedObjective) {\n        actions = Object.keys(activeCards).filter(a => activeCards[a]._parent === selectedObjective && !activeCards[a].checklist)\n    } else if (selectedGuideline) {\n        actions = Object.keys(activeCards).filter(a => activeCards[a]._parent === selectedGuideline && !activeCards[a].checklist)\n    }\n\n    let swotCards = Object.keys(activeCards).filter(a => activeCards[a]._parent === hashs[0])\n    const selectedCard = activeCards\n        && Object.keys(activeCards).filter(a => activeCards[a]\n            && activeCards[a]._selected && activeCards[a].type\n            && activeCards[a].type.indexOf('guideline') > -1)\n\n    return (\n        <div style={{\n            width: 'inherit'\n        }}>\n            {!selectedObjective &&\n                <React.Fragment>\n                    <Hidden smDown>\n                        <div\n                            style={{\n                                position: 'relative',\n                                float: 'left',\n                                width: 'calc(50% - 7px)',\n                                marginRight: '14px',\n                                padding: '7px',\n                                background: customApp('ColumnTitleColor'),\n                                color: customApp('colorText'),\n                                fontSize: '16px',\n                                fontWeight: 'bold',\n                                marginBottom: '15px',\n                                textAlign: 'center',\n                            }}>{translate('$__internalAspects', 1)}</div>\n                        <div\n                            style={{\n                                position: 'relative',\n                                float: 'left',\n                                width: 'calc(50% - 7px)',\n                                padding: '7px',\n                                background: customApp('ColumnTitleColor'),\n                                color: customApp('colorText'),\n                                fontSize: '16px',\n                                fontWeight: 'bold',\n                                marginBottom: '15px',\n                                textAlign: 'center',\n                            }}>{translate('$__externalAspects', 1)}</div>\n                    </Hidden>\n                    <Hidden smUp>\n                        <div\n                            style={{\n                                position: 'relative',\n                                float: 'left',\n                                width: 'calc(100% - 7px)',\n                                padding: '7px',\n                                background: customApp('ColumnTitleColor'),\n                                color: customApp('colorText'),\n                                fontSize: '16px',\n                                fontWeight: 'bold',\n                                marginBottom: '15px',\n                                textAlign: 'center',\n                            }}>{translate('$__s.W.O.T', '*')}</div>\n                    </Hidden>\n                    <Swot\n                        cards={swotCards.map(a => activeCards[a])}\n                        showSelected={Object.keys(activeCards).filter(card => activeCards[card]._selected === true).length > 0 ? true : false}\n                        lockColumns={\n                            selectedCard.length > 0 && activeCards[selectedCard[0]].type === 'guidelineD' ? ['strength', 'threat']\n                                : selectedCard.length > 0 && activeCards[selectedCard[0]].type === 'guidelineR' ? ['strength', 'opportunity']\n                                    : selectedCard.length > 0 && activeCards[selectedCard[0]].type === 'guidelineE' ? ['weakness', 'threat']\n                                        : selectedCard.length > 0 && activeCards[selectedCard[0]].type === 'guidelineC' ? ['weakness', 'opportunity']\n                                            : null\n                        }\n                        columnStyle={{\n                            minWidth: 'calc(25% - 14px)',\n                        }}\n                        showOrder={true}\n                        showSelected={Object.keys(activeCards).filter(card => activeCards[card]._selected === true).length > 0 ? true : false}\n                        inLineAdd={true}\n                    />\n                </React.Fragment>\n            }\n            <GridContainer >\n                <div\n                    style={{\n                        position: 'relative',\n                        float: 'left',\n                        width: 'calc(100% - 28px)',\n                        marginRight: '14px',\n                        marginLeft: '14px',\n                        padding: '7px',\n                        background: customApp('ColumnTitleColor'),\n                        color: customApp('colorText'),\n                        fontSize: '16px',\n                        fontWeight: 'bold',\n                        marginBottom: '15px',\n                        textAlign: 'center',\n                        display: \"flex\",\n                        alignItems: \"center\",\n                        justifyContent: \"center\"\n                    }}>\n                    <div style={{\n                        display: \"flex\",\n                        alignItems: \"center\",\n                        justifyContent: \"center\"\n                    }}>\n                        <Icon icon={MatrixIcon} color={customApp('textColor')} size={25} /><span style={{ marginLeft: 15 }}>{selectedGuideline ? translate('$__planning', 1) : 'MATRIX SWOT'}</span>\n                    </div>\n                </div>\n                {!selectedGuideline ?\n                    <GridItem md={12} >\n                        <GridContainer style={{ paddingBottom: '33px' }}>\n                            <GridItem md={3} sm={12} xs={12}>\n                                <HeaderWithIcon\n                                    title={translate('$__guidelineR', 1)}\n                                    icon={dataType.filter(a => a.name === 'guidelineR')[0].icon}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <div style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    padding: \"7px\",\n                                    minHeight: \"130px\",\n                                    backgroundColor: '#F9F9F9',\n                                    borderRadius: '0 0 7px 7px'\n                                }}>\n                                    <div\n                                        style={{\n                                            position: 'relative',\n                                            width: '100%',\n                                            color: customApp('menu'),\n                                            fontWeight: 'bold',\n                                            paddingBottom: '7px',\n                                            borderBottom: 'solid 1px #e4e4e4',\n                                            textAlign: 'center'\n                                        }}\n                                    >\n                                        {translate('$__guidelineRtypes', 1)}\n                                    </div>\n                                    <div\n                                        style={{\n                                            position: 'relative',\n                                            width: '100%',\n                                            color: customApp('medium'),\n                                            fontSize: '14px',\n                                            padding: '7px',\n                                            textAlign: 'center'\n                                        }}\n                                    >\n                                        {translate('$__guidelineRdetails', 1)}\n                                    </div>\n                                </div>\n                                <DragDropCards cards={cardsGuidelineR} cardType={'guidelineR'} />\n                            </GridItem>\n                            <GridItem md={3} sm={12} xs={12}>\n                                <HeaderWithIcon\n                                    title={translate('$__guidelineD', 1)}\n                                    icon={dataType.filter(a => a.name === 'guidelineD')[0].icon}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <div style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    padding: \"7px\",\n                                    minHeight: \"130px\",\n                                    backgroundColor: '#F9F9F9',\n                                    borderRadius: '0 0 7px 7px'\n                                }}>\n                                    <div\n                                        style={{\n                                            position: 'relative',\n                                            width: '100%',\n                                            color: customApp('menu'),\n                                            fontWeight: 'bold',\n                                            paddingBottom: '7px',\n                                            borderBottom: 'solid 1px #e4e4e4',\n                                            textAlign: 'center'\n                                        }}\n                                    >\n                                        {translate('$__guidelineDtypes', 1)}\n                                    </div>\n                                    <div\n                                        style={{\n                                            position: 'relative',\n                                            width: '100%',\n                                            color: customApp('medium'),\n                                            fontSize: '14px',\n                                            padding: '7px',\n                                            textAlign: 'center'\n                                        }}\n                                    >\n                                        {translate('$__guidelineDdetails', 1)}\n                                    </div>\n                                </div>\n                                <DragDropCards cards={cardsGuidelineD} cardType={'guidelineD'} />\n                            </GridItem>\n                            <GridItem md={3} sm={12} xs={12}>\n                                <HeaderWithIcon\n                                    title={translate('$__guidelineC', 1)}\n                                    icon={dataType.filter(a => a.name === 'guidelineC')[0].icon}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <div style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    padding: \"7px\",\n                                    minHeight: \"130px\",\n                                    backgroundColor: '#F9F9F9',\n                                    borderRadius: '0 0 7px 7px'\n                                }}>\n                                    <div\n                                        style={{\n                                            position: 'relative',\n                                            width: '100%',\n                                            color: customApp('menu'),\n                                            fontWeight: 'bold',\n                                            paddingBottom: '7px',\n                                            borderBottom: 'solid 1px #e4e4e4',\n                                            textAlign: 'center'\n                                        }}\n                                    >\n                                        {translate('$__guidelineCtypes', 1)}\n                                    </div>\n                                    <div\n                                        style={{\n                                            position: 'relative',\n                                            width: '100%',\n                                            color: customApp('medium'),\n                                            fontSize: '14px',\n                                            padding: '7px',\n                                            textAlign: 'center'\n                                        }}\n                                    >\n                                        {translate('$__guidelineCdetails', 1)}\n                                    </div>\n                                </div>\n                                <DragDropCards cards={cardsGuidelineC} cardType={'guidelineC'} />\n                            </GridItem>\n                            <GridItem md={3} sm={12} xs={12}>\n                                <HeaderWithIcon\n                                    title={translate('$__guidelineE', 1)}\n                                    icon={dataType.filter(a => a.name === 'guidelineE')[0].icon}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                <div style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    padding: \"7px\",\n                                    minHeight: \"130px\",\n                                    backgroundColor: '#F9F9F9',\n                                    borderRadius: '0 0 7px 7px'\n                                }}>\n                                    <div\n                                        style={{\n                                            position: 'relative',\n                                            width: '100%',\n                                            color: customApp('menu'),\n                                            fontWeight: 'bold',\n                                            paddingBottom: '7px',\n                                            borderBottom: 'solid 1px #e4e4e4',\n                                            textAlign: 'center'\n                                        }}\n                                    >\n                                        {translate('$__guidelineEtypes', 1)}\n                                    </div>\n                                    <div\n                                        style={{\n                                            position: 'relative',\n                                            width: '100%',\n                                            color: customApp('medium'),\n                                            fontSize: '14px',\n                                            padding: '7px',\n                                            textAlign: 'center'\n                                        }}\n                                    >\n                                        {translate('$__guidelineEdetails', 1)}\n                                    </div>\n                                </div>\n                                <DragDropCards cards={cardsGuidelineE} cardType={'guidelineE'} />\n                            </GridItem>\n                        </GridContainer>\n                    </GridItem>\n                    :\n                    <React.Fragment>\n                        <GridItem md={3} sm={12} xs={12}>\n                            <div>\n                                <HeaderWithIcon\n                                    title={'MATRIX SWOT'}\n                                    icon={dataType.filter(a => a.name === 'matrix')[0].icon}\n                                    color={customApp('colorText')}\n                                    style={{\n                                        background: customApp('ColumnTitleColor'),\n                                        padding: '7px'\n                                    }}\n                                />\n                                {props.hidePrivate && cards[selectedGuideline] && cards[selectedGuideline].private ?\n                                    <React.Fragment></React.Fragment>\n                                    :\n                                    <Card data={cards[selectedGuideline]} db='cards' selectOption expanded />\n                                }\n                                <IconButton icon={'undo'} text={translate(\"$__backToMatrix\", \"*\")}\n                                    onClick={() => {\n                                        backToMatrix('guideline')\n                                    }} />\n                            </div>\n                            {selectedObjective &&\n                                <div>\n                                    <HeaderWithIcon\n                                        title={translate('$__objective', 1)}\n                                        icon={dataType.filter(a => a.name === 'objective')[0].icon}\n                                        color={customApp('colorText')}\n                                        style={{\n                                            background: customApp('ColumnTitleColor'),\n                                            padding: '7px'\n                                        }}\n\n                                    />\n                                    {props.hidePrivate && cards[selectedObjective] && cards[selectedObjective].private ?\n                                        <React.Fragment></React.Fragment>\n                                        :\n                                        <Card data={cards[selectedObjective]} db='cards' selectOption expanded />\n                                    }\n\n                                </div>\n                            }\n                            {selectedGoal &&\n                                <div>\n                                    <HeaderWithIcon\n                                        title={translate('$__goal', 1)}\n                                        icon={dataType.filter(a => a.name === 'goal')[0].icon}\n                                        color={customApp('colorText')}\n                                        style={{\n                                            background: customApp('ColumnTitleColor'),\n                                            padding: '7px'\n                                        }}\n                                        customButtons={[\n                                            {\n                                                title: \"$__new\",\n                                                icon: \"add_box\",\n                                                color: customApp('menu'),\n                                                onClick: () => {\n                                                    props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                        ...reduxStore.getState().sideModule,\n                                                        id: 'new',\n                                                        activeModule: dataType.filter(a => a.name === 'goal')[0].iniModule,\n                                                        db: 'cards',\n                                                        data: {\n                                                            type: 'goal',\n                                                            _parent: selectedObjective,\n                                                            status: 'notStarted'\n                                                        }\n                                                    })\n                                                },\n                                            }\n                                        ]}\n                                    />\n                                    {props.hidePrivate && cards[selectedGoal] && cards[selectedGoal].private ?\n                                        <React.Fragment></React.Fragment>\n                                        :\n                                        <Card data={cards[selectedGoal]} db='cards' selectOption expanded />\n                                    }\n                                </div>\n                            }\n                        </GridItem>\n                        <GridItem md={9} sm={12} xs={12}>\n                            <HeaderWithIcon\n                                title={\n                                    selectedObjective && !selectedGoal ?\n                                        translate('$__goals', 1)\n                                        : !selectedObjective ?\n                                            translate('$__objectives', 1)\n                                            : translate('$__actions', 1)\n                                }\n                                icon={\n                                    selectedObjective && !selectedGoal ?\n                                        dataType.filter(a => a.name === 'goal')[0].icon\n                                        : !selectedObjective ?\n                                            dataType.filter(a => a.name === 'objective')[0].icon\n                                            : 'view_column'\n                                }\n                                color={customApp('colorText')}\n                                style={{\n                                    background: customApp('ColumnTitleColor'),\n                                    padding: '7px'\n                                }}\n                                actionButtonsStyle={{\n                                    position: \"absolute\",\n                                    top: 0,\n                                    bottom: 0,\n                                    display: \"flex\",\n                                    itemAligns: \"center\"\n                                }}\n                                customButtons={[\n                                    selectedGoal ? {\n                                        component: (\n                                            <DialogButtons\n                                                iconColor={customApp(\"color\")}\n                                                options={\n                                                    dataType.filter(a => a.module === 'agile').map(a => (\n                                                        {\n                                                            icon: a.icon,\n                                                            name: translate(`$__${a.name}`, 1),\n                                                            onClick: () => (\n                                                                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                                    ...reduxStore.getState().sideModule,\n                                                                    id: 'new',\n                                                                    db: 'cards',\n                                                                    data: {\n                                                                        type: a.name,\n                                                                        _parent: selectedGoal,\n                                                                        status: 'notStarted'\n                                                                    }\n                                                                })\n                                                            )\n                                                        }\n                                                    )\n                                                    )\n                                                } />\n                                        )\n                                    } :\n                                        {\n                                            title: \"$__new\",\n                                            icon: \"add_box\",\n                                            color: customApp('color'),\n                                            actionsSize: \"22px\",\n                                            show: true,\n                                            onClick: () => {\n                                                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                    ...reduxStore.getState().sideModule,\n                                                    id: 'new',\n                                                    activeModule: dataType.filter(a => a.name === 'objective')[0].iniModule,\n                                                    db: 'cards',\n                                                    data: selectedObjective ? {\n                                                        type: 'goal',\n                                                        _parent: selectedObjective,\n                                                        status: 'notStarted'\n                                                    } : {\n                                                        type: 'objective',\n                                                        _parent: selectedGuideline,\n                                                        status: 'notStarted'\n                                                    }\n                                                })\n                                            },\n                                        }\n                                ]}\n                            />\n                            <AgileStatus cards={actions.map(a => activeCards[a])} viewButton />\n                        </GridItem>\n                    </React.Fragment>\n                }\n            </GridContainer>\n        </div>\n\n    )\n\n}\nconst mapStateToProps = (store, props) => ({\n    store,\n    hidePrivate: store.controls.hidePrivate,\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","import React from \"react\";\nimport { DragDropContext, Droppable } from \"react-beautiful-dnd\";\nimport styled from \"styled-components\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\n\n//COMPONENTS\nimport HeaderWithIcon from \"components/Header/card\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Card from \"components/Card\";\nimport Icon from \"components/Icon\";\n\n\n//@MATERIAL\nimport Dialog from \"@material-ui/core/Dialog\";\nimport Button from '@material-ui/core/Button';\n\n//DEPENDENCIES\nimport Column from \"./Column\";\n\n//FUNCTIONS\nimport { linkCard, updateCard, getChildrens } from \"functions/cards\";\nimport { translate, appAlert, customApp } from \"functions\";\nimport { countNotifications } from \"functions/cards\"\n\n\nfunction App(props) {\n    const { db, session } = reduxStore.getState()\n    const { dataType } = db\n    const [Migrator, setMigrator] = React.useState(false)\n    const [MigratorData, setMigratorData] = React.useState({})\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n    if (hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n\n    let activeCards = {}\n\n    Object.keys(db.cards).filter(a => {\n        let notifications = countNotifications(a)\n        if (db.cards[a]\n            && (\n                !db.cards[a].private\n                || (\n                    db.cards[a].private\n                    && db.cards[a]._users[session._id]\n                )\n            )\n            && (\n                db.cards[a]._planId === hashs[0]\n                || db.cards[a]._parent === hashs[0]\n            )\n            && (\n                props.showCompleted\n                ||\n                (\n                    !props.showCompleted\n                    && db.cards[a].status !== \"completed\"\n                )\n            )\n            && (\n                !props.onlyUnReaded\n                || (\n                    props.onlyUnReaded\n                    && notifications.total > 0\n                )\n            ))\n            return true\n\n    }).map(a => {\n        activeCards = {\n            ...activeCards,\n            [a]: db.cards[a]\n        }\n    })\n\n    const selectedGuideline = Object.keys(activeCards).filter(a => activeCards[a] && activeCards[a].type && activeCards[a]._selected === true && activeCards[a].type.indexOf('guideline') > -1).length > 0 ? Object.keys(activeCards).filter(a => activeCards[a] && activeCards[a].type && activeCards[a]._selected === true && activeCards[a].type.indexOf('guideline') > -1)[0] : null\n    const selectedObjective = Object.keys(activeCards).filter(a => activeCards[a] && activeCards[a]._selected === true && activeCards[a].type === 'objective').length > 0 ? Object.keys(activeCards).filter(a => activeCards[a] && activeCards[a]._selected === true && activeCards[a].type === 'objective')[0] : null\n    const selectedGoal = Object.keys(activeCards).filter(a => activeCards[a]._selected === true && activeCards[a].type === 'goal').length > 0 ? Object.keys(activeCards).filter(a => activeCards[a]._selected === true && activeCards[a].type === 'goal')[0] : null\n\n    const overview = [\n        { value: 'guidelines', type: 'guideline', label: '$__guidelines', icon: 'alt_route', viewButton: true, selectedParent: null },\n        { value: 'objectives', type: 'objective', label: '$__objectives', icon: dataType.filter(a => a.name === 'objective')[0].icon, viewButton: true, selectedParent: selectedGuideline },\n        { value: 'goals', type: 'goal', label: '$__goals', icon: dataType.filter(a => a.name === 'goal')[0].icon, viewButton: true, selectedParent: selectedObjective || selectedGuideline },\n        { value: 'actions', type: 'iniciative', label: '$__actions', icon: 'double_arrow', selectedParent: selectedGoal || selectedObjective || selectedGuideline }\n    ]\n\n    let cards = {}\n\n    cards['guidelines'] = Object.keys(activeCards).filter(a =>\n        (\n            activeCards[a]._parent === hashs[0]\n            || activeCards[a]._planId === hashs[0]\n        )\n        && activeCards[a].type && activeCards[a].type.indexOf('guideline') > -1\n    ) || null\n\n\n    cards['objectives'] = Object.keys(activeCards).filter(a =>\n        activeCards[a].type\n        && activeCards[a].type === 'objective'\n        && (\n            (\n                cards['guidelines'].indexOf(activeCards[a]._parent) > -1\n                ||\n                (\n                    !selectedGuideline\n                    && activeCards[a]._planId === hashs[0]\n                )\n            )\n        )\n    ) || null\n\n    cards['objectives'] = Object.keys(activeCards).filter(a =>\n        activeCards[a].type === 'objective'\n        && !activeCards[a].checklist\n        &&\n        (\n            (\n                selectedGuideline\n                && activeCards[a]._parent === selectedGuideline\n            )\n            ||\n            (\n                !selectedGuideline\n                && activeCards[a]._planId === hashs[0]\n            )\n        )\n    )\n    cards['objectives2'] = Object.keys(activeCards).filter(a => {\n        if (activeCards[a].type === 'objective'\n            && activeCards[a]._parent !== selectedGuideline\n            && !activeCards[a].checklist\n            && cards['objectives'].indexOf(activeCards[a]._parent) > -1)\n            return true\n    }\n    )\n\n    cards['objectives2'].map(a => {\n        if (cards['objectives'].indexOf(a) === -1)\n            cards['objectives'].push(a)\n    })\n\n    cards['goals'] = Object.keys(activeCards).filter(a =>\n        activeCards[a].type\n        && activeCards[a].type === 'goal'\n        &&\n        (\n            (\n                !selectedObjective\n                && cards['objectives'].indexOf(activeCards[a]._parent) > -1\n            )\n            ||\n            (\n                selectedObjective\n                && activeCards[a]._parent === selectedObjective\n            )\n            ||\n            (\n                !selectedObjective\n                && selectedGuideline\n                && activeCards[a]._parent === selectedGuideline\n\n            )\n            ||\n            (\n                !selectedGuideline\n                && !selectedObjective\n                && activeCards[a]._planId === hashs[0]\n            )\n        )\n    ) || null\n\n    cards['goals2'] = Object.keys(activeCards).filter(a =>\n        activeCards[a].type === 'goal'\n        && !activeCards[a].checklist\n        && cards['goals'].indexOf(activeCards[a]._parent) > -1\n    )\n    cards['goals2'].map(a => {\n        if (cards['goals'].indexOf(a) === -1)\n            cards['goals'].push(a)\n    })\n\n    cards['actions'] = Object.keys(activeCards).filter(a => (\n        activeCards[a].type\n        && !activeCards[a].checklist\n        && activeCards[a].type !== 'plan'\n        && activeCards[a].type !== 'objective'\n        && activeCards[a].type !== 'goal'\n        && activeCards[a].type !== 'feed'\n        && activeCards[a].type !== 'link'\n        && activeCards[a].type !== 'insight'\n        && activeCards[a].type !== 'link'\n        && activeCards[a].type !== 'chatGroup'\n        && activeCards[a].type.indexOf('guideline') === -1\n        && dataType.filter(dt => dt.name === activeCards[a].type).length > 0\n        && dataType.filter(dt => dt.name === activeCards[a].type)[0].module !== 'swot')\n        && (\n            (\n                (\n                    selectedGoal\n                    && activeCards[a]._parent === selectedGoal\n                )\n                ||\n                (\n                    !selectedGoal\n                    && selectedObjective\n                    &&\n                    (\n                        activeCards[a]._parent === selectedObjective\n                        || cards['goals'].indexOf(activeCards[a]._parent) > -1\n                    )\n                )\n                ||\n                (\n                    !selectedGoal\n                    && !selectedObjective\n                    && selectedGuideline\n                    &&\n                    (\n                        activeCards[a]._parent === selectedGuideline\n                        || cards['objectives'].indexOf(activeCards[a]._parent) > -1\n                        || cards['goals'].indexOf(activeCards[a]._parent) > -1\n                    )\n                )\n                || (\n                    !selectedGoal\n                    && !selectedObjective\n                    && !selectedGuideline\n                    &&\n                    (\n                        (!selectedGuideline && cards['guidelines'].indexOf(activeCards[a]._parent) > -1)\n                        || (!selectedObjective && cards['objectives'].indexOf(activeCards[a]._parent) > -1)\n                        || (!selectedGoal && cards['goals'].indexOf(activeCards[a]._parent) > -1)\n                    )\n                )\n                ||\n                (\n                    !selectedGoal\n                    && !selectedObjective\n                    && !selectedGuideline\n                    &&\n                    (\n                        !selectedGuideline\n                        && !selectedObjective\n                        && !selectedGoal\n                        && activeCards[a]._planId === hashs[0]\n                    )\n                )\n            )\n        )\n    ) || null\n\n\n    cards['guidelines'] = cards['guidelines'].map(a => activeCards[a])\n    cards['objectives'] = cards['objectives'].map(a => activeCards[a])\n    cards['goals'] = cards['goals'].map(a => activeCards[a])\n    cards['actions'] = cards['actions'].map(a => activeCards[a])\n\n\n\n    const onDragEnd = async result => {\n        const { destination, source, draggableId } = result\n        let newCardsOrder = db.cards\n        if (result.combine) {\n            appAlert({\n                message: `${translate(\"$__confirmLink\", 1)}: ${reduxStore.getState().db.cards[draggableId].name} >>> ${reduxStore.getState().db.cards[result.combine.draggableId] ? reduxStore.getState().db.cards[result.combine.draggableId].name : \"\"}`,\n                variant: \"warning\",\n                persist: true,\n                horizontal: \"right\",\n                confirm: () => {\n                    linkCard(props, {\n                        cardId: draggableId,\n                        cardToLink: result.combine.draggableId\n                    })\n                }\n            })\n\n            return;\n        }\n\n        if (!destination) return false\n\n\n\n        if (destination.droppableId === source.droppableId && destination.id === source.index) return false\n\n        const sourceColumn = source.droppableId\n        const destinationColumn = destination.droppableId\n\n        const sourceCardIds = Array.from(Object.keys(activeCards).filter(c => activeCards[c].status === sourceColumn).sort((a, b) => {\n            if (activeCards[a].order && activeCards[b].order && String(activeCards[a].order.low) && String(activeCards[b].order.low) && parseInt(activeCards[a].order.low) < parseInt(activeCards[b].order.low))\n                return -1\n            return 1\n        }\n        ).map(a => a._id))\n\n        //When move Card in single Column\n\n        if (sourceColumn === destinationColumn && reduxStore.getState().db.orderByTitle) {\n            return\n        }\n\n        if (sourceColumn === destinationColumn && !reduxStore.getState().db.orderByTitle) {\n            const { socket } = reduxStore.getState().functions\n\n            let columnName = sourceColumn === 'iniciative' ? 'action' : sourceColumn\n\n            let itemOrderIds = Array.from(\n                cards[`${columnName}s`]\n                    .filter(card => card.status && card.status !== \"completed\")\n                    .sort((a, b) => {\n                        let orderA = a?.order?.low || !isNaN(a?.order) ? parseInt(a.order) : a.order ? parseInt(a.order) : 0\n                        let orderB = b?.order?.low || !isNaN(b?.order) ? parseInt(b.order) : b.order ? parseInt(b.order) : 0\n\n                        if (orderA < orderB)\n                            return -1\n                        if (orderA > orderB)\n                            return 1\n                        return 0\n                    })\n                    .map(card => card._id)\n            )\n\n            itemOrderIds.splice(source.index, 1)\n            await setTimeout(500)\n\n            itemOrderIds.splice(destination.index, 0, draggableId)\n            await setTimeout(500)\n\n\n            socket.emit(\"data\", {\n                module: \"cards\",\n                method: \"put\",\n                action: \"reorder\"\n            }, {\n                cards: itemOrderIds\n            })\n\n            let newCards = {\n                ...reduxStore.getState().db.cards\n            }\n\n            let reorderAwait = await new Promise((resolve, reject) => {\n                itemOrderIds.map((a, i) => {\n                    newCards = {\n                        ...newCards,\n                        [a]: {\n                            ...newCards[a],\n                            order: `${i + 1}`\n                        }\n                    }\n                    if (i + 1 === itemOrderIds.length)\n                        resolve(true)\n                })\n            })\n            if (reorderAwait)\n                props.reduxFunction(\"IMMEDIATE\", \"SET_DB\", {\n                    ...reduxStore.getState().db,\n                    cards: {\n                        ...reduxStore.getState().db.cards,\n                        ...newCards\n                    }\n                })\n            return\n        }\n\n        //When move Card in mult Column\n        sourceCardIds.splice(source.index, 1)\n\n        const destinationCardIds = Array.from(Object.keys(activeCards).filter(c => c.status === destinationColumn).sort((a, b) => {\n            if (activeCards[a].order && activeCards[b].order && String(activeCards[a].order.low) && String(activeCards[b].order.low) && parseInt(activeCards[a].order.low) < parseInt(activeCards[b].order.low))\n                return -1\n            return 1\n        }\n        ).map(a => a._id))\n        destinationCardIds.splice(destination.index, 0, draggableId)\n\n        sourceCardIds.map((a, i) => {\n            if (!db.cards[a].order || !db.cards[a].order.low) {\n                db.cards[a] = {\n                    ...db.cards[a],\n                    ['order']: {\n                        ['low']: parseInt(i)\n                    }\n                }\n            } else {\n                db.cards[a].order.low = parseInt(i)\n            }\n        })\n\n        destinationCardIds.map((a, i) => {\n            if (!db.cards[a].order || !db.cards[a].order.low) {\n                db.cards[a] = {\n                    ...db.cards[a],\n                    ['order']: {\n                        ['low']: parseInt(i)\n                    }\n                }\n            } else {\n                db.cards[a].order.low = parseInt(i)\n            }\n        })\n\n        let childrens = getChildrens(draggableId)\n        let data = {\n            _id: draggableId,\n            type: destination.droppableId,\n            _childrens: childrens,\n            _objectives: cards['objectives'].filter(fil => childrens[fil._id]).map(a => a),\n            _goals: cards['goals'].filter(fil => childrens[fil._id]).map(a => a)\n        }\n\n        if (db.cards[draggableId].type === \"goal\" && destination.droppableId === \"guideline\") {\n            appAlert({\n                message: translate('$__YouCannotMoveThisItemToThisColumnMoveFirstToTheObjectiveColumn', 1),\n                variant: 'error',\n                persist: false,\n                horizontal: 'center',\n            })\n            setMigratorData({})\n            return\n        }\n        if (\n            db.cards[draggableId].type.indexOf(\"guideline\") === -1\n            && db.cards[draggableId].type !== \"objective\"\n            && db.cards[draggableId].type !== \"goal\"\n            && (\n                destination.droppableId === \"guideline\"\n                || destination.droppableId === \"objective\"\n            )\n        ) {\n            appAlert({\n                message: translate('$__YouCannotMoveThisItemToThisColumnMoveFirstToTheGoalsColumn', 1),\n                variant: 'error',\n                persist: false,\n                horizontal: 'center',\n            })\n            setMigratorData({})\n            return\n        }\n\n\n        if (db.cards[draggableId].type.indexOf('guideline') > -1 && db.cards[draggableId].type !== 'guideline') {\n            appAlert({\n                message: translate('$__youCantMoveGuidelineWithSwotLinked', 1),\n                variant: 'error',\n                persist: false,\n                horizontal: 'center',\n            })\n        } else if (\n            db.cards[draggableId].type === 'guideline'\n            &&\n            (\n                destination.droppableId !== 'guideline'\n            )\n            && (\n                cards['objectives'].filter(fil => fil._parent === draggableId).length > 0\n                || cards['goals'].filter(fil => fil._parent === draggableId).length > 0\n            )\n        ) {\n            setMigratorData(data)\n            setMigrator(true)\n        } else if (\n            db.cards[draggableId].type.indexOf('objective') > -1\n            &&\n            (\n                destination.droppableId !== 'guideline'\n                && destination.droppableId !== 'objective'\n            )\n            && (\n                cards['goals'].filter(fil => fil._parent === draggableId).length > 0\n            )\n        ) {\n            setMigratorData(data)\n            setMigrator(true)\n        } else {\n            appAlert({\n                message: `${translate(\"$__confirmTransformIn\", 1)}: ${translate(`$__${destination.droppableId}`)}`,\n                variant: \"warning\",\n                persist: true,\n                horizontal: \"right\",\n                confirm: () => {\n                    updateType(data)\n                    if (db.cards[db.cards[draggableId]._parent].type.indexOf(destination.droppableId) > -1)\n                        linkCard(props, {\n                            cardId: draggableId,\n                            cardToLink: db.cards[db.cards[draggableId]._parent]._parent\n                        })\n                },\n                cancel: () => {\n                    setMigratorData({})\n                }\n            })\n\n        }\n    }\n\n    const updateType = async (d) => {\n        let data = d\n        if (MigratorData && MigratorData._id)\n            data = MigratorData\n\n        await updateCard(props, data)\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [data._id]: {\n                    ...reduxStore.getState().db.cards[data._id],\n                    type: data.type,\n                },\n            }\n        });\n\n        setMigratorData({})\n    }\n\n    const iniMigration = async (type) => {\n        let MCards = type === 'goals' ? MigratorData._goals : MigratorData._objectives\n        cards[type]\n            .filter(fil => MigratorData._childrens[fil._id]).map(async (a, i) => {\n                MCards.filter(c => c._id === a._id).map(a => {\n                    a.type = type === 'goals' ? 'task' : 'goal'\n                })\n\n                await updateCard(props, {\n                    _id: a._id,\n                    type: type === 'goals' ? 'task' : 'goal'\n                })\n            })\n\n        setMigratorData({\n            ...MigratorData,\n            ...type === 'goals' ? { _goals: MCards } : { _objectives: MCards }\n        })\n    }\n    const finishMigration = async () => {\n        await updateCard(props, {\n            _id: MigratorData._id,\n            type: MigratorData.type\n        })\n        setMigrator(false)\n        setMigratorData({})\n    }\n\n    return (\n        <div>\n            <DragDropContext\n                onDragEnd={onDragEnd}\n            // onDragStart={onDragStart}\n            // onDragUpdate={onDragUpdate}\n            >\n                <Droppable\n                    droppableId=\"ALL-COLUMNS-TYPE\"\n                    type=\"column\"\n                    direction={`${props.inLine ? 'vertical' : 'horizontal'}`}\n                    isDropDisabled={true}\n                >\n                    {provided => (\n                        <Container\n                            {...props}\n                            ref={provided.innerRef}\n                        >\n                            {overview.map((st, index) => {\n                                const theColumn = {\n                                    name: st.label,\n                                    icon: st.icon,\n                                    cards: [],\n                                    emptyHide: false,\n                                }\n                                return <Column\n                                    {...props}\n                                    key={st.value}\n                                    columnId={st.type}\n                                    isDropDisabled\n                                    column={theColumn}\n                                    cards={\n                                        cards\n                                            && cards[st.value]\n                                            ? cards[st.value]\n                                            : []\n                                    }\n                                    index={index}\n                                    columnsSettings={false}\n                                    locked={false}\n                                    columnStyle={{\n                                        minWidth: '200px'\n                                    }}\n                                    viewButton={st.viewButton}\n                                    isCombineEnabled\n                                    inLineAdd\n                                    selectedParent={st.selectedParent}\n                                    cardColorPicker={props.showColors ? true : false}\n                                />\n                            })}\n                            {provided.placeholder}\n                        </Container>\n                    )}\n                </Droppable>\n            </DragDropContext>\n            <Dialog\n                fullWidth={true}\n                aria-labelledby=\"simple-dialog-title\"\n                open={Migrator}\n            >\n                <div style={{ position: \"relative\", marginLeft: \"10px\", marginTop: '5px', width: \"calc(100% - 10px)\" }}>\n                    <HeaderWithIcon\n                        title={translate(\"$__attention\", 1)}\n                        icon=\"label\"\n                        onCancel={() => {\n                            setMigrator(false)\n                            setMigratorData({})\n                        }}\n                    />\n                </div>\n                <div style={{ color: \"#CCCCCC\", padding: \"15px\" }}>\n                    {\n                        MigratorData._childrens\n                        && !MigratorData._skipGoals\n                        && MigratorData._goals.length > 0\n                        && MigratorData._goals.filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type).length > 0\n                        &&\n                        <React.Fragment>\n                            <span style={{ color: 'gray' }}>{translate(`$__YouHaveLinkedGoals`)}\n                                <p style={{ color: 'red' }}>{translate(`$__ThisActionCanOnlyBeUndoneManually`)}</p>\n                            </span>\n                            {MigratorData._goals\n                                .filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type)\n                                .sort((a, b) => {\n                                    if (reduxStore.getState().db.orderByTitle\n                                        && reduxStore.getState().db.orderByTitlePosition === 'ASC'\n                                        && a.name.toLowerCase().trim() < b.name.toLowerCase().trim()\n                                    ) {\n                                        return -1\n                                    } else if (reduxStore.getState().db.orderByTitle\n                                        && reduxStore.getState().db.orderByTitlePosition === 'DESC'\n                                        && a.name.toLowerCase().trim() > b.name.toLowerCase().trim()\n                                    ) {\n                                        return -1\n                                    } else if (reduxStore.getState().db.orderByTitle) {\n                                        return 0\n                                    } else if (!reduxStore.getState().db.orderByTitle && String(a.order) && String(b.order) && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low)) {\n                                        return -1\n                                    } else {\n                                        return 1\n                                    }\n                                }\n                                ).map((a, i) =>\n                                    <div style={{ width: 'calc(100%)', display: \"flex\", alignItems: \"center\", justifyContent: \"center\" }} key={a._id}>\n                                        <Card db=\"cards\" data={a} noShadow />\n                                        <Button\n                                            onClick={() => {\n                                                updateCard(props, {\n                                                    _id: a._id,\n                                                    type: 'task'\n                                                })\n                                            }}\n                                        >\n                                            <Icon\n                                                icon=\"change_circle\"\n                                                color={customApp('menu')}\n                                                title={translate('$__transformInTask')}\n                                            />\n                                        </Button>\n                                    </div>\n                                )\n                            }\n                            <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\", padding: \"15px\" }}>\n                                <CustomButton\n                                    shadow\n                                    title={translate(\"$__skipAll\")}\n                                    text={translate(\"$__skipAll\")}\n                                    color=\"lightgrey\"\n                                    icon={\"skip_next\"}\n                                    size={\"25px\"}\n                                    onClick={() => {\n                                        setMigratorData({\n                                            ...MigratorData,\n                                            _skipGoals: true\n                                        })\n                                    }}\n                                />\n                                <div style={{ marginLeft: \"15px\" }}>\n                                    <CustomButton\n                                        shadow\n                                        title={translate(\"$__changeAllInTasks\")}\n                                        text={translate(\"$__changeAllInTasks\")}\n                                        icon={\"change_circle\"}\n                                        size={\"25px\"}\n                                        onClick={() => {\n                                            iniMigration('goals')\n                                            setMigratorData({\n                                                ...MigratorData,\n                                                _skipGoals: true\n                                            })\n                                        }}\n                                    />\n                                </div>\n                            </div>\n                        </React.Fragment>\n                    }\n                    {\n                        MigratorData._childrens\n                        && !MigratorData._skipObjectives\n                        && MigratorData._objectives.length > 0\n                        && MigratorData._objectives\n                            .filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type).length > 0\n                        &&\n                        <React.Fragment>\n                            <span style={{ color: 'gray' }}>{translate(`$__YouHaveLinkedObjectives`)}\n                                <p style={{ color: 'red' }}>{translate(`$__ThisActionCanOnlyBeUndoneManually`)}</p>\n                            </span>\n                            {MigratorData._objectives\n                                .filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type)\n                                .sort((a, b) => {\n                                    if (reduxStore.getState().db.orderByTitle\n                                        && reduxStore.getState().db.orderByTitlePosition === 'ASC'\n                                        && a.name.toLowerCase().trim() < b.name.toLowerCase().trim()\n                                    ) {\n                                        return -1\n                                    } else if (reduxStore.getState().db.orderByTitle\n                                        && reduxStore.getState().db.orderByTitlePosition === 'DESC'\n                                        && a.name.toLowerCase().trim() > b.name.toLowerCase().trim()\n                                    ) {\n                                        return -1\n                                    } else if (reduxStore.getState().db.orderByTitle) {\n                                        return 0\n                                    } else if (!reduxStore.getState().db.orderByTitle && String(a.order) && String(b.order) && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low)) {\n                                        return -1\n                                    } else {\n                                        return 1\n                                    }\n                                }\n                                ).map((a, i) =>\n                                    <div style={{ width: 'calc(100%)', display: \"flex\", alignItems: \"center\", justifyContent: \"center\" }} key={a._id}>\n                                        <Card db=\"cards\" data={a} noShadow />\n                                        <Button\n                                            onClick={() => {\n                                                updateCard(props, {\n                                                    _id: a._id,\n                                                    type: 'goal'\n                                                })\n                                            }}\n                                        >\n                                            <Icon\n                                                icon=\"change_circle\"\n                                                color={customApp('menu')}\n                                                title={translate('$__transformInGoal')}\n                                            />\n                                        </Button>\n                                    </div>\n                                )\n                            }\n                            <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\", padding: \"15px\" }}>\n                                <CustomButton\n                                    shadow\n                                    title={translate(\"$__skipAll\")}\n                                    text={translate(\"$__skipAll\")}\n                                    color=\"lightgrey\"\n                                    icon={\"skip_next\"}\n                                    size={\"25px\"}\n                                    onClick={() => {\n                                        setMigratorData({\n                                            ...MigratorData,\n                                            _skipObjectives: true\n                                        })\n                                    }}\n                                />\n                                <div style={{ marginLeft: \"15px\" }}>\n                                    <CustomButton\n                                        shadow\n                                        title={translate(\"$__changeAllInGoal\")}\n                                        text={translate(\"$__changeAllInGoal\")}\n                                        icon={\"change_circle\"}\n                                        size={\"25px\"}\n                                        onClick={() => {\n                                            iniMigration('objectives')\n                                            setMigratorData({\n                                                ...MigratorData,\n                                                _skipObjectives: true\n                                            })\n                                        }}\n                                    />\n                                </div>\n                            </div>\n                            <div style={{ marginLeft: \"15px\" }}>\n                                <CustomButton\n                                    shadow\n                                    title={translate(\"$__cancel\")}\n                                    text={translate(\"$__cancel\")}\n                                    icon={\"cancel\"}\n                                    size={\"25px\"}\n                                    onClick={() => {\n                                        setMigrator(false)\n                                        setMigratorData({})\n                                    }}\n                                />\n                            </div>\n                        </React.Fragment>\n                    }\n                    {(\n                        (\n                            MigratorData\n                            && MigratorData._childrens\n                            && Object.keys(MigratorData._childrens).length > 0\n                            && MigratorData._goals.filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type).length === 0\n                            && MigratorData._objectives.filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type).length === 0\n                        )\n                        || (\n                            (\n                                (\n                                    MigratorData._skipGoals\n                                    && MigratorData._goals.length > 0\n                                )\n                                ||\n                                (\n                                    MigratorData\n                                    && MigratorData._goals\n                                    && MigratorData._goals.length === 0\n                                )\n                            )\n                            &&\n                            (\n                                (\n                                    MigratorData._skipObjectives\n                                    && MigratorData._objectives.length > 0\n                                )\n                                ||\n                                (\n                                    MigratorData\n                                    && MigratorData._objectives\n                                    && MigratorData._objectives.length === 0\n                                )\n                            )\n                        )\n                    )\n                        &&\n                        <React.Fragment>\n                            <span style={{ color: 'red' }}>{translate(\"$__clickInSaveToFinishMigration\")}</span>\n                            <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\", padding: \"15px\" }}>\n                                <CustomButton\n                                    shadow\n                                    title={translate(\"$__cancel\")}\n                                    text={translate(\"$__cancel\")}\n                                    color=\"lightgrey\"\n                                    icon={\"close\"}\n                                    size={\"25px\"}\n                                    onClick={() => {\n                                        setMigrator(false)\n                                        setMigratorData({})\n                                    }}\n                                />\n                                <div style={{ marginLeft: \"15px\" }}>\n                                    <CustomButton\n                                        shadow\n                                        title={translate(\"$__save\")}\n                                        text={translate(\"$__save\")}\n                                        icon={\"done_all\"}\n                                        size={\"25px\"}\n                                        onClick={() => {\n                                            finishMigration()\n                                        }}\n                                    />\n                                </div>\n                            </div>\n                        </React.Fragment>\n                    }\n                </div>\n            </Dialog>\n        </div>\n    )\n}\n\n//STYLEDS\nconst Container = styled.div`\nposition:absolute;\nheight:100%;\n${props =>\n        !props.inLine && props.styles && props.styles.discountHeight && `height:calc(100vh - ${props.styles.discountHeight}px);`\n    }\n${props =>\n        props.inLine ?\n            `display: block;\n                width: -webkit-fill-available;\n                ${props.style}`\n            :\n            `   display: flex;\n                width: 100%;\n                ${props.style}\n                @media(min-width: 960px) {\n                    display: flex;\n                }\n                `\n    }\n    @media(max-width: 959px) {\n        display: contents !important;\n        width: -webkit-fill-available;\n        height:auto;\n      }\n    `\n\n//REACT\nconst mapStateToProps = (store, props) => {\n    return ({\n        cards: store.db.cards\n    })\n}\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(App);","import React from \"react\";\nimport PropTypes from \"prop-types\"\nimport Routes from \"routes\"\nimport moment from \"moment-timezone\"\nimport DataPicker from \"components/DataPicker\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Autocomplete from \"components/AutoComplete/multiple\";\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\";\nimport Checkbox from 'components/Checkbox';\nimport Icon from \"components/Icon\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport TextField from \"components/TextField/\";\nimport UserBadge from \"components/Badge/user\";\n\n//@MATERIAL\nimport Accordion from '@material-ui/core/Accordion';\nimport AccordionDetails from '@material-ui/core/AccordionDetails';\nimport AccordionSummary from '@material-ui/core/AccordionSummary';\nimport Avatar from \"@material-ui/core/Avatar\";\nimport Badge from '@material-ui/core/Badge';\nimport FormControlLabel from '@material-ui/core/FormControlLabel';\nimport FormGroup from '@material-ui/core/FormGroup';\nimport InputAdornment from '@material-ui/core/InputAdornment';\nimport Tooltip from \"@material-ui/core/Tooltip\";\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//IMAGES\nimport defaultAvatar from \"assets/img/fundo-sonne.png\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/filter.js\";\nimport \"assets/css/components/react-datepicker.css\";\n\n//FUNCTIONS\nimport { customApp, translate, appAlert } from \"functions/\";\n\nconst useStyles = makeStyles(styles);\nfunction FilterComponent(props) {\n    const classes = useStyles();\n    const {\n        usersStatus,\n        db,\n        search,\n        session,\n    } = reduxStore.getState();\n    const [viewSearch, setviewSearch] = React.useState(false);\n    const [findNameUser, setFindNameUser] = React.useState(\"\")\n    const [findNameClient, setFindNameClient] = React.useState(\"\")\n    const [findNamePlan, setFindNamePlan] = React.useState(\"\")\n\n    let fields = []\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace('#', '')\n    if (hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n\n    const locationPathName = window.location.pathname.split('/')\n    const pathName = `/${locationPathName[1]}`\n\n    let CardAccess = 1\n    if (hashs[0]) {\n        let data = db.cards[hashs[0]] || {}\n        CardAccess = data && data._users && Object.keys(data._users).length > 0 ? data._users[Object.keys(data._users).find(a => a.indexOf(session._id) > -1)] : 0\n        if (CardAccess && CardAccess.access)\n            CardAccess = CardAccess.access\n    }\n\n    const selectUser = (pr) => {\n        if (reduxStore.getState().search.users.selected[pr] && Object.keys(reduxStore.getState().search.users.selected).filter(a => reduxStore.getState().search.users.selected[a]).length <= 1) {\n            props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                ...reduxStore.getState().search,\n                users: {\n                    ...reduxStore.getState().search.users,\n                    selected: {}\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                ...reduxStore.getState().search,\n                users: {\n                    ...reduxStore.getState().search.users,\n                    selected: {\n                        ...reduxStore.getState().search.users.selected && reduxStore.getState().search.users.selected,\n                        [pr]: !reduxStore.getState().search.users.selected[pr],\n                    }\n                }\n            })\n        }\n\n    }\n\n    const selectClient = (pr) => {\n        if (reduxStore.getState().search.groups.selected && Object.keys(reduxStore.getState().search.groups.selected).length > 0) {\n            appAlert({\n                message: translate('$__alertGroupsFilterClear', 1),\n                variant: 'warning',\n                persist: false,\n                horizontal: 'right',\n                confirm: () => {\n                    confirmSelectClient(pr, true)\n                }\n            })\n        } else {\n            confirmSelectClient(pr, false)\n        }\n\n    }\n\n    const confirmSelectClient = (pr, clearGroups) => {\n        if (reduxStore.getState().search.units.selected[pr] && Object.keys(reduxStore.getState().search.units.selected).filter(a => reduxStore.getState().search.units.selected[a]).length <= 1) {\n            props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                ...reduxStore.getState().search,\n                units: {\n                    ...reduxStore.getState().search.units,\n                    selected: {}\n                },\n                ...clearGroups ? { groups: { selected: {} } } : {},\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                ...reduxStore.getState().search,\n                units: {\n                    ...reduxStore.getState().search.units,\n                    selected: {\n                        ...reduxStore.getState().search.units.selected && reduxStore.getState().search.units.selected,\n                        [pr]: !reduxStore.getState().search.units.selected[pr],\n                    }\n                },\n                ...clearGroups ? { groups: { selected: {} } } : {},\n            })\n        }\n    }\n\n    const selectPlan = (pr) => {\n        if (reduxStore.getState().search.plans.selected[pr] && Object.keys(reduxStore.getState().search.plans.selected).filter(a => reduxStore.getState().search.plans.selected[a]).length <= 1) {\n            props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                ...reduxStore.getState().search,\n                plans: {\n                    ...reduxStore.getState().search.plans,\n                    selected: {}\n                }\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                ...reduxStore.getState().search,\n                plans: {\n                    ...reduxStore.getState().search.plans,\n                    selected: {\n                        ...reduxStore.getState().search.plans.selected && reduxStore.getState().search.plans.selected,\n                        [pr]: !reduxStore.getState().search.plans.selected[pr],\n                    }\n                }\n            })\n        }\n    }\n\n    if (hashs[1] && Routes.filter(a => a.path === pathName).length > 0 && Routes.filter(a => a.path === pathName)[0].tabs && Routes.filter(a => a.path === pathName)[0].tabs.length > 0) {\n        let tabs = Routes.filter(a => a.path === pathName)[0].tabs && Routes.filter(a => a.path === pathName)[0].tabs\n        tabs.map(a => {\n            if (a.path === hashs[1])\n                fields = a.searchFields\n        })\n    } else if (Routes.filter(a => a.path === pathName).length > 0 && Routes.filter(a => a.path === pathName)[0].searchFields) {\n        fields = Routes.filter(a => a.path === pathName)[0].searchFields\n    }\n\n    return (\n        <React.Fragment>\n            <div\n                style={{ position: 'relative', width: '100%', padding: '0px', marginBottom: '15px' }}\n            >\n                {fields && fields.length > 0 && fields.indexOf('text') > -1 &&\n                    <div className={classes.textField} style={{ width: \"100%\" }}>\n                        <TextField\n                            className={classes.noLabelLight}\n                            label={translate('$__search', '*')}\n                            variant={'standard'}\n                            autoFocus\n                            value={search.text}\n                            InputProps={{\n                                endAdornment: (\n                                    <InputAdornment position=\"start\">\n                                        <Icon color={customApp('color')}>search</Icon>\n                                    </InputAdornment>\n                                ),\n                                onChange: e => {\n                                    props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                        ...reduxStore.getState().search,\n                                        text: e.target.value\n                                    })\n                                },\n                                onKeyDown: e => {\n                                    if (String(e.which) === '27')\n                                        setviewSearch(false)\n                                }\n                            }}\n                        />\n                    </div>\n                }\n                {fields.indexOf('period') > -1 &&\n                    <React.Fragment>PERIOD</React.Fragment>\n                }\n                {fields.indexOf('date') > -1 ?\n                    <React.Fragment>\n                        <DataPicker\n                            type=\"datetime\"\n                            onChangeStartDate={(d) => {\n                                let newData = {\n                                    startDate: moment(d).unix('x')\n                                }\n                                if (!reduxStore.getState().search.cards.endDate || reduxStore.getState().search.cards.endDate < moment(d).unix('x')) {\n                                    newData = {\n                                        ...newData,\n                                        endDate: moment(`${moment(d).format(\"YYYY-MM-DD\")} 23:59:59`).add(1, 'week').unix('X')\n                                    }\n                                }\n                                props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                    ...reduxStore.getState().search,\n                                    cards: {\n                                        ...reduxStore.getState().search.cards,\n                                        ...newData\n                                    }\n                                })\n                            }}\n                            onChangeEndDate={(d) => {\n                                props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                    ...reduxStore.getState().search,\n                                    cards: {\n                                        ...reduxStore.getState().search.cards,\n                                        endDate: moment(d).unix('x')\n                                    }\n                                })\n                            }}\n                            range\n                            // horizontal\n                            startDate={reduxStore.getState().search.cards.startDate ? new Date(reduxStore.getState().search.cards.startDate * 1000) : null}\n                            endDate={reduxStore.getState().search.cards.endDate ? new Date(reduxStore.getState().search.cards.endDate * 1000) : null}\n                            onClear={() => {\n                                props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                    ...reduxStore.getState().search,\n                                    cards: {\n                                        ...reduxStore.getState().search.cards,\n                                        startDate: null,\n                                        endDate: null,\n                                    }\n                                })\n                            }\n\n                            }\n                        />\n                    </React.Fragment>\n                    : <React.Fragment></React.Fragment>\n                }\n                {fields.indexOf('tags') > -1 ?\n                    <Autocomplete\n                        dbNode={'tag'}\n                        options={reduxStore.getState().db.tag}\n                        style={{ width: '100%' }}\n                        name=\"tag\"\n                        ws\n                        multiple\n                        value={search.tags}\n                        placeholder={translate('$__tags')}\n                        onChange={\n                            (v) => {\n                                props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                    ...reduxStore.getState().search,\n                                    tags: v\n                                })\n                            }\n                        }\n                    />\n                    : <React.Fragment></React.Fragment>\n                }\n                {/* FILTER BY STATUS */}\n                {fields.indexOf('status') > -1 &&\n                    <Accordion style={{ width: \"100%\", padding: 0 }}>\n                        <AccordionSummary\n                            style={{ minWidth: '100%' }}\n                            expandIcon={\n                                <Icon>expand_more</Icon>\n                            }\n                            aria-controls=\"panel1a-content\"\n                            id=\"panel1a-header\"\n                        >\n                            <div style={{ color: customApp('color'), fontSize: '16px', justifyContent: \"space-between\", width: \"100%\", display: \"flex\" }}>\n                                <div\n                                    style={{\n                                        position: 'relative',\n                                        float: 'left',\n                                    }}>\n                                    {translate('$__status')}\n                                </div>\n                                <div style={{\n                                    display: \"flex\",\n                                    justifyContent: \"flex-end\",\n                                }}>\n                                    {Object.keys(search.cards.status).map((a, i) => {\n                                        if (search.cards.status[a] && a !== 'all')\n                                            return (\n                                                <Tooltip\n                                                    title={translate(db.status.filter(fil => fil.value === a)[0].label, 1)}\n                                                    key={i}\n                                                >\n                                                    <div\n                                                        style={{\n                                                            position: 'relative',\n                                                            float: 'left',\n                                                            width: '11px',\n                                                            height: '11px',\n                                                            borderRadius: '50%',\n                                                            backgroundColor: db.status.filter(fil => fil.value === a)[0].color,\n                                                            margin: '7px 3px',\n                                                        }}></div>\n                                                </Tooltip>\n                                            )\n                                    })}\n                                </div>\n                            </div>\n                        </AccordionSummary>\n                        <AccordionDetails\n                            style={{ minWidth: '100%' }}\n                        >\n                            <FormGroup style={{ width: \"100%\" }}>\n                                <FormControlLabel\n                                    style={{ minWidth: '100%' }}\n                                    control={\n                                        <Checkbox\n                                            checked={reduxStore.getState().search.cards.status && reduxStore.getState().search.cards.status.all ? true : false}\n                                            onChange={() => {\n                                                let status = {}\n                                                db.status.map(a => {\n                                                    status = {\n                                                        ...status,\n                                                        [a.value]: reduxStore.getState().search.cards.status.all ? false : true\n                                                    }\n                                                })\n                                                props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                    ...reduxStore.getState().search,\n                                                    cards: {\n                                                        ...reduxStore.getState().search.cards,\n                                                        status: {\n                                                            ...status,\n                                                            all: !reduxStore.getState().search.cards.status.all\n                                                        }\n                                                    }\n                                                })\n                                            }}\n                                            color=\"default\"\n                                        />\n                                    }\n                                    label={translate('$__allStatus')}\n                                />\n                                {db.status.map((pr, index) =>\n                                    <React.Fragment\n                                        key={index}\n                                    >\n                                        <FormControlLabel\n                                            style={{ minWidth: '100%' }}\n                                            control={\n                                                <Checkbox\n                                                    indeterminate={reduxStore.getState().search.cards.status.all ? true : false}\n                                                    checked={reduxStore.getState().search.cards.status && reduxStore.getState().search.cards.status[pr.value] ? true : false}\n                                                    onChange={() => {\n                                                        let status = reduxStore.getState().search.cards.status\n\n                                                        if (status.all)\n                                                            db.status.map(a => {\n                                                                status[a.value] = false\n                                                                status.all = false\n                                                            })\n                                                        props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                            ...reduxStore.getState().search,\n                                                            cards: {\n                                                                ...reduxStore.getState().search.cards,\n                                                                status: {\n                                                                    ...status,\n                                                                    [pr.value]: status.all ? true : !reduxStore.getState().search.cards.status[pr.value],\n                                                                }\n                                                            }\n                                                        })\n                                                    }}\n                                                    color=\"default\"\n                                                />\n                                            }\n                                            label={translate(pr.label)}\n                                        />\n                                    </React.Fragment>\n                                )}\n                            </FormGroup>\n                        </AccordionDetails>\n                    </Accordion>\n                }\n\n                {/* FILTER BY PRIORITY */}\n                {fields.indexOf('priority') > -1 &&\n                    <Accordion style={{ width: \"100%\" }}>\n                        <AccordionSummary\n                            style={{ minWidth: '100%' }}\n                            expandIcon={\n                                <Icon>expand_more</Icon>\n                            }\n                            aria-controls=\"panel1a-content\"\n                            id=\"panel1a-header\"\n                        >\n                            <div style={{ color: customApp('color'), fontSize: '16px', justifyContent: \"space-between\", width: \"100%\", display: \"flex\" }}>\n                                <div\n                                    style={{\n                                        position: 'relative',\n                                        float: 'left',\n                                    }}>\n                                    {translate('$__priority')}\n                                </div>\n                                <div style={{\n                                    display: \"flex\",\n                                    justifyContent: \"flex-end\",\n                                }}>\n                                    {Object.keys(search.cards.priority).map((a, i) => {\n                                        if (search.cards.priority[a] && a !== 'all')\n                                            return (\n                                                <Tooltip\n                                                    title={translate(db.priority.filter(fil => String(fil.value) === String(a))[0].label, 1)}\n                                                    key={i}\n                                                >\n                                                    <div\n                                                        style={{\n                                                            position: 'relative',\n                                                            float: 'left',\n                                                            width: '11px',\n                                                            height: '11px',\n                                                            borderRadius: '50%',\n                                                            backgroundColor: db.priority.filter(fil => String(fil.value) === String(a))[0].color,\n                                                            margin: '7px 3px',\n                                                        }}></div>\n                                                </Tooltip>\n                                            )\n                                    })}\n                                </div>\n                            </div>\n                        </AccordionSummary>\n                        <AccordionDetails\n                            style={{ minWidth: '100%' }}\n                        >\n                            <FormGroup style={{ width: \"100%\" }}>\n                                <FormControlLabel\n                                    style={{ minWidth: '100%' }}\n                                    control={\n                                        <Checkbox\n                                            checked={reduxStore.getState().search.cards.priority && reduxStore.getState().search.cards.priority.all ? true : false}\n                                            onChange={() => {\n                                                let priority = reduxStore.getState().search.cards.priority\n                                                if (priority.all) {\n                                                    db.priority.map(a => {\n                                                        priority[String(a.value)] = false\n                                                    })\n                                                } else {\n                                                    db.priority.map(a => {\n                                                        priority[String(a.value)] = true\n                                                    })\n                                                }\n                                                props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                    ...reduxStore.getState().search,\n                                                    cards: {\n                                                        ...reduxStore.getState().search.cards,\n                                                        priority: {\n                                                            ...priority,\n                                                            all: !reduxStore.getState().search.cards.priority.all\n                                                        }\n                                                    }\n                                                })\n                                            }}\n                                            color=\"default\"\n                                        />\n                                    }\n                                    label={translate('$__allPriorities')}\n                                />\n                                {db.priority.map((pr, index) =>\n                                    <React.Fragment\n                                        key={index}\n                                    >\n                                        <FormControlLabel\n                                            style={{ minWidth: '100%', borderLeft: `3px solid ${pr.color}` }}\n                                            control={\n                                                <Checkbox\n                                                    indeterminate={reduxStore.getState().search.cards.priority && reduxStore.getState().search.cards.priority.all ? true : false}\n                                                    checked={reduxStore.getState().search.cards.priority && reduxStore.getState().search.cards.priority[pr.value] ? true : false}\n                                                    onChange={() => {\n                                                        let priority = reduxStore.getState().search.cards.priority\n\n                                                        if (priority.all)\n                                                            db.priority.map(a => {\n                                                                priority[String(a.value)] = false\n                                                                priority.all = false\n                                                            })\n                                                        props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                            ...reduxStore.getState().search,\n                                                            cards: {\n                                                                ...reduxStore.getState().search.cards,\n                                                                priority: {\n                                                                    ...priority,\n                                                                    [pr.value]: priority.all ? true : !reduxStore.getState().search.cards.priority[pr.value],\n                                                                }\n                                                            }\n                                                        })\n                                                    }}\n                                                    color=\"default\"\n                                                />\n                                            }\n                                            label={translate(pr.label)}\n                                        />\n                                    </React.Fragment>\n                                )}\n                            </FormGroup>\n                        </AccordionDetails>\n                    </Accordion>\n                }\n\n                {/* FILTER BY RISK */}\n                {fields.indexOf('risk') > -1 &&\n                    <Accordion style={{ width: \"100%\" }}>\n                        <AccordionSummary\n                            style={{ minWidth: '100%' }}\n                            expandIcon={\n                                <Icon>expand_more</Icon>\n                            }\n                            aria-controls=\"panel1a-content\"\n                            id=\"panel1a-header\"\n                        >\n                            <div style={{ color: customApp('color'), fontSize: '16px', justifyContent: \"space-between\", width: \"100%\", display: \"flex\" }}>\n                                <div\n                                    style={{\n                                        position: 'relative',\n                                        float: 'left',\n                                    }}>\n                                    {translate('$__risk')}\n                                </div>\n                                <div style={{\n                                    display: \"flex\",\n                                    justifyContent: \"flex-end\",\n                                }}>\n                                    {Object.keys(search.cards.risk).map((a, i) => {\n                                        if (search.cards.risk[a] && a !== 'all')\n                                            return (\n                                                <Tooltip\n                                                    title={translate(db.priority.filter(fil => String(fil.value) === String(a))[0].label, 1)}\n                                                    key={i}\n                                                >\n                                                    <div\n                                                        style={{\n                                                            position: 'relative',\n                                                            float: 'left',\n                                                            width: '11px',\n                                                            height: '11px',\n                                                            borderRadius: '50%',\n                                                            backgroundColor: db.priority.filter(fil => String(fil.value) === String(a))[0].color,\n                                                            margin: '7px 3px',\n                                                        }}></div>\n                                                </Tooltip>\n                                            )\n                                    })}\n                                </div>\n                            </div>\n                        </AccordionSummary>\n                        <AccordionDetails\n                            style={{ minWidth: '100%' }}\n                        >\n                            <FormGroup style={{ width: \"100%\" }}>\n                                <FormControlLabel\n                                    style={{ minWidth: '100%' }}\n                                    control={\n                                        <Checkbox\n                                            checked={reduxStore.getState().search.cards.risk && reduxStore.getState().search.cards.risk.all ? true : false}\n                                            onChange={() => {\n                                                let risk = reduxStore.getState().search.cards.risk\n                                                if (risk.all) {\n                                                    db.priority.map(a => {\n                                                        risk[String(a.value)] = false\n                                                    })\n                                                } else {\n                                                    db.priority.map(a => {\n                                                        risk[String(a.value)] = true\n                                                    })\n                                                }\n                                                props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                    ...reduxStore.getState().search,\n                                                    cards: {\n                                                        ...reduxStore.getState().search.cards,\n                                                        risk: {\n                                                            ...risk,\n                                                            all: !reduxStore.getState().search.cards.risk.all\n                                                        }\n                                                    }\n                                                })\n                                            }}\n                                            color=\"default\"\n                                        />\n                                    }\n                                    label={translate('$__allPriorities')}\n                                />\n                                {db.priority.map((pr, index) =>\n                                    <React.Fragment\n                                        key={index}\n                                    >\n                                        <FormControlLabel\n                                            style={{ minWidth: '100%', borderLeft: `3px solid ${pr.color}` }}\n                                            control={\n                                                <Checkbox\n                                                    indeterminate={reduxStore.getState().search.cards.risk && reduxStore.getState().search.cards.risk.all ? true : false}\n                                                    checked={reduxStore.getState().search.cards.risk && reduxStore.getState().search.cards.risk[pr.value] ? true : false}\n                                                    onChange={() => {\n                                                        let risk = reduxStore.getState().search.cards.risk\n\n                                                        if (risk.all)\n                                                            db.priority.map(a => {\n                                                                risk[String(a.value)] = false\n                                                                risk.all = false\n                                                            })\n                                                        props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                            ...reduxStore.getState().search,\n                                                            cards: {\n                                                                ...reduxStore.getState().search.cards,\n                                                                risk: {\n                                                                    ...risk,\n                                                                    [pr.value]: risk.all ? true : !reduxStore.getState().search.cards.risk[pr.value],\n                                                                }\n                                                            }\n                                                        })\n                                                    }}\n                                                    color=\"default\"\n                                                />\n                                            }\n                                            label={translate(pr.label)}\n                                        />\n                                    </React.Fragment>\n                                )}\n                            </FormGroup>\n                        </AccordionDetails>\n                    </Accordion>\n                }\n\n                {/* FILTER BY COMPLEXITY */}\n                {fields.indexOf('complexity') > -1 &&\n                    <Accordion style={{ width: \"100%\" }}>\n                        <AccordionSummary\n                            style={{ minWidth: '100%' }}\n                            expandIcon={\n                                <Icon>expand_more</Icon>\n                            }\n                            aria-controls=\"panel1a-content\"\n                            id=\"panel1a-header\"\n                        >\n                            <div style={{ color: customApp('color'), fontSize: '16px', justifyContent: \"space-between\", width: \"100%\", display: \"flex\" }}>\n                                <div\n                                    style={{\n                                        position: 'relative',\n                                        float: 'left',\n                                    }}>\n                                    {translate('$__complexity')}\n                                </div>\n                                <div style={{\n                                    display: \"flex\",\n                                    justifyContent: \"flex-end\",\n                                }}>\n                                    {Object.keys(search.cards.complexity).map((a, i) => {\n                                        if (search.cards.complexity[a] && a !== 'all')\n                                            return (\n                                                <Tooltip\n                                                    title={translate(db.priority.filter(fil => String(fil.value) === String(a))[0].label, 1)}\n                                                    key={i}\n                                                >\n                                                    <div\n                                                        style={{\n                                                            position: 'relative',\n                                                            float: 'left',\n                                                            width: '11px',\n                                                            height: '11px',\n                                                            borderRadius: '50%',\n                                                            backgroundColor: db.priority.filter(fil => String(fil.value) === String(a))[0].color,\n                                                            margin: '7px 3px',\n                                                        }}></div>\n                                                </Tooltip>\n                                            )\n                                    })}\n                                </div>\n                            </div>\n                        </AccordionSummary>\n                        <AccordionDetails\n                            style={{ minWidth: '100%' }}\n                        >\n                            <FormGroup style={{ width: \"100%\" }}>\n                                <FormControlLabel\n                                    style={{ minWidth: '100%' }}\n                                    control={\n                                        <Checkbox\n                                            checked={reduxStore.getState().search.cards.complexity && reduxStore.getState().search.cards.complexity.all ? true : false}\n                                            onChange={() => {\n                                                let complexity = reduxStore.getState().search.cards.complexity\n                                                if (complexity.all) {\n                                                    db.priority.map(a => {\n                                                        complexity[String(a.value)] = false\n                                                    })\n                                                } else {\n                                                    db.priority.map(a => {\n                                                        complexity[String(a.value)] = true\n                                                    })\n                                                }\n                                                props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                    ...reduxStore.getState().search,\n                                                    cards: {\n                                                        ...reduxStore.getState().search.cards,\n                                                        complexity: {\n                                                            ...complexity,\n                                                            all: !reduxStore.getState().search.cards.complexity.all\n                                                        }\n                                                    }\n                                                })\n                                            }}\n                                            color=\"default\"\n                                        />\n                                    }\n                                    label={translate('$__allPriorities')}\n                                />\n                                {db.priority.map((pr, index) =>\n                                    <React.Fragment\n                                        key={index}\n                                    >\n                                        <FormControlLabel\n                                            style={{ minWidth: '100%', borderLeft: `3px solid ${pr.color}` }}\n                                            control={\n                                                <Checkbox\n                                                    indeterminate={reduxStore.getState().search.cards.complexity && reduxStore.getState().search.cards.complexity.all ? true : false}\n                                                    checked={reduxStore.getState().search.cards.complexity && reduxStore.getState().search.cards.complexity[pr.value] ? true : false}\n                                                    onChange={() => {\n                                                        let complexity = reduxStore.getState().search.cards.complexity\n\n                                                        if (complexity.all)\n                                                            db.priority.map(a => {\n                                                                complexity[String(a.value)] = false\n                                                                complexity.all = false\n                                                            })\n                                                        props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                            ...reduxStore.getState().search,\n                                                            cards: {\n                                                                ...reduxStore.getState().search.cards,\n                                                                complexity: {\n                                                                    ...complexity,\n                                                                    [pr.value]: complexity.all ? true : !reduxStore.getState().search.cards.complexity[pr.value],\n                                                                }\n                                                            }\n                                                        })\n                                                    }}\n                                                    color=\"default\"\n                                                />\n                                            }\n                                            label={translate(pr.label)}\n                                        />\n                                    </React.Fragment>\n                                )}\n                            </FormGroup>\n                        </AccordionDetails>\n                    </Accordion>\n                }\n\n                {/* FILTER BY IMPACT */}\n                {fields.indexOf('impact') > -1 &&\n                    <Accordion style={{ width: \"100%\" }}>\n                        <AccordionSummary\n                            style={{ minWidth: '100%' }}\n                            expandIcon={\n                                <Icon>expand_more</Icon>\n                            }\n                            aria-controls=\"panel1a-content\"\n                            id=\"panel1a-header\"\n                        >\n                            <div style={{ color: customApp('color'), fontSize: '16px', justifyContent: \"space-between\", width: \"100%\", display: \"flex\" }}>\n                                <div\n                                    style={{\n                                        position: 'relative',\n                                        float: 'left',\n                                    }}>\n                                    {translate('$__impact')}\n                                </div>\n                                <div style={{\n                                    display: \"flex\",\n                                    justifyContent: \"flex-end\",\n                                }}>\n                                    {Object.keys(search.cards.impact).map((a, i) => {\n                                        if (search.cards.impact[a] && a !== 'all')\n                                            return (\n                                                <Tooltip\n                                                    title={translate(db.priority.filter(fil => String(fil.value) === String(a))[0].label, 1)}\n                                                    key={i}\n                                                >\n                                                    <div\n                                                        style={{\n                                                            position: 'relative',\n                                                            float: 'left',\n                                                            width: '11px',\n                                                            height: '11px',\n                                                            borderRadius: '50%',\n                                                            backgroundColor: db.priority.filter(fil => String(fil.value) === String(a))[0].color,\n                                                            margin: '7px 3px',\n                                                        }}></div>\n                                                </Tooltip>\n                                            )\n                                    })}\n                                </div>\n                            </div>\n                        </AccordionSummary>\n                        <AccordionDetails\n                            style={{ minWidth: '100%' }}\n                        >\n                            <FormGroup style={{ width: \"100%\" }}>\n                                <FormControlLabel\n                                    style={{ minWidth: '100%' }}\n                                    control={\n                                        <Checkbox\n                                            checked={reduxStore.getState().search.cards.impact && reduxStore.getState().search.cards.impact.all ? true : false}\n                                            onChange={() => {\n                                                let impact = reduxStore.getState().search.cards.impact\n                                                if (impact.all) {\n                                                    db.priority.map(a => {\n                                                        impact[String(a.value)] = false\n                                                    })\n                                                } else {\n                                                    db.priority.map(a => {\n                                                        impact[String(a.value)] = true\n                                                    })\n                                                }\n                                                props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                    ...reduxStore.getState().search,\n                                                    cards: {\n                                                        ...reduxStore.getState().search.cards,\n                                                        impact: {\n                                                            ...impact,\n                                                            all: !reduxStore.getState().search.cards.impact.all\n                                                        }\n                                                    }\n                                                })\n                                            }}\n                                            color=\"default\"\n                                        />\n                                    }\n                                    label={translate('$__allPriorities')}\n                                />\n                                {db.priority.map((pr, index) =>\n                                    <React.Fragment\n                                        key={index}\n                                    >\n                                        <FormControlLabel\n                                            style={{ minWidth: '100%', borderLeft: `3px solid ${pr.color}` }}\n                                            control={\n                                                <Checkbox\n                                                    indeterminate={reduxStore.getState().search.cards.impact && reduxStore.getState().search.cards.impact.all ? true : false}\n                                                    checked={reduxStore.getState().search.cards.impact && reduxStore.getState().search.cards.impact[pr.value] ? true : false}\n                                                    onChange={() => {\n                                                        let impact = reduxStore.getState().search.cards.impact\n\n                                                        if (impact.all)\n                                                            db.priority.map(a => {\n                                                                impact[String(a.value)] = false\n                                                                impact.all = false\n                                                            })\n                                                        props.reduxFunction(\"ASYNC\", \"SEARCH\", {\n                                                            ...reduxStore.getState().search,\n                                                            cards: {\n                                                                ...reduxStore.getState().search.cards,\n                                                                impact: {\n                                                                    ...impact,\n                                                                    [pr.value]: impact.all ? true : !reduxStore.getState().search.cards.impact[pr.value],\n                                                                }\n                                                            }\n                                                        })\n                                                    }}\n                                                    color=\"default\"\n                                                />\n                                            }\n                                            label={translate(pr.label)}\n                                        />\n                                    </React.Fragment>\n                                )}\n                            </FormGroup>\n                        </AccordionDetails>\n                    </Accordion>\n                }\n\n\n\n                {db.users\n                    && Object.keys(db.users).length > 0\n                    && Object.keys(db.users).filter(a => {\n                        if (\n                            db.users[a]\n                            && db.users[a].type\n                            && (\n                                db.users[a].type !== 'user'\n                            )\n                            && !db.users[a].deleted\n                            && Object.keys(db.cards).filter(cc =>\n                                db.cards[cc]\n                                && db.cards[cc].client\n                                && db.cards[cc].client === a\n                                && db.cards[cc]._users\n                                && db.cards[cc]._users[session._id]\n                            ).length > 0)\n                            return true\n                    }\n                    ).length > 0\n                    && fields.indexOf('units') > -1\n                    && search\n                    && search.groups\n                    && search.groups.selected\n                    && Object.keys(search.groups.selected).length === 0\n                    && search.plans\n                    && search.plans.selected\n                    && Object.keys(search.plans.selected).length === 0\n                    &&\n                    /* FILTER BY CLIENT */\n                    <Accordion style={{ width: \"100%\" }}>\n                        <AccordionSummary\n                            style={{ minWidth: '100%' }}\n                            expandIcon={\n                                <Icon>expand_more</Icon>\n                            }\n                            aria-controls=\"panel1a-content\"\n                            id=\"panel1a-header\"\n                        ><div style={{ color: customApp('color'), fontSize: '16px', justifyContent: \"space-between\", width: \"100%\", display: \"flex\" }}>\n                                {translate('$__units')}\n                                <AvatarGroup max={6}>\n                                    {Object.keys(reduxStore.getState().search.units.selected).length > 0 && Object.keys(reduxStore.getState().search.units.selected).map((a, i) => (\n                                        <Tooltip\n                                            title={db.users[a].name}\n                                            key={i}\n                                        >\n                                            <Avatar alt={db.users[a].name} src={db.users[a].image || null} >\n                                                {db.users[a].name.substr(0, 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                    ))}\n                                </AvatarGroup>\n\n                            </div>\n                        </AccordionSummary>\n                        <AccordionDetails\n                            style={{ minWidth: '100%' }}\n                        >\n                            <FormGroup style={{ width: \"100%\" }}>\n                                <TextField\n                                    className={classes.noLabelLight}\n                                    label={translate('$__search', '*')}\n                                    variant={'standard'}\n                                    autoFocus\n                                    value={findNameClient}\n                                    InputProps={{\n                                        endAdornment: (\n                                            <InputAdornment position=\"start\">\n                                                <Icon color={customApp('color')}>search</Icon>\n                                            </InputAdornment>\n                                        ),\n                                        onChange: e => {\n                                            setFindNameClient(e.target.value)\n                                        },\n                                    }}\n                                />\n                                {Object.keys(db.users)\n                                    .filter(a =>\n                                        (\n                                            db.users[a].type !== 'user'\n                                        )\n                                        && !db.users[a].deleted\n                                        && Object.keys(db.cards).filter(cc =>\n                                            db.cards[cc]\n                                            && db.cards[cc].client\n                                            && db.cards[cc].client === a\n                                            && db.cards[cc]._users\n                                            && db.cards[cc]._users[session._id]\n                                        ).length > 0\n                                        && (\n                                            findNameClient === \"\"\n                                            ||\n                                            db.users[a].name.toLowerCase().indexOf(findNameClient.toLowerCase()) > -1\n                                        )\n                                    ).map(pr =>\n                                        <React.Fragment\n                                            key={pr}\n                                        >\n                                            <FormControlLabel\n                                                key={pr}\n                                                style={{ minWidth: '100%' }}\n                                                control={\n                                                    <React.Fragment>\n                                                        <Avatar alt={db.users[pr].name} src={db.users[pr].image || null} >\n                                                            {db.users[pr].name.substr(0, 1)}\n                                                        </Avatar>\n                                                        <Checkbox\n                                                            checked={reduxStore.getState().search.units.selected && reduxStore.getState().search.units.selected[pr] ? true : false}\n                                                            onChange={() => {\n                                                                selectClient(pr)\n                                                            }}\n                                                            color=\"default\"\n                                                        />\n                                                    </React.Fragment>\n                                                }\n                                                label={db.users[pr].name || db.users[pr].name}\n                                            />\n                                        </React.Fragment>\n                                    )}\n                            </FormGroup>\n                        </AccordionDetails>\n                    </Accordion>\n                }\n\n                {/* FILTER BY USER */}\n                {db.users && Object.keys(db.users).length > 0 && fields.indexOf('users') > -1 &&\n                    <Accordion style={{ width: \"100%\" }}>\n                        <AccordionSummary\n                            style={{ minWidth: '100%' }}\n                            expandIcon={\n                                <Icon>expand_more</Icon>\n                            }\n                            aria-controls=\"panel1a-content\"\n                            id=\"panel1a-header\"\n                        ><div style={{ color: customApp('color'), fontSize: '16px', justifyContent: \"space-between\", width: \"100%\", display: \"flex\" }}>\n                                {translate('$__users')}\n                                <AvatarGroup max={6}>\n                                    {Object.keys(reduxStore.getState().search.users.selected).length > 0 && Object.keys(reduxStore.getState().search.users.selected).map((a, i) => (\n                                        <Tooltip\n                                            title={db.users[a].name}\n                                            key={i}\n                                        >\n                                            <Avatar alt={db.users[a].name} src={db.users[a].image || null} >\n                                                {db.users[a].name.substr(0, 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                    ))}\n                                </AvatarGroup>\n                            </div>\n                        </AccordionSummary>\n                        <AccordionDetails\n                            style={{ minWidth: '100%' }}\n                        >\n                            <FormGroup style={{ width: \"100%\" }}>\n                                <TextField\n                                    className={classes.noLabelLight}\n                                    label={translate('$__search', '*')}\n                                    variant={'standard'}\n                                    autoFocus\n                                    value={findNameUser}\n                                    InputProps={{\n                                        endAdornment: (\n                                            <InputAdornment position=\"start\">\n                                                <Icon color={customApp('color')}>search</Icon>\n                                            </InputAdornment>\n                                        ),\n                                        onChange: e => {\n                                            setFindNameUser(e.target.value)\n                                        },\n                                    }}\n                                />\n                                {Object.keys(db.users)\n                                    .filter(us => {\n                                        if (\n                                            db.users[us].type === 'user'\n                                            && !db.users[us].deleted\n                                            && (\n                                                Object.keys(search.units.selected).length === 0\n                                                || (\n                                                    Object.keys(search.units.selected).length > 0\n                                                    && Object.keys(search.units.selected).filter(ua => ua === us).length > 0\n                                                )\n                                            )\n                                            && (\n                                                (\n                                                    !hashs[0]\n                                                    && (\n                                                        Object.keys(db.cards).filter(uc =>\n                                                            db.cards[uc]._users[us]\n                                                            && db.cards[uc].type !== \"chatGroup\"\n                                                            && db.cards[uc].type !== \"plan\"\n                                                        ).length > 0\n                                                    )\n                                                )\n                                                ||\n                                                (\n                                                    hashs[0]\n                                                    && hashs[0].length === 36\n                                                    && (\n                                                        Object.keys(db.cards).filter(uc =>\n                                                            (\n                                                                db.cards[uc]._planId === hashs[0]\n                                                                || db.cards[uc]._id === hashs[0]\n                                                            )\n                                                            && db.cards[uc]._users[us]\n                                                            && db.cards[uc].type !== \"chatGroup\"\n                                                            && db.cards[uc].type !== \"plan\"\n                                                        ).length > 0\n                                                    )\n                                                )\n                                            )\n                                            &&\n                                            (findNameUser === \"\"\n                                                ||\n                                                (\n                                                    findNameUser !== \"\"\n                                                    && (\n                                                        db.users[us]\n                                                        && db.users[us].name\n                                                        && db.users[us].name.toLowerCase().indexOf(findNameUser.toLowerCase()) > -1\n                                                        || db.users[us].email.toLowerCase().indexOf(findNameUser.toLowerCase()) > -1\n                                                    )\n                                                )\n                                            )) {\n                                            return true\n                                        }\n                                    }).sort((a, b) => {\n                                        if (db.users[a].name.trim().toLowerCase() < db.users[b].name.trim().toLowerCase())\n                                            return -1\n                                        else if (db.users[a].name.trim().toLowerCase() > db.users[b].name.trim().toLowerCase())\n                                            return 1\n                                        return 0\n                                    }).map(pr =>\n                                        db.users && db.users[pr] && db.users[pr]._id &&\n                                        <React.Fragment\n                                            key={pr}\n                                        >\n                                            <FormControlLabel\n                                                key={pr}\n                                                style={{ minWidth: '100%' }}\n                                                control={\n                                                    <React.Fragment>\n                                                        <Badge\n                                                            overlap=\"rectangular\"\n                                                            color=\"secondary\"                                                    >\n                                                            <UserBadge\n                                                                overlap=\"circular\"\n                                                                anchorOrigin={{\n                                                                    vertical: 'bottom',\n                                                                    horizontal: 'right',\n                                                                }}\n                                                                userId={db.users[pr]._id}\n                                                            // variant={usersStatus.users && usersStatus.users[db.users[pr]._id] && usersStatus.users[db.users[pr]._id].status ? \"dot\" : \"standard\"}\n                                                            // status={usersStatus.users && usersStatus.users[db.users[pr]._id] && usersStatus.users[db.users[pr]._id].status ? usersStatus.users[db.users[pr]._id].status : null}\n                                                            >\n                                                                <Avatar alt={db.users[pr].name} src={db.users[pr].image || null} >\n                                                                    {db.users[pr].name.substr(0, 1)}\n                                                                </Avatar>\n                                                            </UserBadge>\n                                                        </Badge>\n                                                        <Checkbox\n                                                            checked={reduxStore.getState().search.users.selected && reduxStore.getState().search.users.selected[pr] ? true : false}\n                                                            onChange={() => {\n                                                                selectUser(pr)\n                                                            }}\n                                                            color=\"default\"\n                                                        />\n                                                    </React.Fragment>\n                                                }\n                                                label={db.users[pr].name}\n                                            />\n                                        </React.Fragment>\n                                    )}\n                            </FormGroup>\n                        </AccordionDetails>\n                    </Accordion>\n                }\n\n\n                {Object.keys(db.cards).filter(a =>\n                    db.cards[a].type === 'plan'\n                    && !db.cards[a].deleted\n                    && !db.cards[a].archived\n                    && db.cards[a]._users\n                    && db.cards[a]._users[session._id]\n                    && Object.keys(db.cards).filter(dc =>\n                        !db.cards[dc].deleted\n                        && db.cards[dc]._planId === a\n                        && db.cards[dc]._users\n                        && db.cards[dc]._users[session._id]\n                    ).length > 0\n                ).length > 0 && fields.indexOf('plans') > -1 &&\n                    /* FILTER BY PLANS */\n                    <Accordion style={{ width: \"100%\" }}>\n                        <AccordionSummary\n                            style={{ minWidth: '100%' }}\n                            expandIcon={\n                                <Icon>expand_more</Icon>\n                            }\n                            aria-controls=\"panel1a-content\"\n                            id=\"panel1a-header\"\n                        ><div style={{ color: customApp('color'), fontSize: '16px', justifyContent: \"space-between\", width: \"100%\", display: \"flex\" }}>\n                                {translate('$__plans')}\n                                <AvatarGroup max={6}>\n                                    {Object.keys(reduxStore.getState().search.plans.selected).length > 0 && Object.keys(reduxStore.getState().search.plans.selected).map((a, i) => (\n                                        <Tooltip\n                                            title={db.cards[a].name}\n                                            key={i}\n                                        >\n                                            <Avatar alt={db.cards[a].name} src={db.cards[a].image || null} style={{ width: 33, height: 33 }}>\n                                                {db.cards[a].name.substr(0, 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                    ))}\n                                </AvatarGroup>\n                            </div>\n                        </AccordionSummary>\n                        <AccordionDetails\n                            style={{ minWidth: '100%', width: \"100%\" }}\n                        >\n                            <FormGroup style={{ width: \"100%\" }}>\n                                <TextField\n                                    className={classes.noLabelLight}\n                                    label={translate('$__search', '*')}\n                                    variant={'standard'}\n                                    autoFocus\n                                    value={findNamePlan}\n                                    InputProps={{\n                                        endAdornment: (\n                                            <InputAdornment position=\"start\">\n                                                <Icon color={customApp('color')}>search</Icon>\n                                            </InputAdornment>\n                                        ),\n                                        onChange: e => {\n                                            setFindNamePlan(e.target.value)\n                                        },\n                                    }}\n                                />\n                                {Object.keys(db.cards)\n                                    .filter(a =>\n                                        db.cards[a].type === 'plan'\n                                        && !db.cards[a].deleted\n                                        && !db.cards[a].archived\n                                        && db.cards[a]._users\n                                        && db.cards[a]._users[session._id]\n                                        && Object.keys(db.cards).filter(dc =>\n                                            !db.cards[dc].deleted\n                                            && db.cards[dc]._planId === a\n                                            && db.cards[dc]._users\n                                            && db.cards[dc]._users[session._id]\n                                        ).length > 0\n                                        && (\n                                            (Object.keys(search.units.selected).length === 0\n                                                && Object.keys(search.groups.selected).length === 0\n                                            )\n                                            ||\n                                            (\n                                                Object.keys(search.units.selected).length > 0\n                                                && Object.keys(search.units.selected).filter(fa => fa === db.cards[a].client).length > 0\n                                            )\n                                            ||\n                                            (\n                                                Object.keys(search.groups.selected).length > 0\n                                                && Object.keys(search.groups.selected).filter(faa => faa === db.cards[a].client).length > 0\n                                            )\n                                        )\n                                        && (\n                                            findNamePlan === \"\"\n                                            ||\n                                            db.cards[a].name.toLowerCase().indexOf(findNamePlan.toLowerCase()) > -1\n                                        )\n                                    )\n                                    .sort((a, b) => {\n                                        if (a.name < b.name) {\n                                            return -1\n                                        } else if (a.name > b.name) {\n                                            return 1\n                                        } else {\n                                            return 0\n                                        }\n                                    })\n                                    .map(pr =>\n                                        <React.Fragment\n                                            key={pr}\n                                        >\n                                            <FormControlLabel\n                                                key={pr}\n                                                style={{ width: \"calc(100% - 15px)\", paddingRight: \"15px\", whiteSpace: \"nowrap\", overflow: 'hidden', textOverflow: \"ellipsis\" }}\n                                                control={\n                                                    <React.Fragment>\n                                                        <Avatar alt={db.cards[pr].name} src={db.cards[pr].image || null} >\n                                                            {db.cards[pr].name.substr(0, 1)}\n                                                        </Avatar>\n                                                        <Checkbox\n                                                            checked={reduxStore.getState().search.plans.selected && reduxStore.getState().search.plans.selected[pr] ? true : false}\n                                                            onChange={() => {\n                                                                selectPlan(pr)\n                                                            }}\n                                                            color=\"default\"\n                                                        />\n                                                    </React.Fragment>\n                                                }\n                                                label={db.cards[pr].name || db.cards[pr].name}\n                                                title={db.cards[pr].name || db.cards[pr].name}\n                                            />\n                                        </React.Fragment>\n                                    )}\n                            </FormGroup>\n                        </AccordionDetails>\n                    </Accordion>\n                }\n                {/* FINAL FILTER PARAMETERS */}\n                <div\n                    style={{\n                        padding: '5px',\n                        width: '100%',\n                        display: 'flex',\n                        justifyContent: 'flex-end'\n                    }}\n                    onClick={() => { setviewSearch(!viewSearch) }}\n                >\n                    <IconButton reverse icon={'clear_all'} text={translate(\"$__removeFilter\", \"*\")}\n                        onClick={() => {\n                            props.reduxFunction(\"ASYNC\", \"SEARCH_CLEAR\", {})\n                        }} />\n                    {/* <IconButton reverse icon={'check'} text={translate(\"$__conclude\", \"*\")} onClick={() => { setviewSearch(!viewSearch) }} /> */}\n                </div>\n            </div>\n        </React.Fragment>\n    );\n}\n\nFilterComponent.propTypes = {\n    handleDrawerToggle: PropTypes.func,\n    sidebarMinimize: PropTypes.func\n};\n\n\nconst mapStateToProps = (store) => ({\n    store: {\n        search: store.search,\n        users: store.db.users\n    }\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(FilterComponent)","import React from \"react\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\";\nimport Button from '@material-ui/core/Button';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport Grow from '@material-ui/core/Grow';\nimport IconButton from '@material-ui/core/IconButton';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport MenuList from '@material-ui/core/MenuList';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport Tooltip from \"@material-ui/core/Tooltip\";\nimport { makeStyles } from '@material-ui/core/styles';\nimport Filter from \"./index\";\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\";\n\n\nconst useStyles = makeStyles((props) => ({\n    iconButtonStyleTransaparent: {\n        padding: 3,\n        margin: 0,\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        }\n    },\n    iconButtonStyleWhite: {\n        padding: 3,\n        margin: 0,\n        backgroundColor: '#FFFFFF',\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        }\n    },\n}));\n\nfunction Comp(props) {\n    const classes = useStyles();\n    const [open, setOpen] = React.useState(false);\n    const anchorRef = React.useRef(null)\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n\n        setOpen(false);\n        if (props.onClose)\n            props.onClose()\n    };\n\n    function handleListKeyDown(event) {\n        if (event.key === 'Tab') {\n            event.preventDefault();\n            setOpen(false);\n            if (props.onClose)\n                props.onClose()\n        }\n    }\n\n    return (\n        <div style={{ zIndex: \"100 !important\", ...props.style ? props.style : {} }}>\n            <Tooltip\n                title={translate(`$__options`, 1)}\n            >\n                {props.hideText ?\n                    <IconButton\n                        ref={anchorRef}\n                        aria-controls={open ? 'menu-list-grow' : undefined}\n                        aria-haspopup=\"true\"\n                        aria-label=\"menu\"\n                        onClick={(e) => {\n                            setOpen((prevOpen) => !prevOpen);\n                            if (!open && props.onOpen)\n                                props.onOpen()\n                            if (open && props.onClose)\n                                props.onClose()\n                            e.stopPropagation()\n                        }}\n                        className={!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}\n                    >\n                        <Icon\n                            usePropagation\n                            size={!props.size ? \"20px\" : props.size}\n                            color={props.btColor ? props.btColor : customApp('menu')}\n                            icon={props.icon ? props.icon : !props.horizontalButton ? 'more_vert' : 'more_horiz'} />\n                    </IconButton>\n                    :\n                    <Button\n                        ref={anchorRef}\n                        aria-controls={open ? 'menu-list-grow' : undefined}\n                        aria-haspopup=\"true\"\n                        aria-label=\"menu\"\n                        onClick={(e) => {\n                            setOpen((prevOpen) => !prevOpen);\n                            if (!open && props.onOpen)\n                                props.onOpen()\n                            if (open && props.onClose)\n                                props.onClose()\n                            e.stopPropagation()\n                        }}\n                        className={!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}\n                    >\n                        <React.Fragment>\n                            <span\n                                style={{\n                                    marginRight: '15px',\n                                    color: props.textColor ? props.textColor : props.color ? props.color : customApp('menu'),\n                                    overflow: \"hidden\",\n                                    textOverflow: \"ellipsis\",\n                                    width: \"90%\",\n                                    maxWidth: props.maxWidth ? props.maxWidth : \"90%\",\n                                    whiteSpace: \"nowrap\"\n                                }}>{translate('$__filter')}</span>\n                            <Icon\n                                usePropagation\n                                size={!props.size ? \"20px\" : props.size}\n                                color={props.btColor ? props.btColor : customApp('menu')}\n                                icon={'filter_alt'} />\n                        </React.Fragment>\n                    </Button>\n                }\n            </Tooltip >\n            <Popper\n                open={open}\n                anchorEl={anchorRef.current}\n                role={undefined}\n                transition\n                // disablePortal\n                style={{ zIndex: \"100 !important\" }}\n            >\n                {({ TransitionProps, placement }) => (\n                    <Grow\n                        {...TransitionProps}\n                        style={{\n                            // ...placement === 'bottom' ? { transformOrigin: 'center top' } : { transformOrigin: 'center bottom' },\n                            transformOrigin: 'right center',\n                            zIndex: \"100 !important\"\n                        }}\n                    >\n                        <Paper>\n                            <ClickAwayListener onClickAway={handleClose}>\n                                <div style={{ padding: \"15px\" }}>\n                                    <Filter\n                                        onChange={(data) => {\n                                            console.log(data)\n                                        }}\n                                    />\n                                </div>\n                            </ClickAwayListener>\n                        </Paper>\n                    </Grow>\n                )}\n            </Popper>\n        </div>\n    )\n}\nexport default Comp;\n","//CORE\r\nimport React from \"react\";\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\";\r\nimport { bindActionCreators } from \"redux\";\r\nimport * as reduxActions from \"store/actions\";\r\nimport reduxStore from \"store/\";\r\n\r\n//COMPONENTS\r\nimport AgileOverview from \"components/AgileV2/overview\";\r\nimport CustomButton from \"components/Buttons/custom\";\r\nimport Filter from \"components/Filter/menuFilter\";\r\nimport GridItem from \"components/Grid/GridItem\";\r\nimport MoreMenu from \"components/MoreMenu\";\r\n\r\n\r\n//FUNCTIONS\r\nimport {\r\n    customApp,\r\n    translate,\r\n} from \"functions/\";\r\n\r\nimport {\r\n    countNotifications\r\n} from \"functions/cards\"\r\n\r\nimport {\r\n    loadCardsV2,\r\n} from \"functions/loadData\"\r\n\r\n\r\nfunction Component(props) {\r\n    const { db } = reduxStore.getState()\r\n    const [viewCompleted, setViewCompleted] = React.useState(true)\r\n    const [viewColors, setViewColors] = React.useState(true)\r\n    const [onlyUnReaded, setOnlyUnReaded] = React.useState(false)\r\n    const [showDeleted, setShowDeleted] = React.useState(false)\r\n    const [loadingDeleted, setLoadingDeleted] = React.useState(false)\r\n\r\n\r\n    let hashs = window.location.hash.split('/')\r\n    hashs[0] = hashs[0].replace('#', '')\r\n\r\n    React.useEffect(() => {\r\n        return () => {\r\n            props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                ...reduxStore.getState().controls,\r\n                deleted: false\r\n            })\r\n        }\r\n    }, [])\r\n\r\n    React.useEffect(() => {\r\n        if (showDeleted)\r\n            loadDeletedCards()\r\n    }, [showDeleted])\r\n\r\n    const loadDeletedCards = async () => {\r\n        setLoadingDeleted(true)\r\n        let Nhashs = window.location.hash.split(\"/\")\r\n        Nhashs[0] = Nhashs[0].replace(\"#\", \"\")\r\n\r\n        let lc = await loadCardsV2(props, {\r\n            idRel: Nhashs[0],\r\n            cardLoad: 'deleted',\r\n        })\r\n        if (lc)\r\n            setLoadingDeleted(false)\r\n    }\r\n\r\n    let unReadeds = 0\r\n    Object.keys(db.cards).filter(a => {\r\n        let notifications = countNotifications(a)\r\n        if (db.cards[a]\r\n            && !db.cards[a].deleted\r\n            && (\r\n                db.cards[a]._planId === hashs[0]\r\n                || db.cards[a]._parent === hashs[0]\r\n            )\r\n            && (\r\n                viewCompleted\r\n                ||\r\n                (\r\n                    !viewCompleted\r\n                    && db.cards[a].status !== \"completed\"\r\n                )\r\n            )\r\n            && notifications.total > 0\r\n        )\r\n            return true\r\n\r\n    }).map(a => {\r\n        let notifications = countNotifications(a)\r\n        unReadeds = unReadeds + notifications.total\r\n    })\r\n\r\n    return (\r\n        <div>\r\n            <GridItem md={12} sm={12} xs={12}>\r\n                <div\r\n                    style={{\r\n                        display: \"flex\",\r\n                        justifyContent: \"flex-end\"\r\n                    }}\r\n                >\r\n                    <Filter style={{\r\n                        marginRight: \"7px\"\r\n                    }} />\r\n                    <MoreMenu\r\n                        text={translate(\"$__options\")}\r\n                        icon={\"settings\"}\r\n                        horizontalButton\r\n                        size={'21px'}\r\n                        color={\"lightgray\"}\r\n                        btColor={\"lightgray\"}\r\n                        options={[\r\n                            {\r\n                                name: db.orderByTitlePosition === 'ASC' ? translate(\"$__orderByAsc\") : translate(\"$__orderByDesc\"),\r\n                                icon: db.orderByTitlePosition === 'ASC' ? \"text_rotation_down\" : \"text_rotate_up\",\r\n                                onClick: () => {\r\n                                    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                                        ...reduxStore.getState().db,\r\n                                        orderByTitlePosition: reduxStore.getState().db.orderByTitlePosition === 'ASC' ? 'DESC' : 'ASC'\r\n                                    })\r\n                                },\r\n                            },\r\n                            {\r\n                                name: db.orderByTitle ? translate(\"$__manualOrder\") : translate(\"$__orderByName\"),\r\n                                icon: db.orderByTitle ? \"drag_handle\" : \"format_list_numbered_rtl\",\r\n                                onClick: () => {\r\n                                    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                                        ...reduxStore.getState().db,\r\n                                        orderByTitle: !reduxStore.getState().db.orderByTitle\r\n                                    })\r\n                                },\r\n                            },\r\n                            {\r\n                                name: viewColors ? translate(\"$__hideCatenationColors\") : translate(\"$__showCatenationColors\"),\r\n                                icon: \"palette\",\r\n                                color: !viewColors ? customApp('menu') : 'lightGray',\r\n                                onClick: () => {\r\n                                    setViewColors(prev => !prev)\r\n                                },\r\n                            },\r\n                            {\r\n                                name: translate(\"$__groupByColor\"),\r\n                                icon: \"gradient\",\r\n                                color: db.groupByColor ? customApp('menu') : 'lightGray',\r\n                                onClick: () => {\r\n                                    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                                        ...reduxStore.getState().db,\r\n                                        groupByColor: !db.groupByColor\r\n                                    })\r\n                                },\r\n                            },\r\n                        ]}\r\n                    />\r\n                    <div style={{ marginLeft: \"7px\", display: \"flex\", alignItems: \"center\" }}>\r\n                        <CustomButton\r\n                            title={viewCompleted ? translate(`$__hideCompleted`, '*') : translate(`$__showCompleted`, '*')}\r\n                            text={viewCompleted ? translate(`$__hideCompleted`, '*') : translate(`$__showCompleted`, '*')}\r\n                            color={viewCompleted ? customApp('menu') : 'lightGray'}\r\n                            icon={viewCompleted ? \"toggle_on\" : \"toggle_off\"}\r\n                            onClick={() => {\r\n                                setViewCompleted(prev => !prev)\r\n                            }}\r\n                            size={'21px'}\r\n                            style={{ padding: \"0px !important\" }}\r\n                        />\r\n                        {unReadeds > 0 ?\r\n                            <CustomButton\r\n                                title={onlyUnReaded ? translate(`$__hideUnreaded`, '*') : translate(`$__showUnreaded`, '*')}\r\n                                text={onlyUnReaded ? translate(`$__hideUnreaded`, '*') : translate(`$__showUnreaded`, '*')}\r\n                                color={onlyUnReaded ? customApp('menu') : 'lightGray'}\r\n                                icon={onlyUnReaded ? \"toggle_on\" : \"toggle_off\"}\r\n                                onClick={() => {\r\n                                    setOnlyUnReaded(prev => !prev)\r\n                                }}\r\n                                badgeContent={unReadeds}\r\n                                size={'21px'}\r\n                                style={{ marginLeft: \"7px\", padding: \"0px !important\" }}\r\n                            />\r\n                            : <React.Fragment></React.Fragment>\r\n                        }\r\n                        <div\r\n                            style={{\r\n                                marginLeft: 15\r\n                            }}\r\n                        >\r\n                            <CustomButton\r\n                                title={!reduxStore.getState().controls.deleted ? translate(\"$__showDeleted\") : translate(\"$__hideDeleted\")}\r\n                                color={!reduxStore.getState().controls.deleted ? 'lightgray' : 'red'}\r\n                                load={loadingDeleted}\r\n                                icon={\"recycling\"}\r\n                                onClick={() => {\r\n                                    setShowDeleted(prev => !prev)\r\n                                    props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                        ...reduxStore.getState().controls,\r\n                                        deleted: !showDeleted\r\n                                    })\r\n                                }}\r\n                                size={'21px'}\r\n                                style={{ padding: \"0px !important\" }}\r\n                            />\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </GridItem>\r\n            <GridItem md={12} style={{\r\n                marginLeft: \"-30px\"\r\n            }}>\r\n                <AgileOverview\r\n                    nodeId={hashs[0] || null}\r\n                    showCompleted={viewCompleted}\r\n                    showColors={viewColors}\r\n                    onlyUnReaded={onlyUnReaded}\r\n                    styles={{\r\n                        discountHeight: 140\r\n                    }}\r\n                />\r\n            </GridItem>\r\n        </div>\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    groupByColor: store.db.groupByColor,\r\n    orderByTitle: store.db.orderByTitle,\r\n    orderByTitlePosition: store.db.orderByTitlePosition,\r\n});\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","import React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\n\n//COMPONENTS\nimport Card from \"components/Card\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\nimport HeaderWithIcon from \"components/Header/withIcon\";\n\n//@MATERIAL\nimport TablePagination from '@material-ui/core/TablePagination';\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/InsightBoards.js\";\nimport InsightsIcon from \"assets/icons/Ideas\";\n\n//FUNCTIONS\nimport {\n    translate\n} from \"functions/\";\nimport { customApp } from \"functions\";\n\nfunction Component(props) {\n    const { classes } = props\n    const { db, search } = reduxStore.getState()\n    const [page, setPage] = React.useState(0)\n    const [limit, setLimit] = React.useState(25)\n    const [locked, setLocked] = React.useState(false)\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    let radarCards = {}\n\n    if (hashs[0].length === 36) {\n        radarCards = Object.keys(db.cards)\n            .filter(a => db.cards[a]._parent && db.cards[a]._parent === hashs[0] && db.cards[a].type === 'link' && !db.cards[a].deleted)\n            .sort((a, b) => {\n                if (db.cards[a].created_at > db.cards[b].created_at)\n                    return -1\n                return 0\n            })\n            .map(a => db.cards[a])\n        radarCards = radarCards.filter(a =>\n        ((a.description && a.description.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n            || (a.name && a.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n        )).map(a => a)\n    } else {\n        radarCards = Object.keys(db.cards)\n            .filter(a => !db.cards[a]._parent && db.cards[a].type === 'link')\n            .sort((a, b) => {\n                if (db.cards[a].created_at > db.cards[b].created_at)\n                    return -1\n                return 0\n            })\n            .map(a => db.cards[a])\n        radarCards = radarCards.filter(a =>\n        ((a.description && a.description.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n            || (a.name && a.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n        )).map(a => a)\n    }\n\n\n\n    return (\n        <div style={{ position: 'relative', justifyContent: 'space-between', margin: 'auto', width: '100%' }}>\n            {/* <HeaderWithIcon\n                title={`radar`}\n                icon={'settings_input_antenna'}\n                fontSize='20px'\n                color={customApp('menu')}\n            /> */}\n            {Object.keys(radarCards).length > 25 &&\n                <div style={{\n                    position: \"relative\",\n                    float: 'left',\n                    width: '100%',\n                    left: '0px',\n                    right: '0px',\n                    padding: '15px',\n                    display: 'flex',\n                    alignItems: 'center',\n                    justifyContent: 'center'\n                }}>\n                    {/* PAGINATION */}\n                    {translate('$__page')} {page + 1} {translate('$__of')} {Math.ceil(Object.keys(radarCards).length / limit)}\n                    <div style={{ display: 'flex', alignItems: 'center' }}>\n                        <TablePagination\n                            component=\"div\"\n                            count={Object.keys(radarCards).length}\n                            page={page}\n                            onChangePage={(event, newPage) => {\n                                setPage(newPage)\n                            }}\n                            rowsPerPage={limit}\n                            onChangeRowsPerPage={(event) => {\n                                setLimit(parseInt(event.target.value, 10))\n                            }}\n                            labelRowsPerPage={translate('$__cardsPerPage')}\n                        />\n                    </div>\n                </div>\n            }\n            <GridContainer>\n                {Object.keys(radarCards).map((card, i) => {\n                    if (i <= ((page + 1) * limit) && i >= page * limit)\n                        // if (i < ((page + 1) * limit) && (i > ((page + 1) * limit) - limit))\n                        return (\n                            <GridItem\n                                key={radarCards[card]._id}\n                                xs={12}\n                                sm={6}\n                                md={4}\n                                lg={3}\n                                xl={2}\n                            >\n                                <Card db=\"cards\" data={radarCards[card]} expanded Avatar Resume />\n                            </GridItem>\n                        )\n                })}\n            </GridContainer>\n            {Object.keys(radarCards).length > 25 &&\n                <div style={{\n                    position: \"relative\",\n                    float: 'left',\n                    width: '100%',\n                    left: '0px',\n                    right: '0px',\n                    padding: '15px',\n                    display: 'flex',\n                    alignItems: 'center',\n                    justifyContent: 'center'\n                }}>\n                    {/* PAGINATION */}\n                    {translate('$__page')} {page + 1} {translate('$__of')} {Math.ceil(Object.keys(radarCards).length / limit)}\n                    <div style={{ display: 'flex', alignItems: 'center' }}>\n                        <TablePagination\n                            component=\"div\"\n                            count={Object.keys(radarCards).length}\n                            page={page}\n                            onChangePage={(event, newPage) => {\n                                setPage(newPage)\n                            }}\n                            rowsPerPage={limit}\n                            onChangeRowsPerPage={(event) => {\n                                setLimit(parseInt(event.target.value, 10))\n                            }}\n                            labelRowsPerPage={translate('$__cardsPerPage')}\n                        />\n                    </div>\n                </div>\n            }\n        </div>\n    )\n}\n\nconst mapStateToProps = (store, ownProps) => {\n    return {\n        store: store,\n        ownProps: ownProps\n    };\n};\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","import React, { memo } from 'react';\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n//COMPONENTS\r\nimport Card from \"components/Card\";\r\nimport GridContainer from \"components/Grid/GridContainer\";\r\nimport GridItem from \"components/Grid/GridItem\";\r\n\r\n//IMAGES\r\nimport tour1 from \"assets/img/tour/strategy-pt.png\"\r\n\r\n//FUNCTIONS\r\nimport { getAppAccess } from \"functions/\";\r\n\r\nfunction App(props) {\r\n    const { db, session, search } = reduxStore.getState()\r\n    let AppAccess = getAppAccess()\r\n\r\n    let hashs = window.location.hash.split('/')\r\n    hashs[0] = hashs[0].replace('#', '')\r\n\r\n    let plans = []\r\n\r\n    plans = Object.keys(db.cards).filter(a =>\r\n        db.cards[a].type === 'plan'\r\n        && (\r\n            (\r\n                hashs[1] !== \"trash\"\r\n                && !db.cards[a].deleted\r\n            )\r\n            || (\r\n                hashs[1] === \"trash\"\r\n                && db.cards[a].deleted\r\n            )\r\n        )\r\n    ).sort((a, b) => {\r\n        if (db.cards[a].order && db.cards[b].order && parseInt(db.cards[a].order.low) < parseInt(db.cards[b].order.low))\r\n            return -1\r\n        if (db.cards[a].order && db.cards[b].order && parseInt(db.cards[a].order.low) > parseInt(db.cards[b].order.low))\r\n            return 1\r\n        return 0\r\n    }).map(a => db.cards[a])\r\n\r\n    if (\r\n        (\r\n            AppAccess\r\n            &&\r\n            !AppAccess.owner\r\n            &&\r\n            (\r\n                !AppAccess.planAdmin\r\n                && !AppAccess.planEdit\r\n                && !AppAccess.planRead\r\n                && !AppAccess.planModerate\r\n            )\r\n            &&\r\n            db.cards\r\n            && session\r\n            && session._id\r\n        )\r\n        || !db.adminView\r\n    ) {\r\n        plans = Object.keys(db.cards).filter(a =>\r\n            db.cards[a]\r\n            && db.cards[a].type === 'plan'\r\n            && (\r\n                !db.cards[a].private\r\n                || (\r\n                    db.cards[a].private\r\n                    && db.cards[a]._users\r\n                    && db.cards[a]._users[session._id]\r\n                )\r\n            )\r\n            && (\r\n                (\r\n                    hashs[1] === 'templates'\r\n                    ||\r\n                    (\r\n                        hashs[1] !== 'templates'\r\n                        && db.cards[a]._users\r\n                        && Object.keys(db.cards[a]._users).filter(us => us === session._id).length > 0\r\n                    )\r\n                )\r\n                ||\r\n                (\r\n                    (\r\n                        hashs[1] === 'admin'\r\n                        && db.cards[a]._users\r\n                        && Object.keys(db.cards[a]._users).filter(us => us === session._id).length === 0\r\n                    )\r\n                )\r\n            )\r\n        ).sort((a, b) => {\r\n            if (db.cards[a].order && db.cards[b].order && parseInt(db.cards[a].order.low) < parseInt(db.cards[b].order.low))\r\n                return -1\r\n            return 1\r\n        }).map(a => db.cards[a])\r\n    } else {\r\n        plans = Object.keys(db.cards).filter(a =>\r\n            db.cards[a]\r\n            && db.cards[a].type === 'plan'\r\n            && db.cards[a]._users\r\n            && (\r\n                Object.keys(db.cards[a]._users).filter(us => us === session._id).length > 0\r\n                || (\r\n                    !db.cards[a].private\r\n                    && Object.keys(db.cards[a]._users).filter(us => us !== session._id).length > 0\r\n                )\r\n            )\r\n        ).sort((a, b) => {\r\n            if (db.cards[a].order && db.cards[b].order && parseInt(db.cards[a].order.low) < parseInt(db.cards[b].order.low))\r\n                return -1\r\n            return 1\r\n        }).map(a => db.cards[a])\r\n    }\r\n\r\n    if (search.text)\r\n        plans = plans.filter(fil => {\r\n            if (\r\n                fil\r\n                && fil.name\r\n                && fil.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1\r\n            )\r\n                return true\r\n            return false\r\n        }).map(res => res)\r\n    plans = plans.filter(fil => {\r\n        if (\r\n            (\r\n                fil\r\n                && fil.status\r\n                && search.cards.status[fil.status]\r\n            )\r\n            ||\r\n            (\r\n                !fil.status\r\n                &&\r\n                (\r\n                    search.cards.status['notStarted']\r\n                )\r\n            )\r\n        )\r\n            return true\r\n        return false\r\n    }).map(res => res)\r\n\r\n    plans = plans.filter(fil => {\r\n        if (\r\n            (\r\n                fil\r\n                && fil.priority\r\n                && search.cards.priority[fil.priority]\r\n            )\r\n            ||\r\n            (\r\n                search.cards.priority['null']\r\n                && !fil.priority\r\n            )\r\n        )\r\n            return true\r\n        return false\r\n    }).map(res => res)\r\n\r\n\r\n    if (Object.keys(search.users.selected).length > 0)\r\n        plans = plans.filter(fil => {\r\n            let result = false\r\n            if (search.users.selected['unassigned'] && (!fil._users || Object.keys(fil._users).length === 0)) {\r\n                result = true\r\n            } else if (!search.users.selected['unassigned']\r\n                && fil\r\n                && fil._users\r\n                && Object.keys(fil._users).length > 0\r\n            ) {\r\n                Object.keys(fil._users).filter(a => {\r\n                    if (search.users.selected[a])\r\n                        result = true\r\n                })\r\n                return result\r\n            }\r\n        }).map(res => res)\r\n\r\n    if (Object.keys(search.units.selected).length > 0) {\r\n        plans = plans.filter(fil => {\r\n            if (search.units.selected['unassigned'] && !fil.client)\r\n                return true\r\n            if (fil.client && search.units.selected[fil.client] && search.units.selected[fil.client] === true)\r\n                return true\r\n        }).map(res => res)\r\n    }\r\n    if (search.tags.length > 0) {\r\n        plans = plans.filter(fil =>\r\n            fil._tags && fil._tags.length > 0 && fil._tags.filter(tag => {\r\n                let result = false\r\n                search.tags.map(tagFilter => {\r\n                    if (tagFilter.value === tag.value)\r\n                        result = true\r\n                })\r\n                return result\r\n            }\r\n            ).length > 0\r\n        ).map(res => res)\r\n    }\r\n\r\n\r\n    return (\r\n        <GridContainer style={{ marginTop: '7px' }} >\r\n            {\r\n                plans && plans.length > 0 && plans\r\n                    .filter(a => {\r\n                        if (\r\n                            (\r\n                                !a._planId\r\n                                || (\r\n                                    a._planId\r\n                                    && plans.filter(pl => pl._id === a._planId).length === 0\r\n                                )\r\n                            )\r\n                            &&\r\n                            (\r\n                                (\r\n                                    (\r\n                                        hashs[1] !== 'templates'\r\n                                        && (\r\n                                            !a.isTemplate\r\n                                            ||\r\n                                            (a.isTemplate && hashs[1] === 'trash')\r\n                                        )\r\n                                    )\r\n                                    ||\r\n                                    (\r\n                                        hashs[1] === 'templates'\r\n                                        && a.isTemplate\r\n                                    )\r\n                                )\r\n                                &&\r\n                                (\r\n                                    (\r\n                                        hashs[1] === 'archived'\r\n                                        && a.archived\r\n                                    )\r\n                                    ||\r\n                                    (\r\n                                        hashs[1] !== 'archived'\r\n                                        && !a.archived\r\n                                    )\r\n                                )\r\n                                &&\r\n                                (\r\n                                    (\r\n                                        hashs[1] === 'trash'\r\n                                        && a.deleted\r\n                                    )\r\n                                    ||\r\n                                    (\r\n                                        hashs[1] !== 'trash'\r\n                                        && !a.deleted\r\n                                    )\r\n                                )\r\n                            )\r\n                        ) return true\r\n                    }\r\n                    )\r\n                    .sort((a, b) => {\r\n                        if (a.name < b.name) {\r\n                            return -1\r\n                        } else if (a.name > b.name) {\r\n                            return 1\r\n                        } else {\r\n                            return 0\r\n                        }\r\n                    }).map((a) => (\r\n                        <GridItem\r\n                            key={a._id}\r\n                            xs={12}\r\n                            sm={6}\r\n                            md={4}\r\n                            lg={3}\r\n                            xl={2}\r\n                        >\r\n                            <Card db=\"cards\" data={a} db='cards' Avatar expanded ignoreList />\r\n                        </GridItem>\r\n                    ))\r\n            }\r\n            {db.loaded && (!plans || plans.length === 0) &&\r\n                <div style={{ width: '100%', height: 'calc(100vh - 150px)', display: 'flex', alignItems: 'center', justifyContent: 'center' }} >\r\n                    <img src={tour1} />\r\n                </div>\r\n            }\r\n        </GridContainer>\r\n    )\r\n}\r\n\r\n\r\nconst mapStateToProps = (store) => {\r\n    let plans = Object.keys(store.db.cards).filter(c => store.db.cards[c].type === 'plan')\r\n    return ({\r\n        store: {\r\n            plans\r\n        }\r\n    })\r\n}\r\n\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(memo(App))","//CORE\nimport React from \"react\"\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport Badge from \"components/Icon/Badge\"\nimport CardTags from \"components/Tags/Card\"\nimport Icon from \"components/Icon\"\nimport UserBadge from \"components/Badge/user\"\nimport MoreMenu from \"components/MoreMenu/\"\nimport Card from \"components/Card\"\n\n\n//@MATERIAL\nimport Tooltip from \"@material-ui/core/Tooltip\"\nimport Avatar from \"@material-ui/core/Avatar\"\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\"\nimport { withStyles } from \"@material-ui/core/styles\"\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule.js\"\n\n//IMAGES\nimport UserCover from \"@material-ui/icons/Person\"\nimport ClientCover from \"@material-ui/icons/Business\"\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\"\n// import { loadUsers } from \"functions/loadData\"\nimport api from \"api/\"\n\n\nfunction Component(props) {\n    const { data, classes } = props\n    const { db, session, usersStatus } = reduxStore.getState()\n    const [mounted, setMounted] = React.useState(false)\n    const [ImagePreview, setImagePreview] = React.useState(null)\n\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true)\n            init()\n        }\n    })\n\n    const init = async () => {\n        // if (data.type === \"client\")\n        //     loadUsers(props, data._id)\n    }\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n\n    let indicators = []\n    let status = {}\n\n    Object.keys(db.cards).filter(fil => {\n        if (db.cards[fil]\n            && db.cards[fil].type !== 'chatGroup'\n            && db.cards[fil].type !== 'link'\n            && db.cards[fil].type !== 'insight'\n            && db.cards[fil]._users\n            && Object.keys(db.cards[fil]._users).length > 0\n            && Object.keys(db.cards[fil]._users).filter(user => user === data._id).length === 1)\n            return true\n        return false\n    }).map(a => {\n        if ((db.dataType.filter(fil => fil.name === db.cards[a].type)[0]\n            && db.dataType.filter(fil => fil.name === db.cards[a].type)[0].module\n            && db.dataType.filter(fil => fil.name === db.cards[a].type)[0].module !== \"swot\"\n        )\n            || (\n                db.cards[a]\n                && db.cards[a].type\n                && db.dataType.filter(fil => fil.name === db.cards[a].type).length > 0\n                && db.dataType.filter(fil => fil.name === db.cards[a].type)[0].module === \"swot\"\n            )\n        ) {\n            if (db.cards[a] && db.cards[a].status && db.cards[a].status !== 'completed') {\n                status = {\n                    ...status,\n                    [db.cards[a].status]: status && status[db.cards[a].status] ? status[db.cards[a].status] + 1 : 1,\n                    total: status.total ? status.total + 1 : 1,\n                    ['late']: db.cards[a].endDate && moment(new Date(db.cards[a].endDate * 1000)).tz('America/Sao_Paulo').format() <= moment().tz('America/Sao_Paulo').format() ? status['late'] ? status['late'] + 1 : 1 : status['late'] ? status['late'] : 0\n                }\n            } else {\n                status = {\n                    ...status,\n                    ['completed']: status && status['completed'] ? status['completed'] + 1 : 1,\n                    total: status.total ? status.total + 1 : 1\n                }\n            }\n            indicators[db.cards[a].type] = !indicators[db.cards[a].type] ? 1 : indicators[db.cards[a].type] + 1\n        } else {\n            indicators[\"swot\"] = indicators[\"swot\"] == null ? 1 : indicators[\"swot\"] + 1\n        }\n    })\n\n    indicators = []\n    status = {}\n\n    return (\n        props.expanded ?\n            <div style={{\n                boxShadow: \"0 0 3px 3px rgba(0,0,0,0.1)\",\n                position: \"relative\",\n                marginLeft: \"15px\",\n                ...props.onClick ? { cursor: \"pointer\" } : {}\n            }}\n                onClick={props.onClick ? () => { props.onClick() } : null}\n            >\n                <div\n                    style={{\n                        backgroundColor: customApp(\"menu\"),\n                        height: \"43px\",\n                        paddingLeft: \"60px\",\n                        fontSize: \"12px\",\n                        color: \"#FFFFFF\",\n                        fontWeight: \"bold\",\n                        textOverflow: \"ellipsis \",\n                        whiteSpace: \"nowrap\",\n                        overflow: \"hidden\",\n                        display: \"flex\",\n                        alignItems: \"center\",\n                        justifyContent: \"space-between\",\n                        left: \"15px\"\n                    }}>\n                    {data.name ? data.name : data.name}\n                    {!props.resume &&\n                        <div style={{\n                            float: \"right\",\n                            display: \"flex\",\n                            alignItems: \"center\",\n                            marginRight: \"7px\"\n                        }}>\n                            {!props.noActions &&\n                                <div style={{\n                                    float: \"right\",\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                    marginRight: \"7px\"\n                                }}>\n                                    <Icon color={customApp(\"color\")} icon={\"close\"}\n                                        onClick={\n                                            () => {\n                                                history.push(`c#tab/${hashs[1]}`)\n                                            }\n                                        } />\n                                </div>\n                            }\n                        </div>\n                    }\n                </div>\n\n                {(!ImagePreview && data.image) ?\n                    <img\n                        style={{\n                            width: \"70px\",\n                            height: \"70px\",\n                            top: \"-20px\",\n                            left: \"-6px\",\n                            borderRadius: \"50%\",\n                            border: `solid 2px ${customApp(\"color\")}`,\n                            zIndex: \"5 !important\",\n                            position: \"absolute\",\n                            backgroundColor: `${customApp(\"color\")}`,\n                        }}\n                        src={`${data.image ? data.image : (!data.type || data.type === \"user\") ? UserCover : ClientCover}`}\n                        onError={(e) => {\n                            setImagePreview(null)\n                        }}\n                        onLoad={(e) => {\n                            setImagePreview(`${!data.image ? (!data.type || data.type === \"user\") ? UserCover : ClientCover : data.image}`)\n                        }}\n                        width=\"100%\" />\n                    : data.image ?\n                        <div\n                            style={{\n                                width: \"50px\",\n                                height: \"50px\",\n                                top: \"-4px\",\n                                left: \"-13px\",\n                                borderRadius: \"50%\",\n                                border: `solid 2px ${customApp(\"color\")}`,\n                                zIndex: \"5 !important\",\n                                position: \"absolute\",\n                                background: customApp(\"AvatarBackground\"),\n                                backgroundImage: `url(\"${ImagePreview}\")`,\n                                backgroundSize: \"cover\",\n                                backgroundPosition: \"center center\",\n                            }}\n                        >\n                        </div>\n                        :\n                        <div\n                            style={{\n                                width: \"50px\",\n                                height: \"50px\",\n                                top: \"-4px\",\n                                left: \"-13px\",\n                                borderRadius: \"50%\",\n                                border: `solid 2px ${customApp(\"color\")}`,\n                                zIndex: \"5 !important\",\n                                position: \"absolute\",\n                                background: customApp(\"AvatarBackground\"),\n                                display: \"flex\",\n                                alignItems: \"center\",\n                                justifyContent: \"center\"\n                            }}\n                        >\n                            {(!data.type || data.type === \"user\") ?\n                                <Icon size=\"16px\" color=\"rgba(250,250,250,0.77)\">person</Icon>\n                                :\n                                <Icon size=\"16px\" color=\"rgba(250,250,250,0.77)\">business</Icon>\n                            }\n\n                        </div>\n                }\n            </div>\n            :\n            <div style={{\n                marginTop: \"33px\",\n                width: props.style && props.style.width ? props.style.width : \"calc(100% - 15px)\",\n                minHeight: \"120px\",\n                backgroundColor: \"#FFFFFF\",\n                boxShadow: \"0 0 3px 3px rgba(0,0,0,0.1)\",\n                position: \"relative\",\n                marginLeft: props.style && props.style.marginLeft ? props.style.marginLeft : \"15px\",\n            }}\n            >\n\n                <div\n                    style={{\n                        backgroundColor: customApp(\"menu\"),\n                        height: \"43px\",\n                        paddingLeft: \"95px\",\n                        fontSize: \"12px\",\n                        color: \"#FFFFFF\",\n                        fontWeight: \"bold\",\n                        display: \"flex\",\n                        alignItems: \"center\",\n                        justifyContent: \"space-between\"\n                    }}>\n                    <div style={{\n                        maxWidth: \"calc(100% - 10px)\",\n                        textOverflow: \"ellipsis \",\n                        whiteSpace: \"nowrap\",\n                        overflow: \"hidden\",\n                    }}>\n                        {data.name ? data.name : data.name}\n                    </div>\n                    {!props.resume &&\n                        <div style={{\n                            float: \"right\",\n                            display: \"flex\",\n                            alignItems: \"center\",\n                            marginRight: \"7px\"\n                        }}>\n                            {(!props.noActions\n                                && (\n                                    !data.independentAccount\n                                    ||\n                                    (\n                                        data.independentAccount\n                                        && session\n                                        && session.matrixAdmin\n                                    )\n                                )\n                                && (\n                                    !data._parent\n                                    ||\n                                    (\n                                        data._parent\n                                        && reduxStore.getState().db.users[data._parent]\n                                        && !reduxStore.getState().db.users[data._parent].independentAccount\n                                    )\n                                )\n\n                            ) &&\n                                <div style={{\n                                    float: \"right\",\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                    marginRight: \"7px\"\n                                }}>\n                                    <Icon color={customApp(\"color\")} icon={\"create\"}\n                                        onClick={\n                                            () => {\n                                                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                    ...db.sideModule,\n                                                    id: data._id,\n                                                    activeModule: \"userEdit\",\n                                                    db: \"users\",\n                                                    data: {\n                                                        type: \"user\",\n                                                        ...data,\n                                                    }\n                                                })\n                                            }\n                                        } />\n                                </div>\n                            }\n                            {!props.noActions && data.type !== \"user\" &&\n                                <div style={{\n                                    float: \"right\",\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                    marginRight: \"7px\"\n                                }}>\n                                    <Icon color={customApp(\"color\")} icon={\"contacts\"}\n                                        onClick={\n                                            () => {\n                                                history.push(`c#tab/units/${data._id}`)\n                                            }\n                                        } />\n                                </div>\n                            }\n                            {!props.noActions && data.type === \"sic\" &&\n                                <div style={{\n                                    float: \"right\",\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                    marginRight: \"7px\"\n                                }}>\n                                    <Icon color={customApp(\"color\")} icon={\"badge\"}\n                                        onClick={\n                                            () => {\n                                                history.push(`c#tab/units/${data._id}`)\n                                            }\n                                        } />\n                                </div>\n                            }\n                        </div>\n                    }\n                </div>\n                {(data.image && (!ImagePreview || (data.image && data.image !== ImagePreview))) ?\n                    <img\n                        style={{\n                            width: \"90px\",\n                            height: \"90px\",\n                            top: \"-24px\",\n                            left: \"-6px\",\n                            borderRadius: \"50%\",\n                            border: `solid 2px ${customApp(\"color\")}`,\n                            zIndex: \"5 !important\",\n                            position: \"absolute\",\n                            backgroundColor: `${customApp(\"color\")}`,\n                        }}\n                        src={`${data.image ? data.image : (!data.type || data.type === \"user\") ? UserCover : ClientCover}`}\n                        onError={(e) => {\n                        }}\n                        onLoad={(e) => {\n                            setImagePreview(`${data.image ? data.image : null}`)\n                        }}\n                        width=\"100%\" />\n                    : data.image ?\n                        <div\n                            style={{\n                                width: \"90px\",\n                                height: \"90px\",\n                                top: \"-24px\",\n                                left: \"-6px\",\n                                borderRadius: \"50%\",\n                                border: `solid 2px ${customApp(\"color\")}`,\n                                zIndex: \"5 !important\",\n                                position: \"absolute\",\n                                background: customApp(\"AvatarBackground\"),\n                                backgroundImage: `url(\"${ImagePreview}\")`,\n                                backgroundSize: \"cover\",\n                                backgroundPosition: \"center center\",\n                            }}\n                        >\n                        </div>\n                        :\n                        <div\n                            style={{\n                                width: \"90px\",\n                                height: \"90px\",\n                                top: \"-24px\",\n                                left: \"-6px\",\n                                borderRadius: \"50%\",\n                                border: `solid 2px ${customApp(\"color\")}`,\n                                zIndex: \"5 !important\",\n                                position: \"absolute\",\n                                background: customApp(\"AvatarBackground\"),\n                                display: \"flex\",\n                                alignItems: \"center\",\n                                justifyContent: \"center\"\n                            }}\n                        >\n                            {(!data.type || data.type === \"user\") ?\n                                <Icon size=\"33px\" color=\"rgba(250,250,250,0.77)\">person</Icon>\n                                :\n                                <Icon size=\"33px\" color=\"rgba(250,250,250,0.77)\">business</Icon>\n                            }\n\n                        </div>\n                }\n                {props.children ?\n                    props.children\n                    :\n                    <React.Fragment>\n                        {data?._access?.enabled && data.type === \"user\" ?\n                            <div\n                                style={{\n                                    width: \"100%\",\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                    justifyContent: \"flex-end\",\n                                    fontSize: 12,\n                                    color: customApp(\"medium\"),\n                                    padding: \"3px 7px\"\n                                }}>\n                                {data?._access?.admin ?\n                                    <React.Fragment>\n                                        <Icon color={customApp(\"medium\")} size={\"12px\"}>supervisor_account</Icon><span>{translate(\"$__supervisorAccount\")}</span>\n                                    </React.Fragment>\n                                    :\n                                    <React.Fragment>\n                                        <Icon color={customApp(\"medium\")} size={\"12px\"}>supervised_user_circle</Icon><span>{translate(\"$__guest\")}</span>\n                                    </React.Fragment>\n                                }\n                            </div>\n                            : data.type === \"user\" && data._access && !data._access.enabled ?\n                                <div style={{ width: \"100%\", display: \"flex\", alignItems: \"center\", color: \"red\", fontSize: 10 }}>{translate(\"$__notEnabled\")}</div>\n                                : <React.Fragment></React.Fragment>\n                        }\n                        {data.groups && data.groups.length > 0 ?\n                            <div style={{\n                                position: \"relative\",\n                                width: \"100%\",\n                                fontSize: \"12px\",\n                                color: customApp(\"mediumText\"),\n                                paddingLeft: \"94px\",\n                                paddingRight: \"15px\",\n                                marginTop: \"15px\",\n                            }}>\n                                {data.groups\n                                    .filter(a => a.value)\n                                    .sort((a, b) => {\n                                        if (a.label < b.label)\n                                            return -1\n                                        return 1\n                                    }).map((item, i) => `${i > 0 ? ` / ` : ``}${item.label}`)\n                                }\n                            </div>\n                            : data.type === \"user\" ?\n                                <div style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    fontSize: \"12px\",\n                                    color: customApp(\"mediumText\"),\n                                    paddingLeft: \"94px\",\n                                    marginTop: \"15px\",\n                                }}>\n                                    {translate(`$__doesntBelongToAGroup`)}\n                                </div>\n                                : <React.Fragment></React.Fragment>\n                        }\n                        {!props.noShowUsers && (data.type !== 'user') &&\n                            <div style={{ marginTop: \"11px\", width: \"100%\", padding: \"15px\" }}>\n                                <ClientInfo id={data._id} {...props} />\n                            </div>\n                        }\n                        {(data.type === 'user' && Object.keys(indicators).length > 0) ?\n                            <div style={{\n                                display: \"flex\",\n                                width: \"100%\",\n                                paddingLeft: \"15px\",\n                                paddingRight: \"15px\",\n                                flexFlow: \"wrap\",\n                                paddingTop: 15,\n                                paddingBottom: 15\n                            }}>\n                                {Object.keys(indicators).map((a, i) => (\n                                    String(a) !== \"null\" && String(a) !== \"undefined\" ?\n                                        <Badge\n                                            overlap=\"rectangular\"\n                                            key={i}\n                                            style={{\n                                                padding: 3\n                                            }}\n                                            icon={db.dataType.filter(c => c.name === a)[0].icon}\n                                            title={translate(`$__${a}`, 1)}\n                                            size=\"16px\"\n                                            count={indicators[a]}\n                                            disabled\n                                        />\n                                        : null\n                                ))\n                                }\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                        {(data.type === 'user' && status && status.total > 0) ?\n                            <div style={{\n                                display: \"flex\",\n                                width: \"100%\",\n                                paddingLeft: \"15px\",\n                                paddingRight: \"15px\",\n                                flexFlow: \"wrap\",\n                                paddingTop: 15,\n                                paddingBottom: 15\n                            }}>\n                                <fieldset style={{\n                                    padding: 7,\n                                    width: \"calc(100% - 14px)\"\n                                }}>\n                                    <legend style={{\n                                        color: \"lightgray\",\n                                        fontSize: 12\n                                    }}>{translate(\"$__openActivities\")}</legend>\n                                    <h3>\n                                        <small>{translate('$__total', 1)}: {status.total}</small>\n                                    </h3>\n                                    {db.status.filter(st => st.value !== \"completed\").map((st, index) => {\n                                        return (\n                                            <div key={`${index}_${st.value}`} style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                                <div style={{ display: 'flex' }}>\n                                                    <Icon color={st.color}>{st.icon}</Icon>\n                                                    <span style={{ marginLeft: '15px' }} >{translate(st.label, 1)}</span>\n                                                </div>\n                                                <div>\n                                                    {status[st.value] ? status[st.value] : 0}\n                                                </div>\n                                            </div>\n                                        )\n                                    })}\n                                    <div style={{ color: 'black', display: 'flex', justifyContent: 'space-between', height: '30px', alignItems: 'center', width: '100%' }}>\n                                        <div style={{ display: 'flex' }}>\n                                            <Icon color={'red'}>assignment_late</Icon>\n                                            <span style={{ marginLeft: '15px' }} >{translate('$__late', 1)}</span>\n                                        </div>\n                                        <div>\n                                            {status.late}\n                                        </div>\n                                    </div>\n                                </fieldset>\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                        {!props.resume &&\n                            <CardTags options={data.tags} showOptions={false} />\n                        }\n                        {props.resume &&\n                            <div>\n                                <UserBadge\n                                    overlap=\"circular\"\n                                    anchorOrigin={{\n                                        vertical: \"top\",\n                                        horizontal: \"left\",\n                                    }}\n                                    userId={data._id}\n                                // variant={usersStatus.users && usersStatus.users[data._id] && usersStatus.users[data._id].status ? \"dot\" : \"standard\"}\n                                // status={usersStatus.users && usersStatus.users[data._id] && usersStatus.users[data._id].status ? usersStatus.users[data._id].status : null}\n                                >\n                                    <Icon size=\"27px\">chat</Icon>\n                                </UserBadge>\n                            </div>\n                        }\n                    </React.Fragment>\n                }\n\n            </div >\n    )\n}\n\nconst ClientInfo = (props) => {\n    const { users } = reduxStore.getState().db\n    const { cards } = reduxStore.getState().db\n\n    let plans = Object.keys(cards)\n        .filter(card =>\n            cards[card].client === props.id\n            && cards[card].type === 'plan'\n            && !cards[card].deleted\n            && !cards[card].archived\n            && !cards[card].isTemplate\n            && (\n                (\n                    !props.completed\n                    && cards[card].status !== 'completed'\n                )\n                ||\n                (\n                    props.completed\n                    && cards[card].status === 'completed'\n                )\n            )\n        )\n        .sort((a, b) => {\n            if (a.name < b.name) {\n                return -1\n            } else if (a.name > b.name) {\n                return 1\n            } else {\n                return 0\n            }\n        })\n        .map(card => cards[card])\n\n    return (\n        <div style={{\n            display: \"flex\",\n            alignItems: \"center\",\n            flexWrap: \"wrap\",\n        }}>\n            {Object.keys(users).filter(u => users[u] && users[u]._parent === props.id).length > 0 &&\n                <React.Fragment>\n                    <div style={{ width: \"100%\" }}>{translate(\"$__users\", 1)}:</div>\n                    <AvatarGroup max={12}>\n                        {Object.keys(users).filter(u => users[u] && users[u]._parent === props.id).map((a, i) =>\n                            <Tooltip\n                                title={users[a].name}\n                                key={a}\n                            >\n                                <Avatar\n                                    alt={users[a].name}\n                                    src={users[a].image || null}\n                                    style={{ width: \"23px\", height: \"23px\" }}>\n                                    {users[a].name.substr(0, 1)}\n                                </Avatar>\n                            </Tooltip>\n                        )\n                        }\n                    </AvatarGroup>\n                </React.Fragment>\n            }\n            {plans.length > 0 &&\n                <div style={{ width: \"100%\" }}>\n                    {plans.map((a, i) => {\n                        return (\n                            <div key={`${a._id}-${i}`}>\n                                <Card data={a} db=\"cards\" Avatar={false} expanded={false} ignoreList notGlobalExpanded />\n                            </div>\n                            // <div\n                            //     key={a._id}\n                            //     style={{\n                            //         marginTop: \"7px\",\n                            //         alignItems: \"center\",\n                            //         display: \"flex\",\n                            //         cursor: \"pointer\",\n                            //         overflow: \"hidden\",\n                            //         textOverflow: \"ellipses\",\n                            //         width: \"100%\",\n                            //         padding: \"3px\",\n                            //         backgroundColor: \"rgba(179,179,179,0.1)\",\n                            //         borderRadius: \"3px\",\n                            //         whiteSpace: \"nowrap\"\n                            //     }}\n                            //     onClick={(e) => {\n                            //         history.push(`sp#${a._id}/dashboard`)//#CORRECT\n                            //     }}\n                            // >\n                            //     <Avatar\n                            //         alt={a.name} src={a.image || null}\n                            //         style={{\n                            //             width: \"22px\",\n                            //             height: \"22px\"\n                            //         }}>\n                            //         {a.name.substr(0, 1)}\n                            //     </Avatar>\n                            //     <span style={{ marginLeft: '7px' }}>\n                            //         {a.name}\n                            //     </span>\n                            // </div>\n                        )\n                    })}\n                </div>\n            }\n        </div>\n    )\n}\nconst mapStateToProps = store => ({\n    usersStatus: store.usersStatus,\n    users: store.db.users\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","import React from \"react\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n//COMPONENTS\r\nimport Card from \"components/Card\"\r\nimport GridContainer from \"components/Grid/GridContainer\"\r\nimport GridItem from \"components/Grid/GridItem\"\r\nimport HeaderWithIcon from \"components/Header/withIcon\"\r\nimport UserCard from \"components/User/card\";\r\n\r\n\r\n//IMAGES\r\nimport tour1 from \"assets/img/tour/strategy-pt.png\"\r\n\r\n//FUNCTIONS\r\nimport { getAppAccess, customApp, translate } from \"functions/\"\r\n\r\nfunction App(props) {\r\n    const { db, session, search } = reduxStore.getState()\r\n    // const { plans } = props\r\n\r\n    React.useEffect(() => {\r\n\r\n    }, [])\r\n\r\n    let AppAccess = getAppAccess()\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace(\"#\", \"\")\r\n\r\n    let plans = []\r\n\r\n    plans = Object.keys(db.cards).filter(a =>\r\n        db.cards[a].type === \"plan\"\r\n        && !db.cards[a].deleted\r\n        && !db.cards[a].isTemplate\r\n        && !db.cards[a].archived\r\n        &&\r\n        (\r\n            (\r\n                !props.completed\r\n                && db.cards[a].status !== \"completed\"\r\n            )\r\n            ||\r\n            (\r\n                props.completed\r\n                && db.cards[a].status === \"completed\"\r\n            )\r\n\r\n        )\r\n    ).sort((a, b) => {\r\n        if (db.cards[a].order && db.cards[b].order && parseInt(db.cards[a].order.low) < parseInt(db.cards[b].order.low))\r\n            return -1\r\n        if (db.cards[a].order && db.cards[b].order && parseInt(db.cards[a].order.low) > parseInt(db.cards[b].order.low))\r\n            return 1\r\n        return 0\r\n    }).map(a => db.cards[a])\r\n\r\n    if (\r\n        (\r\n            AppAccess\r\n            &&\r\n            !AppAccess.owner\r\n            &&\r\n            (\r\n                !AppAccess.planAdmin\r\n                && !AppAccess.planEdit\r\n                && !AppAccess.planRead\r\n                && !AppAccess.planModerate\r\n            )\r\n            &&\r\n            db.cards\r\n            && session\r\n            && session._id\r\n        )\r\n        || !db.adminView\r\n    ) {\r\n\r\n        plans = plans.filter(a =>\r\n            a.type === \"plan\"\r\n            && a && a._users\r\n            && Object.keys(a._users).filter(us =>\r\n                us === session._id\r\n                || (\r\n                    reduxStore.getState().db.users[us]\r\n                    && reduxStore.getState().db.users[us].groups\r\n                    && reduxStore.getState().db.users[us].groups.filter(fil =>\r\n                        a._groups\r\n                        && a._groups[fil.value]\r\n                    ).length > 0\r\n                )\r\n            ).length > 0\r\n\r\n        ).sort((a, b) => {\r\n            if (a && a.order && b && b.order && parseInt(a.order.low) < parseInt(b.order.low))\r\n                return -1\r\n            return 1\r\n        }).map(a => a)\r\n    } else {\r\n        plans = plans.filter(a =>\r\n            a.type === \"plan\"\r\n            && a\r\n            && a._users\r\n            && (\r\n                Object.keys(a._users).filter(us =>\r\n                    us === session._id\r\n                    || (\r\n                        reduxStore.getState().db.users[us]\r\n                        && reduxStore.getState().db.users[us].groups\r\n                        && reduxStore.getState().db.users[us].groups.filter(fil =>\r\n                            a._groups\r\n                            && a._groups[fil.value]\r\n                        ).length > 0\r\n                    )\r\n                ).length > 0\r\n                || (\r\n                    !a.private\r\n                    && Object.keys(a._users).filter(us => us !== session._id).length > 0\r\n                )\r\n            )\r\n        ).sort((a, b) => {\r\n            if (a.order && db.cards[b].order && parseInt(a.order.low) < parseInt(db.cards[b].order.low))\r\n                return -1\r\n            return 1\r\n        }).map(a => a)\r\n    }\r\n\r\n    if (search.text)\r\n        plans = plans.filter(fil => {\r\n            if (fil && fil.name && fil.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\r\n                return true\r\n            return false\r\n        }).map(res => res)\r\n    plans = plans.filter(fil => {\r\n        if ((fil && fil.status && search.cards.status[fil.status]) || (!fil.status && (search.cards.status[\"notStarted\"])))\r\n            return true\r\n        return false\r\n    }).map(res => res)\r\n\r\n    plans = plans.filter(fil => {\r\n        if ((fil && fil.priority && search.cards.priority[fil.priority]) || (search.cards.priority[\"null\"] && !fil.priority))\r\n            return true\r\n        return false\r\n    }).map(res => res)\r\n\r\n\r\n    if (Object.keys(search.users.selected).length > 0)\r\n        plans = plans.filter(fil => {\r\n            let result = false\r\n            if (search.users.selected[\"unassigned\"] && (!fil._users || Object.keys(fil._users).length === 0)) {\r\n                result = true\r\n            } else if (!search.users.selected[\"unassigned\"]\r\n                && fil\r\n                && fil._users\r\n                && Object.keys(fil._users).length > 0\r\n            ) {\r\n                Object.keys(fil._users).filter(a => {\r\n                    if (search.users.selected[a])\r\n                        result = true\r\n                })\r\n                return result\r\n            }\r\n        }).map(res => res)\r\n\r\n    if (Object.keys(search.units.selected).length > 0) {\r\n        plans = plans.filter(fil => {\r\n            if (search.units.selected[\"unassigned\"] && !fil.client)\r\n                return true\r\n            if (fil.client && search.units.selected[fil.client] && search.units.selected[fil.client] === true)\r\n                return true\r\n        }).map(res => res)\r\n    }\r\n    if (search.tags.length > 0) {\r\n        plans = plans.filter(fil =>\r\n            fil._tags && fil._tags.length > 0 && fil._tags.filter(tag => {\r\n                let result = false\r\n                search.tags.map(tagFilter => {\r\n                    if (tagFilter.value === tag.value)\r\n                        result = true\r\n                })\r\n                return result\r\n            }\r\n            ).length > 0\r\n        ).map(res => res)\r\n    }\r\n\r\n    return (\r\n        <div >\r\n            {plans.filter(pl => pl._isFavorite).length > 0 &&\r\n                <div\r\n                    style={{ marginBottom: \"33px\" }}\r\n                >\r\n                    <HeaderWithIcon\r\n                        title={translate(`$__myFavoritePlans`, 1)}\r\n                        icon={\"favorite\"}\r\n                        color={customApp(\"menu\")}\r\n                    />\r\n                    <GridContainer>\r\n                        <Plans plans={plans.filter(pl =>\r\n                            pl._isFavorite\r\n                            && !pl.private\r\n                        ).map(res => res)} />\r\n                    </GridContainer>\r\n                </div>\r\n            }\r\n            {plans.filter(pl => pl._isFavorite && pl.private).length > 0 &&\r\n                <div\r\n                    style={{ marginBottom: \"33px\" }}\r\n                >\r\n                    <HeaderWithIcon\r\n                        title={translate(`$__myFavoritePrivatePlans`, 1)}\r\n                        icon={\"private_connectivity\"}\r\n                        color={customApp(\"menu\")}\r\n                    />\r\n                    <GridContainer>\r\n                        <Plans plans={plans.filter(pl =>\r\n                            pl._isFavorite\r\n                            && pl.private\r\n                        ).map(res => res)} />\r\n                    </GridContainer>\r\n                </div>\r\n            }\r\n            {plans.filter(pl => pl.client && db.users[pl.client]).length > 0 &&\r\n                <div\r\n                    style={{ marginBottom: \"33px\" }}\r\n                >\r\n                    <HeaderWithIcon\r\n                        title={translate(`$__customerPlanning`, 1)}\r\n                        icon={\"business\"}\r\n                        color={customApp(\"menu\")}\r\n                    />\r\n                    <GridContainer>\r\n                        <Client plans={plans.filter(pl => pl.client).map(res => res)} completed={props.completed ? true : false} />\r\n                    </GridContainer>\r\n                </div>\r\n            }\r\n\r\n            {plans.filter(pl => !pl.client && !pl.private).length > 0 &&\r\n                <div\r\n                    style={{ marginBottom: \"33px\" }}\r\n                >\r\n                    <HeaderWithIcon\r\n                        title={translate(`$__accountPlanning`, 1)}\r\n                        icon={\"work\"}\r\n                        color={customApp(\"menu\")}\r\n                    />\r\n                    <GridContainer>\r\n                        <Plans plans={plans.filter(pl => !pl.client && !pl.private).map(res => res)} />\r\n                    </GridContainer>\r\n                </div>\r\n            }\r\n            {plans.filter(pl => pl.client && !db.users[pl.client]).length > 0 &&\r\n                <div\r\n                    style={{ marginBottom: \"33px\" }}\r\n                >\r\n                    <HeaderWithIcon\r\n                        title={translate(`$__consultingPlanning`, 1)}\r\n                        icon={\"work\"}\r\n                        color={customApp(\"menu\")}\r\n                    />\r\n                    <GridContainer>\r\n                        <Plans plans={plans.filter(pl => pl.client && !db.users[pl.client]).map(res => res)} />\r\n                    </GridContainer>\r\n                </div>\r\n            }\r\n            {plans.filter(pl => !pl.client && pl.private).length > 0 &&\r\n                <div\r\n                    style={{ marginBottom: \"33px\" }}\r\n                >\r\n                    <HeaderWithIcon\r\n                        title={translate(`$__privatePlanning`, 1)}\r\n                        icon={\"private_connectivity\"}\r\n                        color={customApp(\"menu\")}\r\n                    />\r\n                    <GridContainer>\r\n                        <Plans plans={plans.filter(pl => !pl.client && pl.private).map(res => res)} />\r\n                    </GridContainer>\r\n                </div>\r\n            }\r\n            {db.loaded && (!plans || plans.length === 0) &&\r\n                <div style={{ width: \"100%\", height: \"calc(100vh - 150px)\", display: \"flex\", alignItems: \"center\", justifyContent: \"center\" }} >\r\n                    <img src={tour1} />\r\n                </div>\r\n            }\r\n        </div>\r\n    )\r\n}\r\nconst Client = (props) => {\r\n    const { db } = reduxStore.getState()\r\n\r\n    let units = []\r\n    props.plans.map(a => {\r\n        if (units.filter(c => c._id === a.client).length === 0 && db.users[a.client])\r\n            units.push(db.users[a.client])\r\n    })\r\n    return (\r\n        <React.Fragment>\r\n            {units.sort((a, b) => {\r\n                let nameA = a.displayName || a.name\r\n                let nameB = b.displayName || b.name\r\n                if (nameA < nameB)\r\n                    return -1\r\n                if (nameA > nameB)\r\n                    return 1\r\n                return 0\r\n            }).map((a, ai) => (\r\n                <GridItem\r\n                    key={`${a._id}-${ai}`}\r\n                    xs={12}\r\n                    sm={6}\r\n                    md={4}\r\n                    lg={4}\r\n                    xl={3}\r\n                    style={{ height: \"calc(100% - 34px)\", padding: \"0px 0px !important\" }}\r\n                >\r\n                    <UserCard\r\n                        data={a}\r\n                        expanded={false}\r\n                        noActions\r\n                        style={{ height: \"calc(100% - 34px)\", margin: 0 }}\r\n                        completed={props.completed ? true : false}\r\n                    />\r\n                </GridItem>\r\n            )\r\n            )}\r\n        </React.Fragment>\r\n    )\r\n}\r\n\r\nconst Plans = (props) => {\r\n    return (\r\n        <React.Fragment>\r\n            {props.plans\r\n                .sort((a, b) => {\r\n                    // console.log(a)\r\n                    if (a.name < b.name) {\r\n                        return -1\r\n                    } else if (a.name > b.name) {\r\n                        return 1\r\n                    }\r\n                    return 0\r\n                })\r\n                .map((a, ai) => (\r\n                    <GridItem\r\n                        key={`${a._id}_${ai}`}\r\n                        xs={12}\r\n                        sm={6}\r\n                        md={4}\r\n                        lg={3}\r\n                        xl={2}\r\n                    >\r\n                        <Card data={a} db=\"cards\" Avatar expanded ignoreList />\r\n                    </GridItem>\r\n                )\r\n                )}\r\n        </React.Fragment>\r\n    )\r\n}\r\n\r\n\r\nconst mapStateToProps = (store, props) => {\r\n    return ({\r\n        ...props,\r\n        cards: store.db.cards\r\n    })\r\n}\r\n\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(App)","import React, { memo } from \"react\"\r\nimport MD5 from \"crypto-js/md5\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\nimport history from \"store/history\"\r\n\r\n//COMPONENTS\r\nimport KanbanBoard from \"components/AgileKanban\";\r\nimport CardsLoader from \"components/Card/loader\"\r\n\r\n\r\n//VIEWS\r\nimport Actions from \"views/StrategyAndPlans/Actions\"\r\nimport BrightAndConnected from \"views/BrightAndConnected/\"\r\nimport Dashboard from \"views/StrategyAndPlans/Dashboard/StrategyAndPlans.js\"\r\nimport InsightBoards from \"views/InsightBoards\"\r\nimport Library from \"views/Library/index.js\"\r\nimport Matrix from \"views/StrategyAndPlans/MATRIX\"\r\nimport Overview from \"views/StrategyAndPlans/Overview\"\r\nimport Radar from \"views/Radar\"\r\n\r\n//DEPENDENCIES\r\nimport Plans from \"./plans\"\r\nimport HomePlans from \"./homePlans\"\r\n\r\nimport {\r\n    planAccountVerify\r\n} from \"functions/cards\"\r\n\r\n\r\nfunction App(props) {\r\n    const { session } = reduxStore.getState()\r\n\r\n    React.useEffect(() => {\r\n        // console.log(\"StrategyAndPlans\")\r\n    }, [])\r\n\r\n\r\n    React.useEffect(() => {\r\n        const scrollTimer = setTimeout(() => {\r\n            document.getElementById(\"mainPannel\").scrollTo(0, 0)\r\n        }, 100)\r\n        return () => {\r\n            clearTimeout(scrollTimer)\r\n        }\r\n    }, [props.history])\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace(\"#\", \"\")\r\n\r\n    if (!window.location.hash.split(\"/\")[0].replace(\"#\", \"\")) {\r\n        history.push(\"sp#tab/home\")\r\n    }\r\n\r\n    let permission = true\r\n\r\n    if (\r\n        hashs[0]\r\n        && hashs[0].length === 36\r\n        && !reduxStore.getState().db.cards[hashs[0]]\r\n    ) {\r\n        permission = false\r\n    }\r\n\r\n    if (\r\n        hashs[0]\r\n        && hashs[0].length === 36\r\n        && reduxStore.getState().db.cards[hashs[0]]\r\n        && !reduxStore.getState().db.cards[hashs[0]].isTemplate\r\n        && (\r\n            reduxStore.getState().db.cards[hashs[0]]._users\r\n            && (\r\n                !reduxStore.getState().db.cards[hashs[0]]._users[session._id]\r\n                && (\r\n                    reduxStore.getState().db.cards[hashs[0]]._account\r\n                    && reduxStore.getState().db.cards[hashs[0]]._account !== MD5(session.account).toString()\r\n                )\r\n            )\r\n        )\r\n    )\r\n        permission = false\r\n\r\n    if (planAccountVerify(hashs[0]))\r\n        permission = planAccountVerify(hashs[0])\r\n\r\n    if (!permission) {\r\n        history.push(\"/deniedAccess\")\r\n        return (\r\n            <React.Fragment></React.Fragment>\r\n        )\r\n    }\r\n\r\n\r\n\r\n    return (\r\n        <div>\r\n            <CardsLoader />\r\n            {(!hashs[0] || (hashs[0] && hashs[0].replace(\"#\", \"\").length !== 36)) && hashs[1] === \"home\" ?\r\n                <React.Fragment>\r\n                    <HomePlans />\r\n                </React.Fragment>\r\n                : (!hashs[0] || (hashs[0] && hashs[0].replace(\"#\", \"\").length !== 36)) && hashs[1] === \"completed\" ?\r\n                    <React.Fragment>\r\n                        <HomePlans completed={true} />\r\n                    </React.Fragment>\r\n                    :\r\n                    (!hashs[0]\r\n                        ||\r\n                        (hashs[0]\r\n                            && hashs[0].replace(\"#\", \"\").length !== 36\r\n                        )\r\n                    )\r\n                    &&\r\n                    <Plans />\r\n            }\r\n            {hashs[0].length === 36 && reduxStore.getState().db.cards[hashs[0].replace(\"#\", \"\")] ?\r\n                <React.Fragment>\r\n                    {hashs[1] && hashs[1] === \"matrix\" &&\r\n                        <Matrix />\r\n                    }\r\n                    {hashs[1] && (hashs[1] === \"actions\" || hashs[1] === \"guidelines\" || hashs[1] === \"objectives\" || hashs[1] === \"goals\")\r\n                        &&\r\n                        <Actions type={hashs[1]} />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"dashboard\" &&\r\n                        <Dashboard />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"overview\" &&\r\n                        <Overview />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"board\" &&\r\n                        <div style={{\r\n                            width: \"100%\"\r\n                        }}>\r\n                            <KanbanBoard\r\n                                nodeId={hashs[0] || null}\r\n                                columProps={{\r\n                                    style: {\r\n                                        height: \"calc(100vh - 190px)\",\r\n                                    }\r\n                                }}\r\n                            />\r\n                        </div>\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"bright-and-connected\" &&\r\n                        <React.Fragment>\r\n                            <BrightAndConnected />\r\n                        </React.Fragment>\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"insight-boards\" &&\r\n                        <InsightBoards />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"radar\" &&\r\n                        <Radar />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"library\" &&\r\n                        <Library />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"planningBoard\" &&\r\n                        <iframe\r\n                            style={{ position: \"absolute\", width: \"calc(100% - 30px)\", height: \"100%\", border: 'none' }}\r\n                            src={`https://miro.com/app/live-embed/${reduxStore.getState().db.cards[hashs[0]].miroBoard}=/?embedAutoplay=true&moveToViewport=-23165,-5837,13803,7546`}\r\n                        ></iframe>\r\n                    }\r\n                </React.Fragment>\r\n                :\r\n                <React.Fragment>\r\n                </React.Fragment>\r\n            }\r\n        </div >\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    history: store.db.history\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(memo(App))","import React from \"react\"\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Card from \"components/Card\"\nimport CustomButton from \"components/Buttons/custom\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport Icon from \"components/Icon\"\nimport LinearProgress from \"components/Progress/linear\"\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//DEPENDENCIES\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/search.js\"\nimport Bright from \"assets/icons/BrigthAndConnected\"\n\n//FUNCTIONS\nimport { translate, customApp, getAppAccess, textColor } from \"functions/\"\nimport { loadCardsV2 } from \"functions/loadData\"\n\nfunction SearchComponent(props) {\n    const [lastChange, setLastChange] = React.useState(null)\n    const [loader, setLoader] = React.useState(false)\n    const [filteredItems, setfilteredItems] = React.useState([])\n    const [hashs, setHashs] = React.useState([])\n    const [adminMode, setAdminMode] = React.useState(false)\n    const { session } = reduxStore.getState()\n    const { db } = props.store\n    const { dataType } = reduxStore.getState().db\n\n    let AppAccess = getAppAccess()\n\n    React.useEffect(() => {\n        return () => {\n            // return false\n        }\n    }, [])\n\n    React.useEffect(() => {\n        searchCards()\n        if (adminMode)\n            loadAdmin()\n    }, [adminMode])\n\n    React.useEffect(() => {\n        if (hashs.length > 0 && hashs[0] !== lastChange) {\n            setAdminMode(false)\n            setLastChange(hashs[0])\n        }\n        const timer = setTimeout(() => searchCards(), 400)\n        // setLoader(true)\n        return () => clearTimeout(timer)\n    }, [db.cards, db.tag, hashs])\n\n    React.useEffect(() => {\n        let Nhashs = window.location.hash.split(\"/\")\n        Nhashs[0] = Nhashs[0].replace(\"#\", \"\")\n        if (JSON.stringify(Nhashs) !== JSON.stringify(hashs)) {\n            setHashs(Nhashs)\n        }\n    })\n\n    React.useEffect(() => {\n        const timer = setTimeout(() => searchCards(), 400)\n        return () => clearTimeout(timer)\n    }, [db.cards, db.tag])\n\n    const loadAdmin = () => {\n        loadCardsV2(props, {\n            cardLoad: 'tags',\n            idRel: hashs[0],\n            adminView: true\n        })\n    }\n\n    const searchCards = async () => {\n        let searchResult = new Promise((resolve, reject) => {\n            let res = Object.keys(db.cards).filter(card =>\n            (\n                db.cards\n                && db.cards[card]\n                && !db.cards[card].deleted\n                && (\n                    (\n                        !adminMode\n                        && (\n                            session\n                            && session._id\n                            && db.cards[card]\n                            && db.cards[card]._users\n                            && db.cards[card]._users[session._id]\n                        )\n                    )\n                    || (\n                        adminMode\n                        && (\n                            AppAccess.owner\n                            || (\n                                AppAccess\n                                && AppAccess.plan\n                                && AppAccess.planAdmin\n                            )\n                        )\n                    )\n                )\n                &&\n                (\n                    hashs\n                    && hashs.length > 0\n                    && hashs[0]\n                    && db.tag\n                    && db.tag.filter(tag =>\n                        tag.value === hashs[0]\n                        || tag.parent === hashs[0]\n                    ).length > 0\n                    && db.cards\n                    && db.cards[card]._tags\n                    && (\n                        db.cards[card]._tags.filter(tag =>\n                            tag.value === hashs[0]\n                            || db.tag.filter(dbt =>\n                                dbt.parent === hashs[0]\n                                && tag.value === dbt.value\n                            ).length > 0\n                        ).length > 0\n                    )\n                )\n                &&\n                (\n                    !db.cards[card].private\n                    ||\n                    (\n                        session\n                        && session._id\n                        && db.cards[card].private\n                        && db.cards[card]._users\n                        && db.cards[card]._users[session._id]\n                    )\n                )\n            )\n            )\n            resolve(res)\n        })\n\n        let response = await searchResult.then(a => {\n            return a\n        })\n        if (response) {\n            setfilteredItems(response)\n            setLoader(false)\n            if (props.onFinish)\n                props.onFinish()\n        }\n    }\n\n    return (\n        <div\n            style={{ width: \"100%\" }}\n        >\n            {loader &&\n                <div style={{ position: \"absolute\", bottom: 0, left: \"7px\", right: \"7px\" }}>\n                    <LinearProgress />\n                </div>\n            }\n            {db.tag.filter(tag => tag.value === hashs[0]).length > 0 ?\n                <div style={{\n                    display: \"flex\",\n                    alignItems: \"center\",\n                }}>\n                    <div style={{\n                        position: 'relative',\n                        padding: \"5px 10px\",\n                        borderRadius: \"8px\",\n                        width: \"fit-content\",\n                        display: \"flex\",\n                        alignItems: \"center\",\n                        ...db.tag.filter(tag => tag.value === hashs[0]).length > 0 && db.tag.filter(tag => tag.value === hashs[0])[0].color ? {\n                            backgroundColor: db.tag.filter(tag => tag.value === hashs[0])[0].color,\n                            color: db.tag.filter(tag => tag.value === hashs[0])[0].color\n                                ? textColor(db.tag.filter(tag => tag.value === hashs[0])[0].color, true)\n                                : customApp(\"menu\")\n                        } : {}\n                    }}>\n                        <Icon\n                            size={\"22px\"}\n                            color={db.tag.filter(tag => tag.value === hashs[0])[0].color\n                                ? textColor(db.tag.filter(tag => tag.value === hashs[0])[0].color, true)\n                                : customApp(\"menu\")}\n                            icon={'tag'}\n                        />\n                        <span style={{ marginLeft: \"7px\" }}>{db.tag.filter(tag => tag.value === hashs[0])[0].label}</span>\n                    </div>\n                    {AppAccess\n                        && AppAccess.plan\n                        && AppAccess.planAdmin\n                        && AppAccess.user\n                        && AppAccess.userAdmin ?\n                        <div>\n                            <CustomButton\n                                title={translate(\"$__adminMode\")}\n                                text={translate(\"$__adminMode\")}\n                                color={adminMode ? customApp('menu') : \"lightgrey\"}\n                                textColor={adminMode ? customApp('menu') : \"lightgrey\"}\n                                icon={\"manage_accounts\"}\n                                onClick={() => {\n                                    setAdminMode(prev => !prev)\n                                }}\n                                style={{ marginLeft: 15 }}\n                                size={\"25px\"}\n                            />\n                        </div>\n                        : <React.Fragment></React.Fragment>\n                    }\n                </div>\n                :\n                <React.Fragment></React.Fragment>\n            }\n            <div style={{ positin: 'relative', width: '100%' }}>\n                <GridContainer>\n                    {filteredItems\n                        .filter(card =>\n                            db.cards[card].type.indexOf('plan') > -1\n                            && (\n                                !props.hidePrivate\n                                || (\n                                    props.hidePrivate\n                                    && !db.cards[card].private\n                                )\n                            )\n                        ).length > 0 &&\n                        <GridItem\n                            xs={12}\n                            sm={12}\n                            md={12}\n                            lg={12}\n                            xl={12}\n                        >\n                            <HeaderWithIcon\n                                title={translate('$__plans', 1)}\n                                icon={dataType.filter(a => a.name === 'plan')[0].icon}\n                                color={customApp('menu')}\n                                filterText={props.text}\n                                style={{\n                                    padding: '7px'\n                                }}\n                            />\n                            <GridContainer>\n                                {filteredItems\n                                    .filter(card =>\n                                        db.cards[card].type === 'plan'\n                                        && (\n                                            !props.hidePrivate\n                                            || (\n                                                props.hidePrivate\n                                                && !db.cards[card].private\n                                            )\n                                        )\n                                    )\n                                    .sort((a, b) => {\n                                        if (db.cards[a].name < db.cards[b].name)\n                                            return -1\n                                        if (db.cards[a].name > db.cards[b].name)\n                                            return 1\n                                        return 0\n                                    })\n                                    .map((card, i) => {\n                                        return (\n                                            <GridItem\n                                                key={card}\n                                                xs={12}\n                                                sm={6}\n                                                md={4}\n                                                lg={4}\n                                                xl={3}\n                                            >\n                                                <Card\n                                                    db=\"cards\"\n                                                    data={db.cards[card]}\n                                                    showConnectedIn\n                                                    showTags\n                                                    searchText={props.text}\n                                                    expanded\n                                                    onAction={props.onAction ? () => { props.onAction() } : null}\n                                                />\n                                            </GridItem>\n                                        )\n                                    })}\n                            </GridContainer>\n                        </GridItem>\n                    }\n                    {filteredItems\n                        .filter(card =>\n                            db.cards[card].type.indexOf('guideline') > -1\n                            && (\n                                !props.hidePrivate\n                                || (\n                                    props.hidePrivate\n                                    && !db.cards[card].private\n                                )\n                            )\n                        ).length > 0 &&\n                        <GridItem\n                            xs={12}\n                            sm={12}\n                            md={12}\n                            lg={12}\n                            xl={12}\n                        >\n                            <HeaderWithIcon\n                                title={translate('$__guidelines', 1)}\n                                icon={dataType.filter(a => a.name === 'guideline')[0].icon}\n                                color={customApp('menu')}\n                                style={{\n                                    padding: '7px'\n                                }}\n                            />\n                            <GridContainer>\n                                {filteredItems\n                                    .filter(card =>\n                                        db.cards[card].type.indexOf('guideline') > -1\n                                        && (\n                                            !props.hidePrivate\n                                            || (\n                                                props.hidePrivate\n                                                && !db.cards[card].private\n                                            )\n                                        )\n                                    )\n                                    .sort((a, b) => {\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return -1\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return 1\n                                        return 0\n                                    })\n                                    .map((card, i) => {\n                                        return (\n                                            <GridItem\n                                                key={card}\n                                                xs={12}\n                                                sm={6}\n                                                md={4}\n                                                lg={4}\n                                                xl={3}\n                                            >\n                                                <Card db=\"cards\" data={db.cards[card]} db='cards' showConnectedIn searchText={props.text} expanded onAction={props.onAction ? () => { props.onAction() } : null} />\n                                            </GridItem>\n                                        )\n                                    })}\n                            </GridContainer>\n                        </GridItem>\n                    }\n\n                    {filteredItems\n                        .filter(card =>\n                            db.cards[card].type.indexOf('objective') > -1\n                            && (\n                                !props.hidePrivate\n                                || (\n                                    props.hidePrivate\n                                    && !db.cards[card].private\n                                )\n                            )\n                        ).length > 0 &&\n                        <GridItem\n                            xs={12}\n                            sm={12}\n                            md={12}\n                            lg={12}\n                            xl={12}\n                        >\n                            <HeaderWithIcon\n                                title={translate('$__objectives', 1)}\n                                icon={dataType.filter(a => a.name === 'objective')[0].icon}\n                                color={customApp('menu')}\n                                style={{\n                                    padding: '7px'\n                                }}\n                            />\n                            <GridContainer>\n                                {filteredItems\n                                    .filter(card =>\n                                        db.cards[card].type.indexOf('objective') > -1\n                                        && (\n                                            !props.hidePrivate\n                                            || (\n                                                props.hidePrivate\n                                                && !db.cards[card].private\n                                            )\n                                        )\n                                    )\n                                    .sort((a, b) => {\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return -1\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return 1\n                                        return 0\n                                    })\n                                    .map((card, i) => {\n                                        return (\n                                            <GridItem\n                                                key={card}\n                                                xs={12}\n                                                sm={6}\n                                                md={4}\n                                                lg={4}\n                                                xl={3}\n                                            >\n                                                <Card db=\"cards\" data={db.cards[card]} db='cards' showConnectedIn searchText={props.text} expanded onAction={props.onAction ? () => { props.onAction() } : null} />\n                                            </GridItem>\n                                        )\n                                    })}\n                            </GridContainer>\n                        </GridItem>\n                    }\n\n                    {filteredItems\n                        .filter(card =>\n                            db.cards[card].type.indexOf('goal') > -1\n                            && (\n                                !props.hidePrivate\n                                || (\n                                    props.hidePrivate\n                                    && !db.cards[card].private\n                                )\n                            )\n                        ).length > 0 &&\n                        <GridItem\n                            xs={12}\n                            sm={12}\n                            md={12}\n                            lg={12}\n                            xl={12}\n                        >\n                            <HeaderWithIcon\n                                title={translate('$__goals', 1)}\n                                icon={dataType.filter(a => a.name === 'goal')[0].icon}\n                                color={customApp('menu')}\n                                style={{\n                                    padding: '7px'\n                                }}\n                            />\n                            <GridContainer>\n                                {filteredItems\n                                    .filter(card =>\n                                        db.cards[card].type.indexOf('goal') > -1\n                                        && (\n                                            !props.hidePrivate\n                                            || (\n                                                props.hidePrivate\n                                                && !db.cards[card].private\n                                            )\n                                        )\n                                    )\n                                    .sort((a, b) => {\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return -1\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return 1\n                                        return 0\n                                    })\n                                    .map((card, i) => {\n                                        return (\n                                            <GridItem\n                                                key={card}\n                                                xs={12}\n                                                sm={6}\n                                                md={4}\n                                                lg={4}\n                                                xl={3}\n                                            >\n                                                <Card db=\"cards\" data={db.cards[card]} db='cards' showConnectedIn searchText={props.text} expanded onAction={props.onAction ? () => { props.onAction() } : null} />\n                                            </GridItem>\n                                        )\n                                    })}\n                            </GridContainer>\n                        </GridItem>\n                    }\n\n                    {filteredItems\n                        .filter(card =>\n                            dataType.filter(dt => dt.name === db.cards[card].type).length > 0\n                            && dataType.filter(dt => dt.name === db.cards[card].type)[0]\n                            && db.cards[card].type !== 'objective'\n                            && db.cards[card].type !== 'goal'\n                            && db.cards[card].type !== 'plan'\n                            && db.cards[card].type !== 'chatGroup'\n                            && db.cards[card].type !== 'link'\n                            && db.cards[card].type !== 'insight'\n                            && db.cards[card].type.indexOf('guideline') === -1\n                            && (\n                                !props.hidePrivate\n                                || (\n                                    props.hidePrivate\n                                    && !db.cards[card].private\n                                )\n                            )\n                        ).length > 0 &&\n                        <GridItem\n                            xs={12}\n                            sm={12}\n                            md={12}\n                            lg={12}\n                            xl={12}\n                        >\n                            <HeaderWithIcon\n                                title={translate('$__actions', 1)}\n                                icon={'double_arrow'}\n                                color={customApp('menu')}\n                                style={{\n                                    padding: '7px'\n                                }}\n                            />\n                            <GridContainer>\n                                {filteredItems\n                                    .filter(card =>\n                                        dataType.filter(dt => dt.name === db.cards[card].type).length > 0\n                                        && dataType.filter(dt => dt.name === db.cards[card].type)[0]\n                                        && db.cards[card].type !== 'objective'\n                                        && db.cards[card].type !== 'goal'\n                                        && db.cards[card].type !== 'plan'\n                                        && db.cards[card].type !== 'chatGroup'\n                                        && db.cards[card].type !== 'link'\n                                        && db.cards[card].type !== 'insight'\n                                        && db.cards[card].type.indexOf('guideline') === -1\n                                        && (\n                                            !props.hidePrivate\n                                            || (\n                                                props.hidePrivate\n                                                && !db.cards[card].private\n                                            )\n                                        )\n                                    )\n                                    .sort((a, b) => {\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return -1\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return 1\n                                        return 0\n                                    })\n                                    .map((card, i) => {\n                                        return (\n                                            <GridItem\n                                                key={card}\n                                                xs={12}\n                                                sm={6}\n                                                md={4}\n                                                lg={4}\n                                                xl={3}\n                                            >\n                                                <Card\n                                                    db=\"cards\"\n                                                    data={db.cards[card]}\n                                                    showConnectedIn\n                                                    searchText={props.text}\n                                                    expanded\n                                                    onAction={props.onAction ? () => { props.onAction() } : null}\n                                                />\n                                            </GridItem>\n                                        )\n                                    })}\n                            </GridContainer>\n                        </GridItem>\n                    }\n\n                    {filteredItems\n                        .filter(card =>\n                            db.cards[card].type === 'insight'\n                            || db.cards[card].type === 'link'\n                        ).length > 0 &&\n                        <GridItem\n                            xs={12}\n                            sm={12}\n                            md={12}\n                            lg={12}\n                            xl={12}\n                        >\n                            <HeaderWithIcon\n                                title={'BRIGHT & CONNECTED'}\n                                icon={Bright}\n                                color={customApp('menu')}\n                                style={{\n                                    padding: '7px'\n                                }}\n                            />\n                            <GridContainer>\n                                {filteredItems\n                                    .filter(card =>\n                                        db.cards[card].type === 'insight'\n                                        || db.cards[card].type === 'link'\n                                    )\n                                    .sort((a, b) => {\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return -1\n                                        if (db.cards[a].name.toLowerCase() < db.cards[b].name.toLowerCase())\n                                            return 1\n                                        return 0\n                                    })\n                                    .map((card, i) => {\n                                        return (\n                                            <GridItem\n                                                key={card}\n                                                xs={12}\n                                                sm={6}\n                                                md={4}\n                                                lg={4}\n                                                xl={3}\n                                            >\n                                                <Card\n                                                    db=\"cards\"\n                                                    data={db.cards[card]}\n                                                    showConnectedIn\n                                                    expanded\n                                                    Avatar\n                                                    Resume\n                                                    onAction={props.onAction ? () => { props.onAction() } : null}\n                                                />\n                                            </GridItem>\n                                        )\n                                    })}\n                            </GridContainer>\n                        </GridItem>\n                    }\n                </GridContainer>\n            </div>\n        </div >\n    )\n}\n\nconst mapStateToProps = (store) => {\n    return {\n        store: {\n            db: {\n                cards: store.db.cards,\n                tag: store.db.tag\n            }\n        },\n        hidePrivate: store.controls.hidePrivate,\n    }\n}\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(SearchComponent))","//CORE\r\nimport React from 'react'\r\n\r\n//REDUX\r\nimport { connect } from 'react-redux'\r\nimport { bindActionCreators } from 'redux';\r\nimport * as reduxActions from 'store/actions';\r\n\r\nfunction Component(props) {\r\n    return (\r\n        <div style={{\r\n            display: 'flex',\r\n            alignItems: 'center',\r\n            justifyContent: 'center',\r\n            height: 'calc(100vh - 115px)'\r\n        }}>\r\n            {props.provisorio || 'Não Autorizado'}\r\n        </div>\r\n    )\r\n}\r\nconst mapStateToProps = store => ({\r\n    store\r\n});\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\r\n","const styles = {\r\n    root: {\r\n\r\n    }\r\n}\r\n\r\nexport default styles;","//REDUX\r\nimport reduxStore from \"store/\";\r\n\r\nfunction countUsers() {\r\n    const { users } = reduxStore.getState().db\r\n    let maxUsers = reduxStore.getState().session.maxUsers && reduxStore.getState().session.maxUsers.low || 0\r\n    let usedUsers = Object.keys(users).filter(fil => {\r\n        if (\r\n            !users[fil].deleted\r\n            && users[fil].type === \"user\"\r\n            && (\r\n                !users[fil]._parent\r\n                || (\r\n                    users[fil]._parent && users[users[fil]._parent]\r\n                )\r\n            )\r\n        )\r\n            return true\r\n    }).length\r\n\r\n    return {\r\n        maxUsers,\r\n        usedUsers\r\n    }\r\n}\r\n\r\nexport {\r\n    countUsers,\r\n}","import React from 'react'\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//COMPONENTES\nimport ErrorPage from \"components/ErrorPages\"\nimport FilterHeader from \"components/Filter/header\"\nimport GridContainer from \"components/Grid/GridContainer.js\"\nimport GridItem from \"components/Grid/GridItem\"\nimport UserCard from \"components/User/card\"\nimport CardsLoader from \"components/Card/loader\"\nimport HeaderWithIcon from \"components/Header/withIcon\";\n\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/users.js\";\n\n//FUNCTIONS\nimport { getAppAccess, translate, customApp } from \"functions/\";\nimport { countUsers } from \"functions/account\"\n\n\nfunction Component(props) {\n    const [hashs, setHashs] = React.useState([])\n    const [external, setExternal] = React.useState(false)\n    const [deleted, setDeleted] = React.useState(false)\n    const { db, session, search } = reduxStore.getState()\n    const { users } = db\n\n    let AppAccess = getAppAccess()\n    let accountUsersCount = countUsers()\n    // console.log(accountUsersCount)\n\n    React.useEffect(() => {\n        let Nhashs = window.location.hash.split(\"/\")\n        Nhashs[0] = Nhashs[0].replace(\"#\", \"\")\n        if (JSON.stringify(Nhashs) !== JSON.stringify(hashs)) {\n            setHashs(Nhashs)\n        }\n    })\n\n    // console.log(accountUsersCount)\n\n\n    let filtered = Object.keys(users).filter(fil => !users[fil].deleted).map(a => users[a])\n\n\n    if (search.text)\n        filtered = filtered.filter(fil => {\n            if ((fil.name && fil.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n                || (fil.name && fil.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n                || (fil.email && fil.email.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n            )\n                return true\n            return false\n        }\n        ).map(a => a)\n\n    if (hashs[0] === 'tab' && hashs[1] === 'users') {\n        filtered = filtered.filter(c => c.type === 'user' && !c._parent).map(a => a)\n    }\n    if (hashs[0] === 'tab' && hashs[1] === 'units') {\n        filtered = filtered.filter(c => c.type !== 'user').map(a => a)\n    }\n\n    // console.log(filtered)\n    if (search.users && search.users.userGroup.length > 0)\n        filtered = filtered.filter(fil => fil.groups.filter(group => group.value === search.users.userGroup[0].value).length > 0).map(a => a)\n\n    if (search.tags.length > 0)\n        filtered = filtered.filter(fil =>\n            fil.tags && fil.tags.length > 0 && fil.tags.filter(tag => {\n                let result = false\n                search.tags.map(tagFilter => {\n                    if (tagFilter.value === tag.value)\n                        result = true\n                })\n                return result\n            }\n            ).length > 0\n        ).map(a => a)\n\n    if (search.userGroups.length > 0)\n        filtered = filtered.filter(fil =>\n            fil.groups && fil.groups.length > 0 && fil.groups.filter(g => {\n                let result = false\n                search.userGroups.map(group => {\n                    if (group.value === g.value)\n                        result = true\n                })\n                return result\n            }\n            ).length > 0\n        ).map(a => a)\n\n\n    let filteredUsers = Object.keys(users).map(a => users[a])\n\n    if (search.text)\n        filteredUsers = filteredUsers.filter(fil => {\n            if ((fil.name && fil.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n                || (fil.name && fil.name.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n                || (fil.email && fil.email.toLowerCase().indexOf(search.text.toLowerCase()) > -1)\n            )\n                return true\n            return false\n        }\n        ).map(a => a)\n    if (hashs[0] === 'tab' && hashs[1] === 'units' && hashs[2] && hashs[2].length === 36) {\n        filteredUsers = filteredUsers.filter(c => c.type === 'user' && c._parent === hashs[2]).map(a => a)\n    }\n    //  if (hashs[0] === 'tab' && hashs[1] === 'groups' && hashs[2] && hashs[2].length === 36) {\n    //     filteredUsers = filteredUsers.filter(c => c.type === 'user' && c._parent === hashs[2]).map(a => a)\n    // } \n    //  if (hashs[0] === 'tab' && hashs[1] === 'sic' && hashs[2] && hashs[2].length === 36) {\n    //     filteredUsers = filteredUsers.filter(c => c.type === 'user' && c._parent === hashs[2]).map(a => a)\n    // }\n    if (search.users && search.users.userGroup.length > 0)\n        filteredUsers = filteredUsers.filter(fil => fil.groups.filter(group => group.value === search.users.userGroup[0].value).length > 0).map(a => a)\n\n    if (search.tags.length > 0)\n        filteredUsers = filteredUsers.filter(fil =>\n            fil.tags && fil.tags.length > 0 && fil.tags.filter(tag => {\n                let result = false\n                search.tags.map(tagFilter => {\n                    if (tagFilter.value === tag.value)\n                        result = true\n                })\n                return result\n            }\n            ).length > 0\n        ).map(a => a)\n\n    if (search.userGroups.length > 0)\n        filteredUsers = filteredUsers.filter(fil =>\n            fil.groups && fil.groups.length > 0 && fil.groups.filter(g => {\n                let result = false\n                search.userGroups.map(group => {\n                    if (group.value === g.value)\n                        result = true\n                })\n                return result\n            }\n            ).length > 0\n        ).map(a => a)\n\n    if (AppAccess && !AppAccess.owner && !AppAccess.user)\n        return (<ErrorPage />)\n\n    if (!window.location.hash.split('/')[0].replace('#', '')) {\n        history.push('c#tab/units')\n    }\n\n    const filterUsersGroup = (group, user) => {\n        if (reduxStore.getState().db.users[user]\n            && reduxStore.getState().db.users[user].groups\n            && reduxStore.getState().db.users[user].groups.length > 0\n            && reduxStore.getState().db.users[user].groups.filter(ug => ug.value === group.value).length > 0\n            && (\n                (\n                    !external\n                    && (\n                        !reduxStore.getState().db.users[user]._parent\n                        || reduxStore.getState().db.users[user]._parent === session.account\n                    )\n                )\n                ||\n                (\n                    external\n                    && reduxStore.getState().db.users[user]._parent\n                    && reduxStore.getState().db.users[user]._parent !== session.account\n                )\n            )\n            && (\n                (\n                    !deleted\n                    && !reduxStore.getState().db.users[user].deleted\n                )\n                ||\n                (\n                    deleted\n                    && reduxStore.getState().db.users[user].deleted\n                )\n            )\n        )\n            return true\n        return false\n    }\n\n    return (\n        <div>\n            <CardsLoader />\n            <div\n            // style={{ marginLeft: \"-30px\", width: \"calc(100% + 30px)\" }}\n            >\n                <FilterHeader />\n                <GridContainer>\n                    {hashs[0] === 'tab' && (hashs[1] === 'departments') ?\n                        <div>\n                            <div>\n                                {reduxStore.getState().db.userGroup.filter(group => {\n                                    if (Object.keys(reduxStore.getState().db.users).filter(user => {\n                                        return filterUsersGroup(group, user)\n                                    }).length > 0)\n                                        return true\n                                }).map(group => {\n                                    let users = Object.keys(reduxStore.getState().db.users).filter(user => {\n                                        return filterUsersGroup(group, user)\n                                    })\n                                    return (\n                                        <div key={group.value}\n                                            style={{ width: \"100%\", padding: 7, marginBottom: 77 }}>\n                                            {/* <div>{group.label} ({users.length})</div> */}\n                                            <HeaderWithIcon\n                                                title={group.label}\n                                                icon={group.icon || null}\n                                                color={customApp('menu')}\n                                                style={{\n                                                    padding: '7px'\n                                                }}\n                                                {...AppAccess\n                                                    && (\n                                                        AppAccess.userAdmin\n                                                        ||\n                                                        AppAccess.userModerate\n                                                    )\n                                                    ? {\n                                                        // permitIcon: true,\n                                                        iconOnEditable: true,\n                                                        editable: true,\n                                                        onEdit: (x) => {\n                                                            // updateCardData(\n                                                            //     {\n                                                            //         ...props,\n                                                            //         data: { _id: hashs[0] }\n                                                            //     }, {\n                                                            //     customColumns: JSON.stringify({\n                                                            //         ...reduxStore.getState().db.cards[hashs[0]] && reduxStore.getState().db.cards[hashs[0]].customColumns ? JSON.parse(reduxStore.getState().db.cards[hashs[0]].customColumns) : {},\n                                                            //         [props.column.name.replace(\"$__\", \"\")]: x\n                                                            //     })\n                                                            // })\n                                                            console.log(x)\n                                                        },\n                                                        placeholder: translate(\"$__groupName\")\n                                                    } : {}}\n                                            />\n                                            <GridContainer>\n                                                {users.sort((a, b) => {\n                                                    let nameA = reduxStore.getState().db.users[a].name.toLowerCase()\n                                                    let nameB = reduxStore.getState().db.users[b].name.toLowerCase()\n                                                    if (nameA < nameB)\n                                                        return -1\n                                                    if (nameA < nameB)\n                                                        return 1\n                                                    return 0\n                                                }).map(id => {\n                                                    return (\n                                                        <GridItem\n                                                            key={`${group.value}_${id}`}\n                                                            xs={12}\n                                                            sm={6}\n                                                            md={4}\n                                                            lg={4}\n                                                            xl={3}\n                                                            style={{ minWidth: \"300px\" }}\n                                                        >\n                                                            <UserCard data={reduxStore.getState().db.users[id]} />\n                                                        </GridItem>\n                                                    )\n                                                })}\n                                            </GridContainer>\n                                        </div>\n                                    )\n                                })}\n                            </div>\n                        </div>\n                        :\n                        <React.Fragment>\n                            {filtered.sort((a, b) => {\n                                if ((a && a.name && a.name < b.name) || (users && a && a.name && a.name < b.name))\n                                    return -1\n                                return 1\n                            }).map((us, i) => (\n                                !hashs[2] || (hashs[2] && us._id === hashs[2]) ?\n                                    <GridItem\n                                        key={us._id}\n                                        xs={12}\n                                        sm={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? 12 : 6}\n                                        md={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? 12 : 4}\n                                        lg={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? 12 : 4}\n                                        xl={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? 12 : 3}\n                                        style={{ minWidth: \"300px\" }}\n                                    >\n                                        <UserCard data={us} expanded={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? true : false} />\n                                    </GridItem>\n                                    : !hashs[2] &&\n                                    <GridItem\n                                        key={us._id}\n                                        xs={12}\n                                        sm={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? 12 : 6}\n                                        md={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? 12 : 4}\n                                        lg={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? 12 : 3}\n                                        xl={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? 12 : 3}\n                                    >\n                                        <UserCard data={us} expanded={hashs[1] && hashs[2] && (hashs[1] === 'units') && hashs[2].length === 36 && db.users[hashs[2]] ? true : false} />\n                                    </GridItem>\n                            ))}\n                            {hashs[0] === 'tab' && (hashs[1] === 'units') && hashs[2] && hashs[2].length === 36 &&\n                                filteredUsers.filter(a => !a.deleted).sort((a, b) => {\n                                    if ((a && a.name && a.name < b.name) || (users && a && a.name && a.name < b.name))\n                                        return -1\n                                    return 1\n                                }).map((us, i) => (\n                                    <GridItem\n                                        key={`${us._id}-${i}`}\n                                        xs={12}\n                                        sm={6}\n                                        md={4}\n                                        lg={3}\n                                        xl={2}\n                                    >\n                                        <UserCard data={us} />\n                                    </GridItem>\n                                ))\n                            }\n                        </React.Fragment>\n                    }\n\n                </GridContainer>\n            </div>\n        </div>\n    );\n}\n\n//REACT\nconst mapStateToProps = (store) => ({\n    users: store.db.users,\n    page: store.db.history\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(styles)(Component));","import React from \"react\";\n\n// mterial-ui components\nimport { makeStyles } from \"@material-ui/core/styles\";\n\nconst styles = {\n  clearfix: {\n    \"&:after,&:before\": {\n      display: \"table\",\n      content: '\" \"'\n    },\n    \"&:after\": {\n      clear: \"both\"\n    }\n  }\n};\n\nconst useStyles = makeStyles(styles);\n\nexport default function Clearfix() {\n  const classes = useStyles();\n  return <div className={classes.clearfix} />;\n}\n","import {\r\n  warningCardHeader,\r\n  successCardHeader,\r\n  dangerCardHeader,\r\n  infoCardHeader,\r\n  primaryCardHeader,\r\n  roseCardHeader,\r\n  grayColor\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst cardIconStyle = {\r\n  cardIcon: {\r\n    \"&$warningCardHeader,&$successCardHeader,&$dangerCardHeader,&$infoCardHeader,&$primaryCardHeader,&$roseCardHeader,&$customCardHeader\": {\r\n      borderRadius: \"3px\",\r\n      backgroundColor: grayColor[0],\r\n      padding: \"7px\",\r\n      marginTop: \"-20px\",\r\n      marginRight: \"15px\",\r\n      float: \"left\"\r\n    }\r\n  },\r\n  warningCardHeader,\r\n  successCardHeader,\r\n  dangerCardHeader,\r\n  infoCardHeader,\r\n  primaryCardHeader,\r\n  roseCardHeader,\r\n  customCardHeader: {}\r\n};\r\n\r\nexport default cardIconStyle;\r\n","import React from \"react\";\nimport classNames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/cardIconStyle.js\";\n\n//FUNCTIONS\nimport {\n  //translate, \n  customApp\n} from \"functions/\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function CardIcon(props) {\n  const classes = useStyles();\n  const { className, children, color, ...rest } = props;\n  const cardIconClasses = classNames({\n    [classes.cardIcon]: true,\n    [classes[color + \"CardHeader\"]]: color,\n    [className]: className !== undefined\n  });\n  return (\n    <div className={cardIconClasses} {...rest}\n      style={color === 'custom' ? {\n        background: `linear-gradient(60deg, ${customApp('color', 1)}, ${customApp('color', 1)})`, //customApp\n        boxShadow: `0 10px 30px -12px ${customApp('color', 0.42)}, 0 4px 25px 0px ${customApp('color', 0.12)}, 0 8px 10px -5px ${customApp('color', 0.2)}` //customApp SHADOW\n      } : {}}\n    >\n      {children}\n    </div>\n  );\n}\n\nCardIcon.propTypes = {\n  className: PropTypes.string,\n  color: PropTypes.oneOf([\n    \"warning\",\n    \"success\",\n    \"danger\",\n    \"info\",\n    \"primary\",\n    \"rose\",\n    \"custom\"\n  ]),\n  children: PropTypes.node\n};\n","import {\r\n  blackColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst cardAvatarStyle = {\r\n  cardAvatar: {\r\n    \"&$cardAvatarProfile img,&$cardAvatarTestimonial img\": {\r\n      width: \"100%\",\r\n      height: \"auto\"\r\n    }\r\n  },\r\n  cardAvatarProfile: {\r\n    maxWidth: \"130px\",\r\n    maxHeight: \"130px\",\r\n    margin: \"-50px auto 0\",\r\n    borderRadius: \"50%\",\r\n    overflow: \"hidden\",\r\n    padding: \"0\",\r\n    boxShadow:\r\n      \"0 16px 38px -12px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.56), 0 4px 25px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.12), 0 8px 10px -5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.2)\",\r\n    \"&$cardAvatarPlain\": {\r\n      marginTop: \"0\"\r\n    }\r\n  },\r\n  cardAvatarPlain: {},\r\n  cardAvatarTestimonial: {\r\n    margin: \"-50px auto 0\",\r\n    maxWidth: \"100px\",\r\n    maxHeight: \"100px\",\r\n    borderRadius: \"50%\",\r\n    overflow: \"hidden\",\r\n    padding: \"0\",\r\n    boxShadow:\r\n      \"0 16px 38px -12px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.56), 0 4px 25px 0px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.12), 0 8px 10px -5px rgba(\" +\r\n      hexToRgb(blackColor) +\r\n      \", 0.2)\",\r\n    \"&$cardAvatarPlain\": {\r\n      marginTop: \"0\"\r\n    }\r\n  },\r\n  cardAvatarTestimonialFooter: {\r\n    marginBottom: \"-50px\",\r\n    marginTop: \"10px\"\r\n  }\r\n};\r\n\r\nexport default cardAvatarStyle;\r\n","import React from \"react\";\nimport classNames from \"classnames\";\nimport PropTypes from \"prop-types\";\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/cardAvatarStyle.js\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function CardAvatar(props) {\n  const classes = useStyles();\n  const {\n    children,\n    className,\n    plain,\n    profile,\n    testimonial,\n    testimonialFooter,\n    ...rest\n  } = props;\n  const cardAvatarClasses = classNames({\n    [classes.cardAvatar]: true,\n    [classes.cardAvatarProfile]: profile,\n    [classes.cardAvatarPlain]: plain,\n    [classes.cardAvatarTestimonial]: testimonial,\n    [classes.cardAvatarTestimonialFooter]: testimonialFooter,\n    [className]: className !== undefined\n  });\n  return (\n    <div className={cardAvatarClasses} {...rest}>\n      {children}\n    </div>\n  );\n}\n\nCardAvatar.propTypes = {\n  children: PropTypes.node.isRequired,\n  className: PropTypes.string,\n  profile: PropTypes.bool,\n  plain: PropTypes.bool,\n  testimonial: PropTypes.bool,\n  testimonialFooter: PropTypes.bool\n};\n","import {\r\n  cardTitle,\r\n  grayColor\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst userProfileStyles = {\r\n  cardTitle,\r\n  cardIconTitle: {\r\n    ...cardTitle,\r\n    marginTop: \"15px\",\r\n    marginBottom: 0,\r\n    \"& small\": {\r\n      fontSize: \"80%\",\r\n      fontWeight: \"400\"\r\n    }\r\n  },\r\n  cardCategory: {\r\n    marginTop: \"10px\",\r\n    color: grayColor[0] + \" !important\",\r\n    textAlign: \"center\"\r\n  },\r\n  description: {\r\n    color: grayColor[0]\r\n  },\r\n  updateProfileButton: {\r\n    float: \"right\"\r\n  }\r\n};\r\nexport default userProfileStyles;\r\n","import React from \"react\";\n\n\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n\n// @MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport InputLabel from \"@material-ui/core/InputLabel\";\n\n// @material-ui/icons\nimport PermIdentity from \"@material-ui/icons/PermIdentity\";\n\n// core components\nimport GridContainer from \"components/Grid/GridContainer.js\";\nimport GridItem from \"components/Grid/GridItem.js\";\nimport Button from \"components/CustomButtons/Button.js\";\nimport CustomInput from \"components/CustomInput/CustomInput.js\";\nimport Clearfix from \"components/Clearfix/Clearfix.js\";\nimport Card from \"components/Card/Card.js\";\nimport CardBody from \"components/Card/CardBody.js\";\nimport CardHeader from \"components/Card/CardHeader.js\";\nimport CardIcon from \"components/Card/CardIcon.js\";\nimport CardAvatar from \"components/Card/CardAvatar.js\";\n\nimport styles from \"assets/jss/material-dashboard-pro-react/views/userProfileStyles.js\";\n\n// import avatar from \"assets/img/faces/marc.jpg\";\n// import profileAvatar from \"assets/img/profile_model.jpg\";\n\nconst useStyles = makeStyles(styles);\n\nfunction Profile(props) {\n  const classes = useStyles();\n  return (\n    <div\n      style={{\n        position: \"relative\",\n        width: \"calc(100% - 7px)\"\n      }}\n    >\n      <GridContainer>\n        <div style={{\n          position: \"relative\",\n          width: \"100%\",\n          boxShadow: \"0px -2px 5px 2px rgba(0,0,0,0.1)\",\n          height: 150,\n          backgroundColor: \"black\",\n          borderTopRightRadius: 11,\n          borderTopLeftRadius: 11,\n          // backgroundImage: `url(${profileAvatar})`,\n          backgroundPosition: \"center center\",\n          backgroundSize: \"cover\",\n          marginBottom: \"-15px\"\n        }}></div>\n        <GridItem xs={12} sm={12} md={8}>\n          <Card>\n            {/* <CardHeader color=\"rose\" icon>\n              <CardIcon color=\"rose\">\n                <PermIdentity />\n              </CardIcon>\n              <h4 className={classes.cardIconTitle}>\n                Edit Profile - <small>Complete your profile</small>\n              </h4>\n            </CardHeader> */}\n            <CardBody>\n              <GridContainer>\n                <GridItem xs={12} sm={12} md={5}>\n                  <CustomInput\n                    labelText=\"Company (disabled)\"\n                    id=\"company-disabled\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                    inputProps={{\n                      disabled: true\n                    }}\n                  />\n                </GridItem>\n                <GridItem xs={12} sm={12} md={3}>\n                  <CustomInput\n                    labelText=\"Username\"\n                    id=\"username\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                  />\n                </GridItem>\n                <GridItem xs={12} sm={12} md={4}>\n                  <CustomInput\n                    labelText=\"Email address\"\n                    id=\"email-address\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                  />\n                </GridItem>\n              </GridContainer>\n              <GridContainer>\n                <GridItem xs={12} sm={12} md={6}>\n                  <CustomInput\n                    labelText=\"First Name\"\n                    id=\"first-name\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                  />\n                </GridItem>\n                <GridItem xs={12} sm={12} md={6}>\n                  <CustomInput\n                    labelText=\"Last Name\"\n                    id=\"last-name\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                  />\n                </GridItem>\n              </GridContainer>\n              <GridContainer>\n                <GridItem xs={12} sm={12} md={4}>\n                  <CustomInput\n                    labelText=\"City\"\n                    id=\"city\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                  />\n                </GridItem>\n                <GridItem xs={12} sm={12} md={4}>\n                  <CustomInput\n                    labelText=\"Country\"\n                    id=\"country\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                  />\n                </GridItem>\n                <GridItem xs={12} sm={12} md={4}>\n                  <CustomInput\n                    labelText=\"Postal Code\"\n                    id=\"postal-code\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                  />\n                </GridItem>\n              </GridContainer>\n              <GridContainer>\n                <GridItem xs={12} sm={12} md={12}>\n                  <InputLabel style={{ color: \"#AAAAAA\" }}>About me</InputLabel>\n                  <CustomInput\n                    labelText=\"Lamborghini Mercy, Your chick she so thirsty, I'm in that two seat Lambo.\"\n                    id=\"about-me\"\n                    formControlProps={{\n                      fullWidth: true\n                    }}\n                    inputProps={{\n                      multiline: true,\n                      rows: 5\n                    }}\n                  />\n                </GridItem>\n              </GridContainer>\n              <Button color=\"rose\" className={classes.updateProfileButton}>\n                Update Profile\n              </Button>\n              <Clearfix />\n            </CardBody>\n          </Card>\n        </GridItem>\n        <GridItem xs={12} sm={12} md={4}>\n          <Card db=\"cards\" profile>\n            <CardAvatar profile>\n              <a href=\"#pablo\" onClick={e => e.preventDefault()}>\n                {/* <img src={avatar} alt=\"...\" /> */}\n              </a>\n            </CardAvatar>\n            <CardBody profile>\n              <h6 className={classes.cardCategory}>CEO / CO-FOUNDER</h6>\n              <h4 className={classes.cardTitle}>Alec Thompson</h4>\n              <p className={classes.description}>\n                Don{\"'\"}t be scared of the truth because we need to restart the\n                human foundation in truth And I love you like Kanye loves Kanye\n                I love Rick Owens’ bed design but the back is...\n              </p>\n              <Button color=\"rose\" round>\n                Follow\n              </Button>\n            </CardBody>\n          </Card>\n        </GridItem>\n      </GridContainer>\n    </div>\n  );\n}\n\nconst mapStateToProps = (store) => ({})\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps,\n  mapDispatchToProps\n)(Profile)\n","//CORE\nimport React from \"react\"\nimport Cards from \"react-credit-cards\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport Switch from \"components/Switch\"\nimport TextField from \"components/TextField\"\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Users.js\"\n\n//FUNCTIONS\nimport api from \"api/\"\nimport {\n    customApp,\n    appAlert,\n    translate,\n    getAppAccess\n} from \"functions/\"\nimport { saveAccess } from \"functions/users.js\"\n\n\nimport 'react-credit-cards/es/styles-compiled.css';\n\nfunction Component(props) {\n    const { functions } = reduxStore.getState()\n    const { socket } = functions\n    const [data, setData] = React.useState({\n        cvc: '',\n        expiry: '',\n        focus: '',\n        name: '',\n        number: '',\n    })\n\n    const AppAccess = getAppAccess()\n\n    return (\n        <div>\n            <Cards\n                cvc={data.cvc}\n                expiry={data.expiry}\n                focused={data.focus}\n                name={data.name}\n                number={data.number}\n            />\n            <fieldset style={{\n                wordBreak: \"break-word\"\n            }}>\n                <legend>\n                    {translate(\"$__paymentPreffer\")}\n                </legend>\n                <div\n                    style={{\n                        borderRadius: 15,\n                        background: customApp(\"ColumnTitleColor\"),\n                        color: \"#FFFFFF\",\n                        boxShadow: \"0 0 3px 7px rgba(0,0,0,0.03)\",\n                        padding: 15\n                    }}\n                >\n                </div>\n                <TextField\n                    id={`sideModule_user_displayName`}\n                    label={translate('$__displayName', 1)}\n                    variant={customApp('fieldVariant')}\n                    name=\"number\"\n                    InputProps={{\n                        autoComplete: 'new-password',\n                        multiline: true,\n                        endAdornment: (\n                            <InputAdornment position=\"end\">\n                                <Icon icon='view_comfy_ind' />\n                            </InputAdornment>\n                        ),\n                        onChange: (d) => {\n                            setData({\n                                ...data,\n                                ['number']: d.target.value\n                            })\n                        },\n                    }}\n                    value={data && data.number ? data.number : ''}\n                    placeholder={translate('$__cardNumber', 1)}\n                // disabled={permission ? false : true}\n                />\n            </fieldset>\n            <fieldset style={{\n                wordBreak: \"break-word\"\n            }}>\n                <legend>\n                    {translate(\"$__forceChangePassword\")}\n                </legend>\n                <Switch\n                    checked={data && data._access && data._access.user ? true : false}\n                    onChange={(d) => {\n                        // changeData({\n                        //     name: 'user',\n                        //     value: data && data._access && data._access.user ? false : true\n                        // })\n                    }}\n                    name=\"checkedA\"\n                    inputProps={{ 'aria-label': 'secondary checkbox' }}\n                />\n                {translate(\"$__forceChangePasswordDescription\")}\n            </fieldset>\n        </div >\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","import React, { memo } from \"react\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\nimport history from \"store/history\"\r\n\r\n//COMPONENTS\r\nimport CreditCard from \"components/Account/creditCard\"\r\n\r\n//VIEWS\r\n\r\n//DEPENDENCIES\r\n\r\n//FUNCTIONS\r\nimport { getAppAccess, translate } from \"functions/\"\r\n\r\nimport { customApp } from \"functions\"\r\n\r\n\r\n\r\nfunction App(props) {\r\n    //SANDBOX\r\n    //GALAX Id 5473\r\n    //GALAX Hash 83Mw5u8988Qj6fZqS4Z8K7LzOo1j28S706R0BeFe\r\n    const test = async () => {\r\n        const { socket } = reduxStore.getState().functions\r\n\r\n        socket.emit(\"data\", {\r\n            module: \"galaxPay\",\r\n            method: \"post\",\r\n            action: \"integration\"\r\n        }, {\r\n            action: \"reqData\",\r\n            accountData: reduxStore.getState().session.GlobalData\r\n        }, response => {\r\n            console.log(response)\r\n            if (response.error) {\r\n                console.log(\"companyDataError\", response.error)\r\n                console.log(response)\r\n            }\r\n        })\r\n    }\r\n    return (\r\n        <div>\r\n            <CreditCard />\r\n            <div style={{ padding: 15, backgroundColor: \"black\" }} onClick={() => { test() }}>TEST</div>\r\n        </div >\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    history: store.db.history\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(memo(App))","import React, { memo } from \"react\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\nimport history from \"store/history\"\r\n\r\n//COMPONENTS\r\n\r\n//VIEWS\r\n\r\n//DEPENDENCIES\r\n\r\n//FUNCTIONS\r\nimport { getAppAccess, translate } from \"functions/\"\r\n\r\nimport { customApp } from \"functions\"\r\n\r\nfunction App(props) {\r\n\r\n    React.useEffect(() => {\r\n        console.log(\"StrategyAndPlans\")\r\n    }, [])\r\n\r\n    React.useEffect(() => {\r\n        const scrollTimer = setTimeout(() => {\r\n            document.getElementById(\"mainPannel\").scrollTo(0, 0)\r\n        }, 100)\r\n        return () => {\r\n            clearTimeout(scrollTimer)\r\n        }\r\n    }, [props.history])\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace(\"#\", \"\")\r\n\r\n    if (!window.location.hash.split(\"/\")[0].replace(\"#\", \"\")) {\r\n        history.push(\"sp#tab/home\")\r\n    }\r\n\r\n\r\n    if (hashs[0] && hashs[0].length === 36 && !reduxStore.getState().db.cards[hashs[0]]) {\r\n        history.push(\"/deniedAccess\")\r\n    }\r\n\r\n\r\n    return (\r\n        <div>\r\n            integration\r\n            {/* <CardsLoader /> */}\r\n            {/* {(!hashs[0] || (hashs[0] && hashs[0].replace(\"#\", \"\").length !== 36)) && hashs[1] === \"home\" ?\r\n                <React.Fragment>\r\n                    <HomePlans />\r\n                </React.Fragment>\r\n                : (!hashs[0] || (hashs[0] && hashs[0].replace(\"#\", \"\").length !== 36)) && hashs[1] === \"completed\" ?\r\n                    <React.Fragment>\r\n                        <HomePlans completed={true} />\r\n                    </React.Fragment>\r\n                    :\r\n                    (!hashs[0]\r\n                        ||\r\n                        (hashs[0]\r\n                            && hashs[0].replace(\"#\", \"\").length !== 36\r\n                        )\r\n                    )\r\n                    &&\r\n                    // <Plans />\r\n            } */}\r\n            {/* {hashs[0].length === 36 && reduxStore.getState().db.cards[hashs[0].replace(\"#\", \"\")] ?\r\n                <React.Fragment>\r\n                    {hashs[1] && hashs[1] === \"matrix\" &&\r\n                        <Matrix />\r\n                    }\r\n                    {hashs[1] && (hashs[1] === \"actions\" || hashs[1] === \"guidelines\" || hashs[1] === \"objectives\" || hashs[1] === \"goals\")\r\n                        &&\r\n                        <Actions type={hashs[1]} />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"dashboard\" &&\r\n                        <Dashboard />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"overview\" &&\r\n                        <Overview />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"bright-and-connected\" &&\r\n                        <React.Fragment>\r\n                            <BrightAndConnected />\r\n                        </React.Fragment>\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"insight-boards\" &&\r\n                        <InsightBoards />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"radar\" &&\r\n                        <Radar />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"library\" &&\r\n                        <Library />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"planningBoard\" &&\r\n                        <iframe\r\n                            style={{ position: \"absolute\", width: \"calc(100% - 30px)\", height: \"100%\", border: 'none' }}\r\n                            src={`https://miro.com/app/live-embed/${reduxStore.getState().db.cards[hashs[0]].miroBoard}=/?embedAutoplay=true&moveToViewport=-23165,-5837,13803,7546`}\r\n                        ></iframe>\r\n                    }\r\n                </React.Fragment>\r\n                :\r\n                <React.Fragment>\r\n                </React.Fragment>\r\n            } */}\r\n        </div >\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    history: store.db.history\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(memo(App))","import React, { memo } from \"react\"\r\nimport { Editor } from 'react-draft-wysiwyg';\r\nimport { EditorState, convertToRaw, ContentState } from 'draft-js';\r\nimport draftToHtml from 'draftjs-to-html';\r\nimport htmlToDraft from 'html-to-draftjs';\r\n\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\nimport history from \"store/history\"\r\n\r\n//COMPONENTS\r\nimport ErrorBoundary from \"components/ErrorBoundary\"\r\nimport GridContainer from \"components/Grid/GridContainer\"\r\nimport GridItem from \"components/Grid/GridItem\"\r\nimport CustomButton from \"components/Buttons/custom\"\r\n\r\n\r\n//VIEWS\r\n\r\n//FUNCTIONS\r\nimport apims from \"apims/\";\r\n\r\nimport { getAppAccess, translate, BytesConvert } from \"functions/\"\r\n\r\nimport {\r\n    customApp,\r\n    tokenDecode\r\n} from \"functions\"\r\n\r\nimport 'react-draft-wysiwyg/dist/react-draft-wysiwyg.css';\r\n\r\nrequire('dotenv').config()\r\n\r\nfunction App(props) {\r\n    const { session, db } = reduxStore.getState()\r\n    const [data, setData] = React.useState({})\r\n    const [iniData, setIniData] = React.useState(session.GlobalData ? session.GlobalData : {})\r\n    const [editorData, setEditorData] = React.useState({\r\n        historyEditor: null\r\n    })\r\n\r\n    React.useEffect(() => {\r\n        setData(session.GlobalData ? session.GlobalData : {})\r\n        setIniData(session.GlobalData ? session.GlobalData : {})\r\n        let history = EditorState.createEmpty(),\r\n            vocation = EditorState.createEmpty(),\r\n            legacy = EditorState.createEmpty(),\r\n            message = EditorState.createEmpty(),\r\n            strategicStatement = EditorState.createEmpty(),\r\n            values = EditorState.createEmpty()\r\n\r\n        if (session.GlobalData.history) {\r\n            history = htmlToDraft(`<div>${session.GlobalData.history}</div>`)\r\n            history = ContentState.createFromBlockArray(history.contentBlocks)\r\n            history = EditorState.createWithContent(history);\r\n        }\r\n\r\n        if (session.GlobalData.strategicStatement) {\r\n            strategicStatement = htmlToDraft(`<div>${session.GlobalData.strategicStatement}</div>`)\r\n            strategicStatement = ContentState.createFromBlockArray(strategicStatement.contentBlocks)\r\n            strategicStatement = EditorState.createWithContent(strategicStatement);\r\n        }\r\n\r\n        if (session.GlobalData.values) {\r\n            values = htmlToDraft(`<div>${session.GlobalData.values}</div>`)\r\n            values = ContentState.createFromBlockArray(values.contentBlocks)\r\n            values = EditorState.createWithContent(values);\r\n        }\r\n\r\n\r\n        if (session.GlobalData.vocation) {\r\n            vocation = htmlToDraft(`<div>${session.GlobalData.vocation}</div>`)\r\n            vocation = ContentState.createFromBlockArray(vocation.contentBlocks)\r\n            vocation = EditorState.createWithContent(vocation);\r\n        }\r\n\r\n\r\n\r\n        if (session.GlobalData.legacy) {\r\n            legacy = htmlToDraft(`<div>${session.GlobalData.legacy}</div>`)\r\n            legacy = ContentState.createFromBlockArray(legacy.contentBlocks)\r\n            legacy = EditorState.createWithContent(legacy);\r\n        }\r\n        if (session.GlobalData.message) {\r\n            message = htmlToDraft(`<div>${session.GlobalData.message}</div>`)\r\n            message = ContentState.createFromBlockArray(message.contentBlocks)\r\n            message = EditorState.createWithContent(message)\r\n        }\r\n\r\n        setEditorData({\r\n            history,\r\n            vocation,\r\n            legacy,\r\n            message,\r\n            values,\r\n            strategicStatement\r\n        })\r\n    }, [])\r\n\r\n    const saveData = async () => {\r\n        let newData = {}\r\n        let file\r\n        Object.keys(data).map(mp => {\r\n            if (data[mp] && (!iniData[mp] || JSON.stringify({ a: data[mp] }) !== JSON.stringify({ a: iniData[mp] }))) {\r\n                newData = {\r\n                    ...newData,\r\n                    [mp]: data[mp] && typeof data[mp] === 'string' ? data[mp].trim() : data[mp]\r\n                }\r\n            }\r\n        })\r\n        // JSON.str\r\n        try {\r\n            const { socket } = reduxStore.getState().functions\r\n            socket.emit(\"data\", {\r\n                module: \"account\",\r\n                method: \"post\",\r\n                action: \"save\"\r\n            }, newData, response => {\r\n                if (response.error) {\r\n                    console.log(\"companyDataError\", response.error)\r\n                } else {\r\n                    props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\r\n                        ...reduxStore.getState().session,\r\n                        GlobalData: {\r\n                            ...reduxStore.getState().session.GlobalData,\r\n                            ...newData\r\n                        }\r\n                    });\r\n                }\r\n            })\r\n            setData(\r\n                {\r\n                    ...reduxStore.getState().session.GlobalData,\r\n                    ...newData\r\n                }\r\n            )\r\n            setIniData(\r\n                {\r\n                    ...reduxStore.getState().session.GlobalData,\r\n                    ...newData\r\n                }\r\n            )\r\n        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    }\r\n\r\n    return (\r\n        <div>\r\n            <GridContainer\r\n                style={{\r\n                    marginTop: 15\r\n                }}\r\n            >\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={12}\r\n                    md={6}\r\n                    lg={6}\r\n                    xl={6}\r\n                    style={{\r\n                        marginBottom: 33\r\n                    }}\r\n                >\r\n                    <div\r\n                        style={{\r\n                            padding: 7,\r\n                            width: \"100%\",\r\n                            backgroundColor: \"#FFFFFF\",\r\n                            borderRadius: 2,\r\n                            boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                        }}\r\n                    >\r\n                        <div>{translate(\"$__adminMessage\")}</div>\r\n                        {console.log(editorData.message)}\r\n                        <ErrorBoundary>\r\n                            <Editor\r\n                                toolbar={{\r\n                                    options: ['inline', 'blockType', 'fontSize', 'fontFamily', 'list', 'textAlign', 'colorPicker', 'link', 'emoji', 'image', 'remove', 'history'],\r\n                                    inline: {\r\n                                        inDropdown: false,\r\n                                        options: ['bold', 'italic'],\r\n                                    },\r\n                                }}\r\n                                editorState={editorData.message}\r\n                                onEditorStateChange={(d) => {\r\n                                    setData({\r\n                                        ...data,\r\n                                        message: draftToHtml(convertToRaw(d.getCurrentContent())),\r\n                                    })\r\n                                    setEditorData({\r\n                                        ...editorData,\r\n                                        message: d,\r\n                                    })\r\n                                }}\r\n                                hashtag={{\r\n                                    separator: ' ',\r\n                                    trigger: '#',\r\n                                }}\r\n                                editorStyle={{\r\n                                    minHeight: 150\r\n                                }}\r\n                            />\r\n                        </ErrorBoundary>\r\n                    </div>\r\n                </GridItem>\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={12}\r\n                    md={6}\r\n                    lg={6}\r\n                    xl={6}\r\n                    style={{\r\n                        marginBottom: 33\r\n                    }}\r\n                >\r\n                    <div\r\n                        style={{\r\n                            padding: 7,\r\n                            width: \"100%\",\r\n                            backgroundColor: \"#FFFFFF\",\r\n                            borderRadius: 2,\r\n                            boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                        }}\r\n                    >\r\n                        <div>{translate(\"$__strategicStatement\")}</div>\r\n                        <ErrorBoundary>\r\n                            <Editor\r\n                                toolbar={{\r\n                                    options: ['inline', 'blockType', 'fontSize', 'fontFamily', 'list', 'textAlign', 'colorPicker', 'link', 'emoji', 'image', 'remove', 'history'],\r\n                                    inline: {\r\n                                        inDropdown: false,\r\n                                        options: ['bold', 'italic'],\r\n                                    },\r\n                                }}\r\n                                editorState={editorData.strategicStatement}\r\n                                onEditorStateChange={(d) => {\r\n                                    setData({\r\n                                        ...data,\r\n                                        strategicStatement: draftToHtml(convertToRaw(d.getCurrentContent())),\r\n                                    })\r\n                                    setEditorData({\r\n                                        ...editorData,\r\n                                        strategicStatement: d,\r\n                                    })\r\n                                }}\r\n                                hashtag={{\r\n                                    separator: ' ',\r\n                                    trigger: '#',\r\n                                }}\r\n                                editorStyle={{\r\n                                    minHeight: 150\r\n                                }}\r\n                            />\r\n                        </ErrorBoundary>\r\n                    </div>\r\n                </GridItem>\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={12}\r\n                    md={6}\r\n                    lg={6}\r\n                    xl={6}\r\n                    style={{\r\n                        marginBottom: 33\r\n                    }}\r\n                >\r\n                    <div\r\n                        style={{\r\n                            padding: 7,\r\n                            width: \"100%\",\r\n                            backgroundColor: \"#FFFFFF\",\r\n                            borderRadius: 2,\r\n                            boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                        }}\r\n                    >\r\n                        <div>{translate(\"$__vocation\")}</div>\r\n                        <ErrorBoundary>\r\n                            <Editor\r\n                                toolbar={{\r\n                                    options: ['inline', 'blockType', 'fontSize', 'fontFamily', 'list', 'textAlign', 'colorPicker', 'link', 'emoji', 'image', 'remove', 'history'],\r\n                                    inline: {\r\n                                        inDropdown: false,\r\n                                        options: ['bold', 'italic'],\r\n                                    },\r\n                                }}\r\n                                editorState={editorData.vocation}\r\n                                onEditorStateChange={(d) => {\r\n                                    setData({\r\n                                        ...data,\r\n                                        vocation: draftToHtml(convertToRaw(d.getCurrentContent())),\r\n                                    })\r\n                                    setEditorData({\r\n                                        ...editorData,\r\n                                        vocation: d,\r\n                                    })\r\n                                }}\r\n                                hashtag={{\r\n                                    separator: ' ',\r\n                                    trigger: '#',\r\n                                }}\r\n                                editorStyle={{\r\n                                    minHeight: 150\r\n                                }}\r\n                            />\r\n                        </ErrorBoundary>\r\n                    </div>\r\n                </GridItem>\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={12}\r\n                    md={6}\r\n                    lg={6}\r\n                    xl={6}\r\n                    style={{\r\n                        marginBottom: 33\r\n                    }}\r\n                >\r\n                    <div\r\n                        style={{\r\n                            padding: 7,\r\n                            width: \"100%\",\r\n                            backgroundColor: \"#FFFFFF\",\r\n                            borderRadius: 2,\r\n                            boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                        }}\r\n                    >\r\n                        <div>{translate(\"$__history\")}</div>\r\n                        <ErrorBoundary>\r\n                            <Editor\r\n                                toolbar={{\r\n                                    options: ['inline', 'blockType', 'fontSize', 'fontFamily', 'list', 'textAlign', 'colorPicker', 'link', 'emoji', 'image', 'remove', 'history'],\r\n                                    inline: {\r\n                                        inDropdown: false,\r\n                                        options: ['bold', 'italic'],\r\n                                    },\r\n                                }}\r\n                                editorState={editorData.history}\r\n                                onEditorStateChange={(d) => {\r\n                                    setData({\r\n                                        ...data,\r\n                                        history: draftToHtml(convertToRaw(d.getCurrentContent())),\r\n                                    })\r\n                                    setEditorData({\r\n                                        ...editorData,\r\n                                        history: d,\r\n                                    })\r\n                                }}\r\n                                hashtag={{\r\n                                    separator: ' ',\r\n                                    trigger: '#',\r\n                                }}\r\n                                editorStyle={{\r\n                                    minHeight: 150\r\n                                }}\r\n                            />\r\n                        </ErrorBoundary>\r\n                    </div>\r\n                </GridItem>\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={12}\r\n                    md={6}\r\n                    lg={6}\r\n                    xl={6}\r\n                    style={{\r\n                        marginBottom: 33\r\n                    }}\r\n                >\r\n                    <div\r\n                        style={{\r\n                            padding: 7,\r\n                            width: \"100%\",\r\n                            backgroundColor: \"#FFFFFF\",\r\n                            borderRadius: 2,\r\n                            boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                        }}\r\n                    >\r\n                        <div>{translate(\"$__values\")}</div>\r\n                        <ErrorBoundary>\r\n                            <Editor\r\n                                toolbar={{\r\n                                    options: ['inline', 'blockType', 'fontSize', 'fontFamily', 'list', 'textAlign', 'colorPicker', 'link', 'emoji', 'image', 'remove', 'history'],\r\n                                    inline: {\r\n                                        inDropdown: false,\r\n                                        options: ['bold', 'italic'],\r\n                                    },\r\n                                }}\r\n                                editorState={editorData.values}\r\n                                onEditorStateChange={(d) => {\r\n                                    setData({\r\n                                        ...data,\r\n                                        values: draftToHtml(convertToRaw(d.getCurrentContent())),\r\n                                    })\r\n                                    setEditorData({\r\n                                        ...editorData,\r\n                                        values: d,\r\n                                    })\r\n                                }}\r\n                                hashtag={{\r\n                                    separator: ' ',\r\n                                    trigger: '#',\r\n                                }}\r\n                                editorStyle={{\r\n                                    minHeight: 150\r\n                                }}\r\n                            />\r\n                        </ErrorBoundary>\r\n                    </div>\r\n                </GridItem>\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={12}\r\n                    md={6}\r\n                    lg={6}\r\n                    xl={6}\r\n                    style={{\r\n                        marginBottom: 33\r\n                    }}\r\n                >\r\n                    <div\r\n                        style={{\r\n                            padding: 7,\r\n                            width: \"100%\",\r\n                            backgroundColor: \"#FFFFFF\",\r\n                            borderRadius: 2,\r\n                            boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                        }}\r\n                    >\r\n                        <div>{translate(\"$__legacy\")}</div>\r\n                        <ErrorBoundary>\r\n                            <Editor\r\n                                toolbar={{\r\n                                    options: ['inline', 'blockType', 'fontSize', 'fontFamily', 'list', 'textAlign', 'colorPicker', 'link', 'emoji', 'image', 'remove', 'history'],\r\n                                    inline: {\r\n                                        inDropdown: false,\r\n                                        options: ['bold', 'italic'],\r\n                                    },\r\n                                }}\r\n                                editorState={editorData.legacy}\r\n                                onEditorStateChange={(d) => {\r\n                                    setData({\r\n                                        ...data,\r\n                                        legacy: draftToHtml(convertToRaw(d.getCurrentContent())),\r\n                                    })\r\n                                    setEditorData({\r\n                                        ...editorData,\r\n                                        legacy: d,\r\n                                    })\r\n                                }}\r\n                                style={{\r\n                                    minHeight: 150\r\n                                }}\r\n                                hashtag={{\r\n                                    separator: ' ',\r\n                                    trigger: '#',\r\n                                }}\r\n                                editorStyle={{\r\n                                    minHeight: 150\r\n                                }}\r\n                            />\r\n                        </ErrorBoundary>\r\n                    </div>\r\n                </GridItem>\r\n\r\n\r\n            </GridContainer>\r\n            {JSON.stringify(data) !== JSON.stringify(iniData) ?\r\n                <div style={{\r\n                    display: \"flex\",\r\n                    justifyContent: \"flex-end\"\r\n                }}>\r\n                    <CustomButton\r\n                        // shadow\r\n                        title={translate(\"$__save\")}\r\n                        text={translate(\"$__save\")}\r\n                        color=\"green\"\r\n                        // tr\r\n                        icon={\"save\"}\r\n                        size={\"25px\"}\r\n                        onClick={() => {\r\n                            saveData()\r\n                        }}\r\n                    />\r\n                </div>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n        </div>\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    history: store.db.history\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(App)","import React from \"react\";\r\n\r\n//FUNTIONS\r\nimport { customApp, translate } from \"functions/\";\r\n\r\n\r\nexport default function PercentualBar(props) {\r\n    return (\r\n        <div style={{\r\n            position: \"relative\",\r\n            height: 5,\r\n            backgroundColor: \"lightgray\",\r\n            width: \"100%\",\r\n            overflow: \"hidden\",\r\n            borderRadius: 3,\r\n            boxShadow: \"0 0 0 2px rgba(0,0,0,0.05)\"\r\n        }}>\r\n            <div style={{\r\n                position: \"absolute\",\r\n                top: 1,\r\n                left: 1,\r\n                bottom: 1,\r\n                width: `calc(${props.value ? props.value : 0}% - 2px)`,\r\n                overflow: \"hidden\",\r\n                background: `${props.background ? props.background : customApp('ColumnTitleColor')}`,\r\n                borderRadius: 3,\r\n                boxShadow: \"0 0 0 2px rgba(0,0,0,0.05)\"\r\n            }}>\r\n            </div>\r\n        </div>\r\n    );\r\n}\r\n","// ID_CREATED*************************\n\n//CORE\nimport React from \"react\"\nimport { cpf, cnpj } from 'cpf-cnpj-validator';\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport ImgCropper from \"components/Cropper\"\nimport TextField from \"components/TextField\"\nimport CustomButton from \"components/Buttons/custom\"\nimport SelectUsers from \"components/User/select\";\n\n//@MATERIAL\nimport Icon from \"components/Icon\"\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card.js\"\n\n//FUNCTIONS\nimport { upload } from \"functions/upload.js\";\nimport {\n    translate,\n    customApp,\n    validateEmail,\n    appAlert,\n    getAppAccess,\n    getDate\n} from \"functions/\"\nimport { save, emailExist } from \"functions/users.js\"\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\nfunction Component(props) {\n    const { classes } = props\n    const { db, session } = reduxStore.getState()\n    const { users, dataType } = db\n    const [data, setData] = React.useState(session.GlobalData ? session.GlobalData : {})\n    const [iniData, setIniData] = React.useState(session.GlobalData ? session.GlobalData : {})\n    const [emailError, setEmailError] = React.useState(!validateEmail(data && data.email ? data.email : ''))\n    const [reqSave, setReqSave] = React.useState(false)\n    const AppAccess = getAppAccess()\n\n    const saveData = async () => {\n        let newData = {}\n        let file\n        Object.keys(data).map(mp => {\n            if (mp === \"file\") {\n                file = data[mp]\n            } else if (mp === 'document') {\n                let valid = false\n                if (data[mp].length === 11 && cpf.isValid(data[mp]))\n                    valid = true\n                if (data[mp].length === 14 && cnpj.isValid(data[mp]))\n                    valid = true\n                if (valid) {\n                    newData = {\n                        ...newData,\n                        [mp]: data[mp] && typeof data[mp] === 'string' ? data[mp].trim() : data[mp]\n                    }\n                } else {\n                    appAlert({\n                        message: `${translate(`$__${mp}`)}: ${translate(\"$__invalidDocument\")}`,\n                        variant: 'warning',\n                        persist: false,\n                        horizontal: 'right',\n                        confirm: null\n                    })\n                }\n\n            } else if (data[mp] && (!iniData[mp] || JSON.stringify({ a: data[mp] }) !== JSON.stringify({ a: iniData[mp] }))) {\n                newData = {\n                    ...newData,\n                    [mp]: data[mp] && typeof data[mp] === 'string' ? data[mp].trim() : data[mp]\n                }\n            } else if (!data[mp] && mp !== \"_id\") {\n                appAlert({\n                    message: `${translate(`$__${mp}`)}: ${translate(\"$__cantBeEmpty\")}`,\n                    variant: 'warning',\n                    persist: false,\n                    horizontal: 'right',\n                    confirm: null\n                })\n            }\n        })\n        // JSON.str\n        try {\n            const { socket } = reduxStore.getState().functions\n            let imageResult = file ? await upload(session.account, file) : true\n            if (imageResult) {\n                if (String(imageResult) !== 'true') {\n                    newData = {\n                        ...newData,\n                        image: imageResult\n                    }\n                }\n                socket.emit(\"data\", {\n                    module: \"account\",\n                    method: \"post\",\n                    action: \"save\"\n                }, newData, response => {\n                    if (response.error) {\n                        console.log(\"companyDataError\", response.error)\n                    } else {\n                        props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                            ...reduxStore.getState().session,\n                            GlobalData: {\n                                ...reduxStore.getState().session.GlobalData,\n                                ...newData\n                            }\n                        });\n                        setIniData({\n                            ...reduxStore.getState().session.GlobalData,\n                            ...newData\n                        })\n                    }\n                })\n            }\n        } catch (e) {\n            console.log(e)\n        }\n    }\n\n    let permission = false\n    if (data._id === session._id ||\n        (AppAccess\n            &&\n            (\n                AppAccess.user\n                && (\n                    AppAccess.userAdmin\n                    || AppAccess.userEdit\n                )\n            )\n        ))\n        permission = true\n\n    // console.log(data)\n    if (data.independentAccount)\n        permission = false\n\n    return (\n        <div>\n            <div\n                id={`sideModule_user_foto`}\n            >\n                <ImgCropper\n                    maxWidthOrHeight={600}\n                    img={\n                        data &&\n                            data.image ?\n                            data.image :\n                            null\n                    }\n                    onChange={(a, file) => {\n                        setData({\n                            ...data,\n                            file: file\n                        })\n                    }}\n                    avatar\n                    avatarIcon={'business'}\n                />\n            </div>\n            <TextField\n                id={`sideModule_user_fullName`}\n                label={translate('$__fullCompanyName', 1)}\n                variant={customApp('fieldVariant')}\n                name={'fullName'}\n                InputLabelProps={{\n                    shrink: true,\n                }}\n                InputProps={{\n                    autoComplete: 'new-password',\n                    endAdornment: (\n                        <InputAdornment position=\"end\">\n                            <Icon icon='business' />\n                        </InputAdornment>\n                    ),\n                    onChange: (d) => {\n                        setData({\n                            ...data,\n                            fullName: d.target.value\n                        })\n                    },\n                    onBlur: (d) => {\n                        if (data && !data.fullName) {\n                            let name = d.target.value ? `${d.target.value.split(' ')[0]} ${d.target.value.split(' ')[1] ? d.target.value.split(' ')[1] : ''}` : \"\"\n                            setData({\n                                ...data,\n                                fullName: name\n                            })\n                        }\n                    }\n                }}\n                value={data && data.fullName ? data.fullName : ''}\n                placeholder={translate('$__fullName', 1)}\n                autoFocus\n                disabled={true}\n            />\n            <TextField\n                id={`sideModule_user_displayName`}\n                label={translate('$__displayName', 1)}\n                variant={customApp('fieldVariant')}\n                name=\"name\"\n                InputProps={{\n                    autoComplete: 'new-password',\n                    multiline: true,\n                    endAdornment: (\n                        <InputAdornment position=\"end\">\n                            <Icon icon='view_comfy_ind' />\n                        </InputAdornment>\n                    ),\n                    onChange: (d) => {\n                        setData({\n                            ...data,\n                            name: d.target.value\n                        })\n                    },\n                }}\n                value={data && data.name ? data.name : ''}\n                placeholder={translate('$__displayName', 1)}\n                disabled={true}\n            />\n            <TextField\n                id={`customURL`}\n                label={translate('$__customURL', 1)}\n                variant={customApp('fieldVariant')}\n                name={'customURL'}\n                InputLabelProps={{\n                    shrink: true,\n                }}\n                InputProps={{\n                    autoComplete: 'new-password',\n                    endAdornment: (\n                        <InputAdornment position=\"end\">\n                            <span style={{ color: \"gray\", fontSize: 12 }}>.machen.ai</span>\n                        </InputAdornment>\n                    ),\n                    onChange: (d) => {\n                        setData({\n                            ...data,\n                            customURL: d.target.value.trim()\n                        })\n                    },\n                    onBlur: (d) => {\n                        if (data && !data.fullName) {\n                            setData({\n                                ...data,\n                                customURL: d.target.value.trim()\n                            })\n                        }\n                    }\n                }}\n                value={data && data.customURL ? data.customURL : ''}\n                placeholder={translate('$__customURL', 1)}\n                autoFocus\n            />\n            <TextField\n                id={`__documentCPForCNPJ`}\n                label={translate('$__documentCPForCNPJ', 1)}\n                variant={customApp('fieldVariant')}\n                name=\"document\"\n                InputProps={{\n                    autoComplete: 'new-password',\n                    multiline: true,\n                    endAdornment: (\n                        <InputAdornment position=\"end\">\n                            <Icon icon='view_comfy_ind' />\n                        </InputAdornment>\n                    ),\n                    onChange: (d) => {\n                        setData({\n                            ...data,\n                            document: d.target.value\n                        })\n                    },\n                }}\n                value={data && data.document ? data.document : ''}\n                placeholder={translate('$__displayName', 1)}\n                disabled={iniData.document ? true : false}\n            />\n            <fieldset>\n                <legend>{translate(\"$__accountResponsible\")}</legend>\n                <ErrorBoundary>\n                    <SelectUsers\n                        includeMe\n                        admins\n                        avatarSize=\"33px\"\n                        permission={true}\n                        noLimit\n                        selected={data.accountResponsible ? [data.accountResponsible] : null}\n                        onSelect={(e) => {\n                            setData({\n                                ...data,\n                                accountResponsible: e[0]\n                            })\n                        }}\n                    />\n                </ErrorBoundary>\n            </fieldset>\n            <fieldset>\n                <legend>{translate(\"$__invoiceResponsible\")}</legend>\n                <ErrorBoundary>\n                    <SelectUsers\n                        includeMe\n                        admins\n                        avatarSize=\"33px\"\n                        permission={true}\n                        noLimit\n                        selected={data.invoiceResponsible ? [data.invoiceResponsible] : null}\n                        onSelect={(e) => {\n                            setData({\n                                ...data,\n                                invoiceResponsible: e[0]\n                            })\n                        }}\n                    />\n                </ErrorBoundary>\n            </fieldset>\n            <ul style={{\n                color: customApp(\"color\")\n            }}>\n                <li>\n                    {translate(\"$__createdAt\")}: {getDate(data.created_at)}\n                </li>\n                {data.expire_at ?\n                    <li style={{\n                        color: customApp(\"menu\")\n                    }}>\n                        {translate(\"$__expireDate\")}: {getDate(data.expire_at)}\n                    </li>\n                    : <React.Fragment></React.Fragment>\n                }\n            </ul>\n            {JSON.stringify(data) !== JSON.stringify(iniData) ?\n                <div style={{\n                    display: \"flex\",\n                    justifyContent: \"flex-end\"\n                }}>\n                    <CustomButton\n                        // shadow\n                        title={translate(\"$__save\")}\n                        text={translate(\"$__save\")}\n                        color=\"green\"\n                        // tr\n                        icon={\"save\"}\n                        size={\"25px\"}\n                        onClick={() => {\n                            saveData()\n                            // setEditor(false)\n                        }}\n                    />\n                </div>\n                : <React.Fragment></React.Fragment>\n            }\n        </div>\n    )\n}\nconst mapStateToProps = (store) => ({\n    session: store.session\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Autocomplete from \"components/AutoComplete\"\nimport TextField from \"components/TextField\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Switch from \"components/Switch\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Users.js\"\n\n//FUNCTIONS\nimport {\n    customApp,\n    translate,\n} from \"functions/\"\n\nfunction Component(props) {\n    const { classes } = props\n    const {\n        session,\n        functions,\n        db\n    } = reduxStore.getState()\n    const [data, setData] = React.useState(session.GlobalData ? session.GlobalData : {})\n    const [iniData, setIniData] = React.useState(session.GlobalData ? session.GlobalData : {})\n\n    const saveData = async () => {\n        let newData = {}\n        let file\n        Object.keys(data).map(mp => {\n            if (data[mp] && (!iniData[mp] || JSON.stringify({ a: data[mp] }) !== JSON.stringify({ a: iniData[mp] }))) {\n                newData = {\n                    ...newData,\n                    [mp]: data[mp] && typeof data[mp] === 'string' ? data[mp].trim() : data[mp]\n                }\n            }\n        })\n\n        if (!newData.requireExpirePassword && newData.expiresIn)\n            newData.expiresIn = null\n\n        try {\n            const { socket } = reduxStore.getState().functions\n\n            socket.emit(\"data\", {\n                module: \"account\",\n                method: \"post\",\n                action: \"save\"\n            }, newData, response => {\n                if (response.error) {\n                    console.log(\"companyDataError\", response.error)\n                } else {\n                    props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                        ...reduxStore.getState().session,\n                        GlobalData: {\n                            ...reduxStore.getState().session.GlobalData,\n                            ...newData\n                        }\n                    });\n                }\n            })\n        } catch (e) {\n            console.log(e)\n        }\n    }\n\n    return (\n        <div>\n            <fieldset style={{\n                wordBreak: \"break-word\"\n            }}>\n                <legend>\n                    {translate(\"$__2FactorTokenRequired\")}\n                </legend>\n                <div style={{\n                    position: \"relative\",\n                    width: \"100%\",\n                    display: \"flex\",\n                    alignItems: \"center\"\n                }}>\n                    <Switch\n                        checked={data && data.requireToken ? true : false}\n                        onChange={(d) => {\n                            let newData = {\n                                ...data,\n                                requireToken: !data.requireToken,\n                            }\n                            if (data.requireToken)\n                                delete newData.requireToken\n                            setData(newData)\n                        }}\n                        name=\"checkedA\"\n                        inputProps={{ 'aria-label': 'secondary checkbox' }}\n                    />\n                    {translate(\"$__required\")}\n                </div>\n                <i>{translate(\"$__2FactorTokenRequiredDescription\")}</i>\n            </fieldset>\n            <fieldset style={{\n                wordBreak: \"break-word\"\n            }}>\n                <legend>\n                    {translate(\"$__forceChangePassword\")}\n                </legend>\n                <div style={{\n                    position: \"relative\",\n                    width: \"100%\",\n                    display: \"flex\",\n                    alignItems: \"center\"\n                }}>\n                    <Switch\n                        checked={data && data.requireExpirePassword ? true : false}\n                        onChange={(d) => {\n                            let newData = {\n                                ...data,\n                                requireExpirePassword: !data.requireExpirePassword,\n                            }\n                            if (data.requireExpirePassword) {\n                                delete newData.requireExpirePassword\n                                if (data.passwordExpire)\n                                    delete newData.passwordExpire\n                            }\n\n                            setData(newData)\n                        }}\n                        name=\"checkedA\"\n                        inputProps={{ 'aria-label': 'secondary checkbox' }}\n                    />\n                    {translate(\"$__required\")}\n                </div>\n                <i>{translate(\"$__forceChangePasswordDescription\")}</i>\n                {data.requireExpirePassword ?\n                    <fieldset>\n                        <legend>{translate('$__sessionDuration', 1)}</legend>\n                        <Autocomplete\n                            id=\"combo-box-demo\"\n                            options={db.passwordExpire}\n                            getOptionLabel={(option) => translate(option.label, 1)}\n                            style={{ width: \"100%\" }}\n                            name=\"status\"\n                            disableClearable\n                            value={\n                                data\n                                    && data.passwordExpire\n                                    && db.passwordExpire\n                                    ? db.passwordExpire.filter(a =>\n                                        String(a.value) === String(data.passwordExpire)\n                                    )[0]\n                                    : db.passwordExpire[0]\n                            }\n                            renderInput={(params) =>\n                                <TextField\n                                    {...params}\n                                    label={translate(\"$__expiresIn\", 1)}\n                                    variant={customApp(\"fieldVariant\")}\n                                    value={\n                                        data\n                                            && data.passwordExpire\n                                            && db.passwordExpire\n                                            ? db.passwordExpire.filter(a =>\n                                                String(a.value) === String(data.passwordExpire)\n                                            )[0]\n                                            : db.passwordExpire.filter(a =>\n                                                !a.value\n                                            )[0]\n                                    }\n                                />\n                            }\n                            onChange={\n                                (d, v) => {\n                                    setData({\n                                        ...data,\n                                        passwordExpire: v[\"value\"]\n                                    })\n                                }\n                            }\n                        />\n                    </fieldset>\n                    : <React.Fragment></React.Fragment>\n                }\n            </fieldset>\n            <fieldset>\n                <legend>{translate('$__language', 1)}</legend>\n                <Autocomplete\n                    id=\"combo-box-demo\"\n                    options={db.languages}\n                    getOptionLabel={(option) => translate(option.label, 1)}\n                    style={{ width: \"100%\" }}\n                    name=\"status\"\n                    disableClearable\n                    value={data\n                        && data.language\n                        && db.languages\n                        && db.languages.filter(a =>\n                            String(a.value) === String(data.language)\n                        ).length > 0\n                        ? db.languages.filter(a =>\n                            String(a.value) === String(data.language)\n                        )[0]\n                        : db.languages[0]\n                    }\n                    renderInput={(params) =>\n                        <TextField\n                            {...params}\n                            label={translate(\"$__language\", 1)}\n                            variant={customApp(\"fieldVariant\")}\n                            value={data\n                                && data.language\n                                && db.languages\n                                && db.languages.filter(a =>\n                                    String(a.value) === String(data.language)\n                                ).length > 0\n                                ? db.languages.filter(a =>\n                                    String(a.value) === String(data.language)\n                                )[0]\n                                : db.languages[0]\n                            }\n                        />\n                    }\n                    onChange={\n                        (d, v) => {\n                            setData({\n                                ...data,\n                                language: v[\"value\"]\n                            })\n                        }\n                    }\n                />\n            </fieldset>\n            <fieldset>\n                <legend>{translate('$__sessionExpire', 1)}</legend>\n                <Autocomplete\n                    id=\"combo-box-demo\"\n                    options={db.expiresIn}\n                    getOptionLabel={(option) => translate(option.label, 1)}\n                    style={{ width: \"100%\" }}\n                    name=\"status\"\n                    disableClearable\n                    value={\n                        data\n                            && data.expiresIn\n                            && db.expiresIn\n                            ? db.expiresIn.filter(a =>\n                                String(a.value) === String(data.expiresIn)\n                            )[0]\n                            : db.expiresIn.filter(a =>\n                                !a.value\n                            )[0]\n                    }\n                    renderInput={(params) =>\n                        <TextField\n                            {...params}\n                            label={translate(\"$__expiresIn\", 1)}\n                            variant={customApp(\"fieldVariant\")}\n                            value={\n                                data\n                                    && data.expiresIn\n                                    && db.expiresIn\n                                    ? db.expiresIn.filter(a =>\n                                        String(a.value) === String(data.expiresIn)\n                                    )[0]\n                                    : db.expiresIn.filter(a =>\n                                        !a.value\n                                    )[0]\n                            }\n                        />\n                    }\n                    onChange={\n                        (d, v) => {\n                            setData({\n                                ...data,\n                                expiresIn: v[\"value\"]\n                            })\n                        }\n                    }\n                />\n            </fieldset>\n            {JSON.stringify(data) !== JSON.stringify(iniData) ?\n                <div style={{\n                    display: \"flex\",\n                    justifyContent: \"flex-end\"\n                }}>\n                    <CustomButton\n                        // shadow\n                        title={translate(\"$__save\")}\n                        text={translate(\"$__save\")}\n                        color=\"green\"\n                        // tr\n                        icon={\"save\"}\n                        size={\"25px\"}\n                        onClick={() => {\n                            saveData()\n                            // setEditor(false)\n                        }}\n                    />\n                </div>\n                : <React.Fragment></React.Fragment>\n            }\n        </div >\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({\n    session: store.session\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport Password from \"components/Password\"\nimport SideModuleCloseAndSave from \"components/SideModule/closeAndSave\"\nimport Switch from \"components/Switch\"\nimport TextField from \"components/TextField\"\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\n// import { withStyles } from \"@material-ui/core/styles\"\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Users.js\"\n\n//FUNCTIONS\nimport apims from \"api/\"\n\nimport {\n    BytesConvert,\n    appAlert,\n    customApp,\n    getAppAccess,\n    translate,\n} from \"functions/\"\nimport { saveAccess } from \"functions/users.js\"\n\n\nimport 'react-credit-cards/es/styles-compiled.css';\n\nconst useStyles = makeStyles({\n    list: {\n        position: \"relative\",\n        listStyleType: \"disclosure-closed\",\n        \"& li\": {\n            marginBottom: 3\n        },\n    },\n    item: {\n        display: \"flex\",\n        alignItems: \"center\",\n    }\n});\n\nfunction Component(props) {\n    const { functions, session } = reduxStore.getState()\n    const { socket } = functions\n    const { planDetails, data } = props\n\n    const classes = useStyles();\n\n    const AppAccess = getAppAccess()\n\n    const upgradeSubscription = (\n        <span style={{ marginLeft: 15, color: \"red\", fontSize: 11, cursor: \"pointer\" }} onClick={() => {\n            history.push(\"#tab/subscriptionUpgrade\")\n        }}>{translate(\"$__upgradeSubscription\")}</span>\n    )\n    return (\n        <div>\n            <fieldset style={{\n                wordBreak: \"break-word\",\n                padding: 0,\n                position: \"relative\"\n            }}>\n                <legend>\n                    {translate(\"$__subscription\")}: <span style={{ fontWeight: \"bold\" }}>{translate(planDetails.label)}</span>\n                </legend>\n                <ul\n\n                    className={classes.list}\n                >\n\n                    <li >{translate(\"$__adminLimit\", 1)}: {data && data.customAdminsLimit ? data.customAdminsLimit : planDetails.settings.admins}</li>\n                    <li >{translate(\"$__storageSpace\", 1)}: {data && data.customStorageSpace ? BytesConvert(data.customStorageSpace) : BytesConvert(planDetails.settings.space)}</li>\n                    <li>{translate(\"$__BrightAndConnected\", 1)}:\n                        <ul style={{\n                            position: \"relative\",\n                            paddingLeft: 10,\n                            listStyleType: \"disc\",\n                        }}>\n                            <li className={classes.item}>{translate(\"$__feed\", 1)}: {planDetails.settings.brightAndConnected.feed ? <Icon icon='check' color={customApp(\"color\")} size={18} /> : upgradeSubscription}</li>\n                            {planDetails.settings.brightAndConnected.feed ?\n                                <li className={classes.item}>{translate(\"$__feedDays\", 1)}:\n                                    {planDetails.settings.brightAndConnected.feedDays ? `${planDetails.settings.brightAndConnected.feedDays} ${translate(\"$__days\")}` : translate(\"$__unlimited\")}\n                                </li>\n                                : <React.Fragment></React.Fragment>\n                            }\n                            <li className={classes.item}>{translate(\"$__radarLimit\", 1)}: {planDetails.settings.brightAndConnected.radarLimit ? planDetails.settings.brightAndConnected.radarLimit : translate(\"$__unlimited\")}</li>\n                            <li className={classes.item}>{translate(\"$__insights\", 1)}: {planDetails.settings.brightAndConnected.insight ? <Icon icon='check' color={customApp(\"color\")} size={18} /> : upgradeSubscription}</li>\n                        </ul>\n                    </li>\n                    <li>{translate(\"$__plannings\", 1)}:\n                        <ul style={{\n                            position: \"relative\",\n                            paddingLeft: 10,\n                            listStyleType: \"disc\",\n                        }}>\n                            <li className={classes.item}>{translate(\"$__limit\", 1)}: {planDetails.settings.plan.limit ? planDetails.settings.brightAndConnected.radarLimit : translate(\"$__unlimited\")}</li>\n                            <li className={classes.item}>{translate(\"$__clientPlannings\", 1)}: {planDetails.settings.plan.planClient ? <Icon icon='check' color={customApp(\"color\")} size={18} /> : upgradeSubscription}</li>\n                            {planDetails.settings.plan.planClient ?\n                                <li className={classes.item}>{translate(\"$__clientUserAdmins\", 1)}: {planDetails.settings.plan.clientAdmin ? planDetails.settings.plan.clientAdmin : upgradeSubscription}</li>\n                                : <React.Fragment></React.Fragment>}\n                            <li className={classes.item}>{translate(\"$__externalPlanning\", 1)}: {planDetails.settings.plan.machenPlan ? <Icon icon='check' color={customApp(\"color\")} size={18} /> : upgradeSubscription}</li>\n                            <li className={classes.item}>{translate(\"$__professionalTemplates\", 1)}: {planDetails.settings.plan.templates ? <Icon icon='check' color={customApp(\"color\")} size={18} /> : upgradeSubscription}</li>\n                            <li className={classes.item}>{translate(\"$__guidelineLimit\", 1)}: {planDetails.settings.plan.guidelineLimit ? planDetails.settings.plan.guidelineLimit : translate(\"$__unlimited\")}</li>\n                            <li className={classes.item}>{translate(\"$__feedLimit\", 1)}: {planDetails.settings.plan.feedLimit ? planDetails.settings.plan.feedLimit : translate(\"$__unlimited\")}</li>\n                            <li className={classes.item}>{translate(\"$__radarLimit\", 1)}: {planDetails.settings.plan.radarLimit ? planDetails.settings.plan.radarLimit : translate(\"$__unlimited\")}</li>\n                            <li className={classes.item}>{translate(\"$__insightLimit\", 1)}: {planDetails.settings.plan.insightLimit ? planDetails.settings.plan.insightLimit : translate(\"$__unlimited\")}</li>\n                        </ul>\n                    </li>\n                    <a href=\"https://machen.ai/#planos\" target={\"_blank\"} style={{ fontWeight: \"bold\", color: customApp(\"menu\"), marginTop: 33 }}>{translate(\"$__viewMoreDetails\")}</a>\n                </ul>\n            </fieldset>\n        </div >\n    )\n}\nconst mapStateToProps = (store, ownProps) => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)","import React, { memo } from \"react\"\r\n\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\nimport history from \"store/history\"\r\n\r\n//COMPONENTS\r\nimport ErrorBoundary from \"components/ErrorBoundary\"\r\nimport GridContainer from \"components/Grid/GridContainer\"\r\nimport GridItem from \"components/Grid/GridItem\"\r\nimport Icon from \"components/Icon\"\r\nimport PercentualBar from \"components/Percentual/bar\"\r\n\r\n//VIEWS\r\n\r\n//DEPENDENCIES\r\nimport AccountData from \"components/Account/edit\"\r\nimport AccountPreffers from \"components/Account/preffers\"\r\nimport SubscriptionDetails from \"components/Account/SubscriptionDetails\"\r\n\r\n//FUNCTIONS\r\nimport apims from \"apims/\";\r\n\r\nimport { getAppAccess, translate, BytesConvert } from \"functions/\"\r\n\r\nimport {\r\n    customApp,\r\n    tokenDecode\r\n} from \"functions\"\r\n\r\nrequire('dotenv').config()\r\n\r\nfunction App(props) {\r\n    const { session, db } = reduxStore.getState()\r\n    const [usedSpace, setUsedSpace] = React.useState(0)\r\n\r\n    React.useEffect(() => {\r\n    }, [])\r\n\r\n    React.useEffect(() => {\r\n        const scrollTimer = setTimeout(() => {\r\n            document.getElementById(\"mainPannel\").scrollTo(0, 0)\r\n        }, 100)\r\n        init()\r\n        return () => {\r\n            clearTimeout(scrollTimer)\r\n        }\r\n    }, [props.history])\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace(\"#\", \"\")\r\n\r\n    if (!window.location.hash.split(\"/\")[0].replace(\"#\", \"\")) {\r\n        history.push(\"sp#tab/home\")\r\n    }\r\n\r\n\r\n    if (hashs[0] && hashs[0].length === 36 && !reduxStore.getState().db.cards[hashs[0]]) {\r\n        history.push(\"/deniedAccess\")\r\n    }\r\n\r\n    const init = async () => {\r\n        try {\r\n            const res = await apims.post('/Account_Space')\r\n            if (res)\r\n                setUsedSpace(parseInt(res.data))\r\n        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    }\r\n    let space = db.plans[0].settings.space\r\n    let subscriptionPlan = db.plans[0]\r\n    if (\r\n        session\r\n        && session.GlobalData\r\n        && String(session.GlobalData.plan)\r\n        && db.plans[session.GlobalData.plan]\r\n        && db.plans[session.GlobalData.plan].settings\r\n    ) {\r\n        space = db.plans[session.GlobalData.plan].settings.space\r\n        subscriptionPlan = db.plans[session.GlobalData.plan]\r\n    }\r\n\r\n    let percent = usedSpace * (100 / parseInt(space))\r\n\r\n\r\n\r\n    return (\r\n        <div>\r\n            {/* <div style={{\r\n                position: \"absolute\",\r\n                left: 0,\r\n                top: 0,\r\n                right: 0,\r\n                padding: 7,\r\n                backgroundColor: \"#FFFFFF\",\r\n                borderRadius: 2,\r\n                boxShadow: \"0px 0px 0px 2px rgba(0,0,0,0.1)\"\r\n            }}> */}\r\n            <GridContainer\r\n                style={{\r\n                    marginBottom: 15,\r\n                    backgroundColor: \"#FFFFFF\",\r\n                    borderRadius: 2,\r\n                    boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                }}\r\n            >\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={6}\r\n                    md={6}\r\n                    lg={6}\r\n                    xl={6}\r\n                    style={{\r\n                        display: \"flex\",\r\n                        alignItems: \"center\"\r\n                    }}\r\n                >\r\n                    <div style={{\r\n                        display: \"flex\",\r\n                        justifyContent: \"space-between\",\r\n                        alignItems: \"center\",\r\n                    }}>\r\n                        <div\r\n                            style={{\r\n                                padding: 10,\r\n                                background: customApp(\"AvatarBackground\"),\r\n                            }}\r\n                        >\r\n                            <Icon icon=\"card_membership\" size={30} color={\"#FFFFFF\"} />\r\n                        </div>\r\n                        <div style={{ marginLeft: 7, width: \"calc(100% - 40px)\" }}>\r\n                            <div\r\n                                style={{\r\n                                    position: \"relative\",\r\n                                    width: \"100%\",\r\n                                    color: customApp(\"menu\"),\r\n                                    fontWeight: \"bolder\",\r\n                                    marginTop: 7,\r\n                                }}>{translate(\"$__subscriptionPlan\", '*')}: {translate(subscriptionPlan.label, '*')}</div>\r\n                            <div style={{\r\n                                width: \"100%\",\r\n                                color: \"mediumgray\",\r\n                                fontSize: 12,\r\n                                fontWeight: \"bold\"\r\n                            }}>{translate(\"$__adminLimit\", 1)}: {subscriptionPlan.settings.admins}</div>\r\n                            <a href=\"#\" style={{\r\n                                position: \"relative\",\r\n                                top: '-7px',\r\n                                color: customApp(\"color\"),\r\n                                fontSize: 10,\r\n                                fontWeight: 'bold'\r\n                            }}>{translate(\"$__viewContract\")}</a>\r\n                        </div>\r\n                    </div>\r\n                </GridItem>\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={6}\r\n                    md={6}\r\n                    lg={6}\r\n                    xl={6}\r\n                    style={{\r\n                        display: \"flex\",\r\n                        alignItems: \"center\"\r\n                    }}\r\n                >\r\n                    <div style={{\r\n                        display: \"flex\",\r\n                        justifyContent: \"space-between\",\r\n                        alignItems: \"center\",\r\n                    }}>\r\n                        <div\r\n                            style={{\r\n                                padding: 10,\r\n                                background: customApp(\"AvatarBackground\"),\r\n                            }}\r\n                        >\r\n                            <Icon icon=\"storage\" size={30} color={\"#FFFFFF\"} />\r\n                        </div>\r\n                        <div style={{ marginLeft: 7, width: \"calc(100% - 40px)\" }}>\r\n                            <div\r\n                                style={{\r\n                                    position: \"relative\",\r\n                                    marginTop: 7,\r\n                                    color: customApp(\"menu\"),\r\n                                    fontWeight: \"bolder\"\r\n                                }}>{translate(\"$__usedStorage\", \"*\")}<span style={{ marginLeft: 15, color: \"red\", fontSize: 11, cursor: \"pointer\" }} onClick={() => {\r\n                                    history.push(\"#tab/subscriptionUpgrade\")\r\n                                }}>{translate(\"$__upgradeSubscription\")}</span>\r\n                            </div>\r\n                            <PercentualBar\r\n                                value={Math.ceil(percent)}\r\n                                background={percent > 100 ? \"red\" : null}\r\n                            />\r\n                            <div>\r\n                                <span style={{\r\n                                    color: percent > 100 ? \"red\" : \"mediumgray\",\r\n                                    fontSize: 12,\r\n                                    fontWeight: \"bold\"\r\n                                }}>{translate(\"$__used\", 1)}: {BytesConvert(usedSpace)}</span> <span style={{ color: \"lightgray\", fontSize: 11 }}>{translate(\"$__of\")} {translate(\"$__accountSpace\", 1)}: {BytesConvert(space)}</span>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </GridItem>\r\n            </GridContainer>\r\n\r\n            {/* </div > */}\r\n            <GridContainer\r\n                style={{\r\n                    // marginTop: 15\r\n                }}\r\n            >\r\n\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={12}\r\n                    md={4}\r\n                    lg={4}\r\n                    xl={4}\r\n                >\r\n                    <div\r\n                        style={{\r\n                            padding: 7,\r\n                            width: \"100%\",\r\n                            backgroundColor: \"#FFFFFF\",\r\n                            borderRadius: 2,\r\n                            boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                        }}\r\n                    >\r\n                        <div>Dados da conta</div>\r\n                        <ErrorBoundary>\r\n                            <AccountData data={session && session.GlobalData ? session.GlobalData : {}} />\r\n                        </ErrorBoundary>\r\n                    </div>\r\n                </GridItem>\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={12}\r\n                    md={4}\r\n                    lg={4}\r\n                    xl={4}\r\n                >\r\n                    <div\r\n                        style={{\r\n                            padding: 7,\r\n                            width: \"100%\",\r\n                            backgroundColor: \"#FFFFFF\",\r\n                            borderRadius: 2,\r\n                            boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                        }}\r\n                    >\r\n                        Preferências\r\n                        <ErrorBoundary>\r\n                            <AccountPreffers data={session && session.GlobalData ? session.GlobalData : {}} />\r\n                        </ErrorBoundary>\r\n                    </div>\r\n                </GridItem>\r\n                <GridItem\r\n                    xs={12}\r\n                    sm={12}\r\n                    md={4}\r\n                    lg={4}\r\n                    xl={4}\r\n                >\r\n                    <div\r\n                        style={{\r\n                            padding: 7,\r\n                            width: \"100%\",\r\n                            backgroundColor: \"#FFFFFF\",\r\n                            borderRadius: 2,\r\n                            boxShadow: \"0px 0px 7px 5px rgba(0,0,0,0.03)\"\r\n                        }}\r\n                    >\r\n                        {translate(\"$__subscriptionDetails\")}\r\n                        <ErrorBoundary>\r\n                            <SubscriptionDetails data={session && session.GlobalData ? session.GlobalData : {}} planDetails={subscriptionPlan} />\r\n                        </ErrorBoundary>\r\n                    </div>\r\n                </GridItem>\r\n            </GridContainer>\r\n        </div>\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    history: store.db.history\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(memo(App))","// ID_CREATED*************************\n\n//CORE\nimport React, { useState } from \"react\"\nimport { Panel as ColorPicker } from 'rc-color-picker';\nimport { GradientPickerPopover } from 'react-linear-gradient-picker';\n\n\n\n//COMPONENTS\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card.js\"\n\n//FUNCTIONS\nimport {\n    hexToRgba\n} from \"functions/\"\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\nimport 'rc-color-picker/assets/index.css';\nimport 'react-linear-gradient-picker/dist/index.css';\n\nconst WrappedColorPicker = ({ onSelect, ...rest }) => (\n    <ColorPicker {...rest} onChange={c => {\n        onSelect(c.color, c.alpha / 100);\n    }}\n        animation=\"slide-up\"\n    />\n);\n\nfunction convertLinearToPallet(x) {\n    let c = x.replace('linear-gradient(90deg,', \"\").replace('radial-gradient(90deg,', \"\")\n    let s = c.split('rgba(')\n    let colors = []\n    s.map(color => {\n        let xc = color.split(') ')\n        if (xc.length === 2) {\n            let cl = xc[0].split(',')\n            let os = (parseInt(xc[1].replace(')', \"\").replace(\"%\", \"\")) / 100).toFixed(2)\n            colors.push({\n                color: `rgb(${cl[0]}, ${cl[1]}, ${cl[2]})`,\n                offset: `${os}`,\n                opacity: `${cl[3]}`\n            })\n        }\n    })\n    return colors\n}\n\nfunction GradientColor(props) {\n    const [open, setOpen] = useState(false);\n    const value = props?.value?.css ? convertLinearToPallet(props.value.css) : props?.value?.color || []\n\n    const setGradientColor = (options) => {\n        let x = options.color\n        let colorConstruct = (!props.type || props.type === 'linear')\n            ? `linear-gradient(90deg, `\n            : `radial-gradient(`\n        x.map((c, i) => {\n            if (c.color.indexOf(\"#\") > -1) {\n                colorConstruct = `${colorConstruct}${hexToRgba(c.color, c.opacity || 1)} ${Math.ceil(c.offset * 100)}% ${i < x.length - 1 ? `,` : ``} `\n            }\n            if (c.color.indexOf(\"rgb\") > -1 && c.color.indexOf(\"rgba\") === -1) {\n                colorConstruct = `${colorConstruct}rgba(${c.color.replace(\"rgb(\", \"\").replace(')', `, ${c.opacity || 1}`)}) ${Math.ceil(c.offset * 100)}% ${i < x.length - 1 ? `,` : ``} `\n            }\n        })\n        colorConstruct = `${colorConstruct})`\n\n        if (props.onChange)\n            props.onChange({\n                css: colorConstruct,\n                palette: x\n            })\n    }\n\n\n    return (\n        <GradientPickerPopover {...{\n            showAnglePicker: false,\n            showGradientTypePicker: false,\n            open,\n            setOpen,\n            width: 320,\n            paletteHeight: 32,\n            palette: value,\n            onPaletteChange: (e) => {\n                setGradientColor({\n                    name: 'ColumnTitleColor',\n                    color: e,\n                })\n            }\n        }}>\n            <WrappedColorPicker />\n        </GradientPickerPopover>\n    )\n}\n\nexport default GradientColor","// ID_CREATED*************************\r\n\r\n//CORE\r\nimport React, { useState } from \"react\"\r\nimport { cpf, cnpj } from 'cpf-cnpj-validator';\r\nimport ColorPicker from 'rc-color-picker';\r\n\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n//COMPONENTS\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport FakeExpanded from \"components/Card/FakeExpanded.js\"\r\nimport GradientColor from \"components/ColorPicker/Gradient\"\r\nimport GridContainer from \"components/Grid/GridContainer\"\r\nimport GridItem from \"components/Grid/GridItem\"\r\nimport HeaderWithMenu from \"components/Header/card\"\r\nimport Icon from \"components/Icon\"\r\nimport ImgCropper from \"components/Cropper\"\r\nimport LinearProgress from \"components/Progress/linear\"\r\nimport TextField from \"components/TextField\"\r\nimport { Paper } from \"@material-ui/core\"\r\n\r\n//@MATERIAL\r\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\r\nimport { withStyles } from \"@material-ui/core/styles\"\r\n\r\n//STYLES\r\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sideModule-Card.js\"\r\n\r\n//FUNCTIONS\r\nimport { upload } from \"functions/upload.js\";\r\nimport {\r\n    translate,\r\n    customApp,\r\n    getAppAccess,\r\n} from \"functions/\"\r\nimport ErrorBoundary from \"components/ErrorBoundary\"\r\n\r\nimport 'rc-color-picker/assets/index.css';\r\nimport 'react-linear-gradient-picker/dist/index.css';\r\n\r\n\r\nfunction Component(props) {\r\n    const { db, session } = reduxStore.getState()\r\n    const { custom } = session\r\n    const [data, setData] = React.useState(session.custom || {})\r\n    const [iniData, setIniData] = React.useState({})\r\n    const [newData, setNewData] = React.useState({})\r\n    const [logo, setLogo] = React.useState(null)\r\n    const [background, setBackground] = React.useState(null)\r\n    const [fieldsRefresh, setFieldsRefresh] = React.useState(false)\r\n    const [saveDataLoading, setSaveDataLoading] = React.useState(false)\r\n    const AppAccess = getAppAccess()\r\n\r\n    React.useEffect(() => {\r\n        let isSubscribed = true\r\n        if (isSubscribed)\r\n            setIniData(session.custom || {})\r\n    }, [])\r\n\r\n    React.useEffect(() => {\r\n        if (fieldsRefresh)\r\n            setTimeout(() => {\r\n                setFieldsRefresh(false)\r\n            }, 500)\r\n    }, [fieldsRefresh])\r\n\r\n    const setCustom = (d) => {\r\n        props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\r\n            ...reduxStore.getState().session,\r\n            custom: {\r\n                ...reduxStore.getState().session.custom,\r\n                [d.name]: d.value\r\n            }\r\n        });\r\n        setNewData({\r\n            ...newData,\r\n            [d.name]: d.value\r\n        })\r\n        setData({\r\n            ...data,\r\n            [d.name]: d.value\r\n        })\r\n    }\r\n\r\n    const resetData = async () => {\r\n        setData(iniData)\r\n        setNewData({})\r\n        props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\r\n            ...reduxStore.getState().session,\r\n            custom: iniData\r\n        });\r\n    }\r\n\r\n    const saveData = async () => {\r\n        setSaveDataLoading(true)\r\n        let newCustom = {\r\n            ...custom?.custom ? JSON.parse(custom?.custom) : {},\r\n            ...newData,\r\n        }\r\n        setData(newCustom)\r\n        setIniData(newCustom)\r\n\r\n\r\n        try {\r\n\r\n            let imageResult = logo ? await upload(session.account, logo) : true\r\n            let backgroundResult = background ? await upload(session.account, background) : true\r\n            if (imageResult && backgroundResult) {\r\n                if (logo) {\r\n                    newCustom = {\r\n                        ...newCustom,\r\n                        customLogo: imageResult\r\n                    }\r\n                }\r\n                if (background) {\r\n                    newCustom = {\r\n                        ...newCustom,\r\n                        loginBackground: backgroundResult\r\n                    }\r\n                }\r\n\r\n                // console.log(newCustom)\r\n                // return false\r\n                const { socket } = reduxStore.getState().functions\r\n                socket.emit(\"data\", {\r\n                    module: \"account\",\r\n                    method: \"post\",\r\n                    action: \"save\"\r\n                }, {\r\n                    custom: JSON.stringify(newCustom)\r\n                }, response => {\r\n                    setSaveDataLoading(false)\r\n                    setNewData({})\r\n                }\r\n                )\r\n            }\r\n        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    }\r\n\r\n    let permission = false\r\n    if (data._id === session._id ||\r\n        (AppAccess\r\n            &&\r\n            (\r\n                AppAccess.user\r\n                && (\r\n                    AppAccess.userAdmin\r\n                    || AppAccess.userEdit\r\n                )\r\n            )\r\n        ))\r\n        permission = true\r\n\r\n    // console.log(data)\r\n    if (data.independentAccount)\r\n        permission = false\r\n\r\n    return (\r\n        <GridContainer>\r\n            <GridItem\r\n                md={4}\r\n            >\r\n                <Paper style={{ marginTop: 15, padding: 7 }}>\r\n                    <fieldset>\r\n                        <legend>{translate(\"$__logo\")}</legend>\r\n                        <ImgCropper\r\n                            maxWidthOrHeight={600}\r\n                            img={custom.customLogo}\r\n                            onChange={(a, file) => {\r\n                                setLogo(file)\r\n                                setCustom({\r\n                                    name: 'customLogo',\r\n                                    value: a\r\n                                })\r\n                            }}\r\n                            transparent\r\n                            ignoreAspect={true}\r\n                            noGuides\r\n                            viewMode={0}\r\n                            accept={\".png\"}\r\n                            checkOrientation\r\n                        />\r\n\r\n                    </fieldset>\r\n                </Paper>\r\n            </GridItem>\r\n            <GridItem\r\n                md={4}\r\n            >\r\n                <Paper style={{ marginTop: 15, padding: 7 }}>\r\n                    <fieldset>\r\n                        <legend>{translate(\"$__loginBackground\")}</legend>\r\n                        <ImgCropper\r\n                            maxWidthOrHeight={2000}\r\n                            img={custom.loginBackground}\r\n                            onChange={(a, file) => {\r\n                                setBackground(file)\r\n                                setCustom({\r\n                                    name: 'loginBackground',\r\n                                    value: a\r\n                                })\r\n                            }}\r\n                            transparent\r\n                            ignoreAspect={true}\r\n                            noGuides\r\n                            viewMode={0}\r\n                            accept={\".jpg, .jpeg\"}\r\n                            checkOrientation\r\n                        />\r\n                    </fieldset>\r\n                </Paper>\r\n            </GridItem>\r\n            <GridItem\r\n                md={4}\r\n            >\r\n                <Paper style={{ marginTop: 15, padding: 7 }}>\r\n                    <fieldset>\r\n                        <legend>{translate(\"$__backgroundColumnsTitle\")}</legend>\r\n                        <HeaderWithMenu\r\n                            title={translate(`$__backgroundColumnsTitle`, 1)}\r\n                            icon={'gradient'}\r\n                            color={customApp('colorText')}\r\n                            style={{\r\n                                background: customApp('ColumnTitleColor'),\r\n                                padding: '7px'\r\n                            }}\r\n                        />\r\n                        <div style={{\r\n                            display: \"flex\",\r\n                            justifyContent: \"center\",\r\n                            alignItems: \"center\",\r\n                            flexFlow: \"wrap\"\r\n                        }}>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <GradientColor value={\r\n                                        {\r\n                                            css: custom.ColumnTitleColor\r\n                                        }\r\n\r\n                                    }\r\n                                        onChange={(e) => {\r\n                                            setCustom({\r\n                                                name: 'ColumnTitleColor',\r\n                                                value: e.css\r\n                                            })\r\n                                        }}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <div style={{ marginRight: 7 }}>{translate(\"$__background\")}</div>\r\n                            </div>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <ColorPicker\r\n                                        enableAlpha={false}\r\n                                        animation=\"slide-up\"\r\n                                        color={custom.colorText || null}\r\n                                        mode={\"RGB\"}\r\n                                        onChange={c => {\r\n                                            setCustom({\r\n                                                name: 'colorText',\r\n                                                value: c.color\r\n                                            })\r\n                                        }}\r\n                                    // placement={\"topLeft\"}\r\n                                    />\r\n                                    <div style={{ marginRight: 7 }}>{translate(\"$__text\")}</div>\r\n                                </ErrorBoundary>\r\n                            </div>\r\n                        </div>\r\n\r\n                    </fieldset>\r\n                </Paper>\r\n            </GridItem>\r\n            <GridItem\r\n                md={4}\r\n            >\r\n                <Paper style={{ marginTop: 15, padding: 7 }}>\r\n                    <fieldset>\r\n                        <legend>{translate(\"$__menu\")}</legend>\r\n                        <div style={{\r\n                            display: \"flex\",\r\n                            justifyContent: \"center\",\r\n                            alignItems: \"center\",\r\n                            flexFlow: \"wrap\"\r\n                        }}>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <GradientColor value={\r\n                                        {\r\n                                            css: custom.menuColor\r\n                                        }\r\n\r\n                                    }\r\n                                        onChange={(e) => {\r\n                                            setCustom({\r\n                                                name: 'menuColor',\r\n                                                value: e.css\r\n                                            })\r\n                                        }}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <div style={{ marginRight: 7 }}>{translate(\"$__background\")}</div>\r\n                            </div>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <ColorPicker\r\n                                        enableAlpha={false}\r\n                                        animation=\"slide-up\"\r\n                                        color={custom.menuButtonColor}\r\n                                        mode={\"RGB\"}\r\n                                        onChange={c => {\r\n                                            setCustom({\r\n                                                name: 'menuButtonColor',\r\n                                                value: c.color\r\n                                            })\r\n                                        }}\r\n                                    // placement={\"topRight\"}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <div style={{ marginRight: 7 }}>{translate(\"$__menuText\")}</div>\r\n                            </div>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <ColorPicker\r\n                                        enableAlpha={false}\r\n                                        animation=\"slide-up\"\r\n                                        color={custom.active}\r\n                                        mode={\"RGB\"}\r\n                                        onChange={c => {\r\n                                            setCustom({\r\n                                                name: 'active',\r\n                                                value: c.color\r\n                                            })\r\n                                        }}\r\n                                    // placement={\"topRight\"}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <div style={{ marginRight: 7 }}>{translate(\"$__menuActiveText\")}</div>\r\n                            </div>\r\n                        </div>\r\n\r\n                    </fieldset>\r\n                </Paper>\r\n            </GridItem>\r\n            <GridItem\r\n                md={4}\r\n            >\r\n                <Paper style={{ marginTop: 15, padding: 7 }}>\r\n                    <fieldset>\r\n                        <legend>{translate(\"$__submenu\")}</legend>\r\n                        <div style={{\r\n                            display: \"flex\",\r\n                            justifyContent: \"center\",\r\n                            alignItems: \"center\",\r\n                            flexFlow: \"wrap\"\r\n                        }}>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <GradientColor value={\r\n                                        {\r\n                                            css: custom.subMenuColor\r\n                                        }\r\n\r\n                                    }\r\n                                        onChange={(e) => {\r\n                                            setCustom({\r\n                                                name: 'subMenuColor',\r\n                                                value: e.css\r\n                                            })\r\n                                        }}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <div style={{ marginRight: 7 }}>{translate(\"$__background\")}</div>\r\n                            </div>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <ColorPicker\r\n                                        enableAlpha={false}\r\n                                        animation=\"slide-up\"\r\n                                        color={custom.subMenuTextColor}\r\n                                        mode={\"RGB\"}\r\n                                        onChange={c => {\r\n                                            setCustom({\r\n                                                name: 'subMenuTextColor',\r\n                                                value: c.color\r\n                                            })\r\n                                        }}\r\n                                    // placement={\"topRight\"}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <div style={{ marginRight: 7 }}>{translate(\"$__menuTextIconColor\")}</div>\r\n                            </div>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <ColorPicker\r\n                                        enableAlpha={false}\r\n                                        animation=\"slide-up\"\r\n                                        color={custom.subMenuTextColorActive}\r\n                                        mode={\"RGB\"}\r\n                                        onChange={c => {\r\n                                            setCustom({\r\n                                                name: 'subMenuTextColorActive',\r\n                                                value: c.color\r\n                                            })\r\n                                        }}\r\n                                    // placement={\"topRight\"}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <div style={{ marginRight: 7 }}>{translate(\"$__subMenuActiveText\")}</div>\r\n                            </div>\r\n                        </div>\r\n\r\n                    </fieldset>\r\n                </Paper>\r\n            </GridItem>\r\n            <GridItem\r\n                md={4}\r\n            >\r\n                <Paper style={{ marginTop: 15, padding: 7 }}>\r\n                    <fieldset>\r\n                        <legend>{translate(\"$__complement\")}</legend>\r\n                        <div style={{\r\n                            display: \"flex\",\r\n                            justifyContent: \"center\",\r\n                            alignItems: \"center\",\r\n                            flexFlow: \"wrap\"\r\n                        }}>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n\r\n                                <ErrorBoundary>\r\n                                    <GradientColor value={\r\n                                        {\r\n                                            css: custom.linearProgress\r\n                                        }\r\n\r\n                                    }\r\n                                        onChange={(e) => {\r\n                                            setCustom({\r\n                                                name: 'linearProgress',\r\n                                                value: e.css\r\n                                            })\r\n                                        }}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <LinearProgress customColor={custom.linearProgress} />\r\n                                <div style={{ marginRight: 7 }}>{translate(\"$__progress\")}</div>\r\n                            </div>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <ColorPicker\r\n                                        enableAlpha={false}\r\n                                        animation=\"slide-up\"\r\n                                        color={custom.color}\r\n                                        mode={\"RGB\"}\r\n                                        onChange={c => {\r\n                                            setCustom({\r\n                                                name: 'color',\r\n                                                value: c.color\r\n                                            })\r\n                                        }}\r\n                                    // placement={\"topRight\"}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <div style={{ marginRight: 7 }}>{translate(\"$__borderColor\")}</div>\r\n                            </div>\r\n                            <div style={{\r\n                                display: \"flex\",\r\n                                justifyContent: \"center\",\r\n                                alignItems: \"center\",\r\n                                width: \"100%\",\r\n                                justifyContent: \"space-between\"\r\n                            }}>\r\n\r\n                                <ErrorBoundary>\r\n                                    <ColorPicker\r\n                                        enableAlpha={false}\r\n                                        animation=\"slide-up\"\r\n                                        color={custom.menu}\r\n                                        mode={\"RGB\"}\r\n                                        onChange={c => {\r\n                                            setCustom({\r\n                                                name: 'menu',\r\n                                                value: c.color\r\n                                            })\r\n                                        }}\r\n                                    // placement={\"topRight\"}\r\n                                    />\r\n                                </ErrorBoundary>\r\n                                <div style={{ marginRight: 7, fontWeight: \"bold\", color: customApp(\"menu\") }}>{translate(\"$__primaryText\")}</div>\r\n                            </div>\r\n                        </div>\r\n\r\n                    </fieldset>\r\n                </Paper>\r\n            </GridItem>\r\n            <GridItem\r\n                md={4}\r\n            >\r\n                <Paper style={{ marginTop: 15, padding: 7 }}>\r\n                    <fieldset>\r\n                        <legend style={{ display: \"flex\", alignItems: \"center\" }}>{translate(\"$__cardImageCover\")}\r\n\r\n                            <GradientColor value={\r\n                                {\r\n                                    css: custom.AvatarBackground,\r\n\r\n                                }\r\n                            }\r\n                                onChange={(e) => {\r\n                                    setCustom({\r\n                                        name: 'AvatarBackground',\r\n                                        value: e.css\r\n                                    })\r\n                                }}\r\n                                type={\"radial\"}\r\n                            />\r\n                            <ColorPicker\r\n                                enableAlpha={false}\r\n                                animation=\"slide-up\"\r\n                                color={custom.avatarIconColor}\r\n                                mode={\"RGB\"}\r\n                                onChange={c => {\r\n                                    setCustom({\r\n                                        name: 'avatarIconColor',\r\n                                        value: c.color\r\n                                    })\r\n                                }}\r\n                            // placement={\"topRight\"}\r\n                            />\r\n                        </legend>\r\n                        <FakeExpanded\r\n                            backgroundColor={custom.AvatarBackground}\r\n                            avatarIconColor={custom.avatarIconColor}\r\n                            responsive\r\n                        />\r\n                    </fieldset>\r\n                </Paper>\r\n            </GridItem>\r\n            <GridItem\r\n                md={4}\r\n            >\r\n                <Paper style={{ marginTop: 15, padding: 7 }}>\r\n                    <fieldset>\r\n                        <legend style={{ display: \"flex\", alignItems: \"center\" }}>\r\n                            {translate(\"$__fields\")}\r\n                        </legend>\r\n                        <div style={{\r\n                            display: \"flex\",\r\n                            justifyContent: \"center\",\r\n                            alignItems: \"center\",\r\n                            width: \"100%\",\r\n                            justifyContent: \"space-between\"\r\n                        }}>\r\n\r\n                            <ErrorBoundary>\r\n                                <ColorPicker\r\n                                    enableAlpha={false}\r\n                                    animation=\"slide-up\"\r\n                                    color={custom.line}\r\n                                    mode={\"RGB\"}\r\n                                    onChange={c => {\r\n                                        setCustom({\r\n                                            name: 'line',\r\n                                            value: c.color\r\n                                        })\r\n                                        setFieldsRefresh(true)\r\n                                    }}\r\n                                // placement={\"topRight\"}\r\n                                />\r\n                            </ErrorBoundary>\r\n                            <div style={{ marginRight: 7 }}>{translate(\"$__line\")}</div>\r\n                        </div>\r\n                        <div style={{\r\n                            display: \"flex\",\r\n                            justifyContent: \"center\",\r\n                            alignItems: \"center\",\r\n                            width: \"100%\",\r\n                            justifyContent: \"space-between\"\r\n                        }}>\r\n\r\n                            <ErrorBoundary>\r\n                                <ColorPicker\r\n                                    enableAlpha={false}\r\n                                    animation=\"slide-up\"\r\n                                    color={custom.medium}\r\n                                    mode={\"RGB\"}\r\n                                    onChange={c => {\r\n                                        setCustom({\r\n                                            name: 'medium',\r\n                                            value: c.color\r\n                                        })\r\n                                        setFieldsRefresh(true)\r\n                                    }}\r\n                                // placement={\"topRight\"}\r\n                                />\r\n                            </ErrorBoundary>\r\n                            <div style={{ marginRight: 7 }}>{translate(\"$__inputAdorment\")}</div>\r\n                        </div>\r\n                        {!fieldsRefresh ?\r\n                            <TextField\r\n                                label={translate(\"$__field\", 1)}\r\n                                variant={custom.fieldVariant}\r\n                                name={\"field\"}\r\n                                // InputLabelProps={{\r\n                                //     shrink: true,\r\n                                // }}\r\n                                InputProps={{\r\n                                    autoComplete: \"new-password\",\r\n                                    endAdornment: (\r\n                                        <InputAdornment position=\"end\">\r\n                                            <Icon icon=\"format_color_fill\" color={custom.medium} />\r\n                                        </InputAdornment>\r\n                                    ),\r\n                                }}\r\n                            />\r\n                            : <TextField\r\n                                label={translate(\"$__field\", 1)}\r\n                                variant={custom.fieldVariant}\r\n                                name={\"field\"}\r\n                                InputLabelProps={{\r\n                                    shrink: true,\r\n                                }}\r\n                                InputProps={{\r\n                                    autoComplete: \"new-password\",\r\n                                    endAdornment: (\r\n                                        <InputAdornment position=\"end\">\r\n                                            <Icon icon=\"format_color_fill\" />\r\n                                        </InputAdornment>\r\n                                    ),\r\n                                }}\r\n                            />\r\n                        }\r\n                    </fieldset>\r\n                </Paper>\r\n            </GridItem>\r\n            {\r\n                JSON.stringify(data) !== JSON.stringify(iniData) ?\r\n                    <div style={{\r\n                        position: \"fixed\",\r\n                        bottom: 50,\r\n                        right: 50,\r\n                        display: \"flex\",\r\n                        justifyContent: \"flex-end\"\r\n                    }}>\r\n                        <div >\r\n                            <CustomButton\r\n                                // shadow\r\n                                title={translate(\"$__reset\")}\r\n                                text={translate(\"$__reset\")}\r\n                                color=\"red\"\r\n                                // tr\r\n                                icon={\"format_color_reset\"}\r\n                                size={\"25px\"}\r\n                                onClick={() => {\r\n                                    resetData()\r\n                                }}\r\n                                load={saveDataLoading}\r\n                            />\r\n                        </div>\r\n                        <div style={{ marginLeft: 15 }}>\r\n                            <CustomButton\r\n                                // shadow\r\n                                title={translate(\"$__save\")}\r\n                                text={translate(\"$__save\")}\r\n                                color=\"green\"\r\n                                // tr\r\n                                icon={\"save\"}\r\n                                size={\"25px\"}\r\n                                onClick={() => {\r\n                                    saveData()\r\n                                    // setEditor(false)\r\n                                }}\r\n                                load={saveDataLoading}\r\n                            />\r\n                        </div>\r\n\r\n                    </div>\r\n                    : <React.Fragment></React.Fragment>\r\n            }\r\n        </GridContainer>\r\n    )\r\n}\r\nconst mapStateToProps = (store) => ({\r\n    session: store.session\r\n})\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\r\n\r\n\r\n/*\r\n<TextField\r\n                            label={translate(dataType && dataType.fieldsTitle && dataType.fieldsTitle.name ? dataType.fieldsTitle.name : \"$__titleOfCard\", 1)}\r\n                            variant={customApp(\"fieldVariant\")}\r\n                            name={\"name\"}\r\n                            InputLabelProps={{\r\n                                shrink: true,\r\n                            }}\r\n                            InputProps={{\r\n                                autoComplete: \"new-password\",\r\n                                endAdornment: (\r\n                                    <InputAdornment position=\"end\">\r\n                                        <Icon icon=\"view_headline\" />\r\n                                    </InputAdornment>\r\n                                ),\r\n                                onChange: (d) => {\r\n                                    changeData(d.target)\r\n                                },\r\n                            }}\r\n                            value={data && data.name ? data.name : \"\"}\r\n                            placeholder={translate(dataType && dataType.fieldsTitle && dataType.fieldsTitle.placeholder && dataType.fieldsTitle.placeholder.name ? dataType.fieldsTitle.placeholder.name : \"$__titleOfCard_placeholder\", 1)}\r\n                            disabled={!permission || data.status === \"completed\" || (dataType && dataType.disabledFields && dataType.disabledFields.indexOf(\"name\") > -1) ? true : false}\r\n                        />\r\n*/","import React, { memo } from \"react\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\nimport history from \"store/history\"\r\n\r\n//DEPENDENCIES\r\nimport Invoices from \"./invoices\"\r\nimport Integrations from \"./integrations\"\r\nimport Profile from \"./profile\"\r\nimport Resume from \"./resume\"\r\nimport WhiteLabel from \"./whiteLabel\"\r\n\r\n//FUNCTIONS\r\nimport { getAppAccess, translate } from \"functions/\"\r\n\r\nimport { customApp } from \"functions\"\r\nimport ErrorBoundary from \"components/ErrorBoundary\"\r\n\r\nfunction App(props) {\r\n    // React.useEffect(() => {\r\n    //     console.log(\"accAdmin\")\r\n    // }, [])\r\n\r\n    React.useEffect(() => {\r\n        const scrollTimer = setTimeout(() => {\r\n            document.getElementById(\"mainPannel\").scrollTo(0, 0)\r\n        }, 100)\r\n        return () => {\r\n            clearTimeout(scrollTimer)\r\n        }\r\n    }, [props.history])\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace(\"#\", \"\")\r\n\r\n    if (!window.location.hash.split(\"/\")[0].replace(\"#\", \"\")) {\r\n        history.push(\"acc#tab/resume\")\r\n    }\r\n\r\n    return (\r\n        <div>\r\n            {/* <CardsLoader /> */}\r\n            {hashs[1] && hashs[1] === \"resume\" ?\r\n                <ErrorBoundary>\r\n                    <Resume />\r\n                </ErrorBoundary>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n            {hashs[1] && hashs[1] === \"profile\" ?\r\n                <ErrorBoundary>\r\n                    <Profile />\r\n                </ErrorBoundary>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n            {hashs[1] && hashs[1] === \"whiteLabel\" ?\r\n                <ErrorBoundary>\r\n                    <WhiteLabel />\r\n                </ErrorBoundary>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n            {hashs[1] && hashs[1] === \"integrations\" ?\r\n                <ErrorBoundary>\r\n                    <Integrations />\r\n                </ErrorBoundary>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n            {hashs[1] && hashs[1] === \"invoicing\" ?\r\n                <ErrorBoundary>\r\n                    <Invoices />\r\n                </ErrorBoundary>\r\n                : <React.Fragment></React.Fragment>\r\n            }\r\n            {/* {(!hashs[0] || (hashs[0] && hashs[0].replace(\"#\", \"\").length !== 36)) && hashs[1] === \"home\" ?\r\n                <React.Fragment>\r\n                    <HomePlans />\r\n                </React.Fragment>\r\n                : (!hashs[0] || (hashs[0] && hashs[0].replace(\"#\", \"\").length !== 36)) && hashs[1] === \"completed\" ?\r\n                    <React.Fragment>\r\n                        <HomePlans completed={true} />\r\n                    </React.Fragment>\r\n                    :\r\n                    (!hashs[0]\r\n                        ||\r\n                        (hashs[0]\r\n                            && hashs[0].replace(\"#\", \"\").length !== 36\r\n                        )\r\n                    )\r\n                    &&\r\n                    // <Plans />\r\n            } */}\r\n            {/* {hashs[0].length === 36 && reduxStore.getState().db.cards[hashs[0].replace(\"#\", \"\")] ?\r\n                <React.Fragment>\r\n                    {hashs[1] && hashs[1] === \"matrix\" &&\r\n                        <Matrix />\r\n                    }\r\n                    {hashs[1] && (hashs[1] === \"actions\" || hashs[1] === \"guidelines\" || hashs[1] === \"objectives\" || hashs[1] === \"goals\")\r\n                        &&\r\n                        <Actions type={hashs[1]} />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"dashboard\" &&\r\n                        <Dashboard />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"overview\" &&\r\n                        <Overview />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"bright-and-connected\" &&\r\n                        <React.Fragment>\r\n                            <BrightAndConnected />\r\n                        </React.Fragment>\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"insight-boards\" &&\r\n                        <InsightBoards />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"radar\" &&\r\n                        <Radar />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"library\" &&\r\n                        <Library />\r\n                    }\r\n                    {hashs[1] && hashs[1] === \"planningBoard\" &&\r\n                        <iframe\r\n                            style={{ position: \"absolute\", width: \"calc(100% - 30px)\", height: \"100%\", border: 'none' }}\r\n                            src={`https://miro.com/app/live-embed/${reduxStore.getState().db.cards[hashs[0]].miroBoard}=/?embedAutoplay=true&moveToViewport=-23165,-5837,13803,7546`}\r\n                        ></iframe>\r\n                    }\r\n                </React.Fragment>\r\n                :\r\n                <React.Fragment>\r\n                </React.Fragment>\r\n            } */}\r\n        </div >\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    history: store.db.history\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps,\r\n    mapDispatchToProps\r\n)(memo(App))","import React from \"react\";\n\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n// core components\nimport GridContainer from \"components/Grid/GridContainer.js\";\nimport GridItem from \"components/Grid/GridItem.js\";\n\nimport styles from \"assets/jss/material-dashboard-pro-react/views/errorPageStyles.js\";\nimport { customApp } from \"functions\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function ErrorPage() {\n    const classes = useStyles();\n    return (\n        <div className={classes.contentCenter}>\n            <GridContainer>\n                <GridItem md={12}>\n                    <h1 className={classes.title} style={{ color: customApp(\"color\") }}>\\o/</h1>\n                    <h2 className={classes.subTitle} style={{ color: customApp(\"menu\") }}>Você já utilizou o número de usuários contratados</h2>\n                    <h4 className={classes.description} style={{ color: customApp(\"menu\") }}>\n                        Entre em contato com nossos consultores para solicitar um upgrade do seu plano.\n                    </h4>\n                </GridItem>\n            </GridContainer>\n        </div>\n    );\n}\n","import React from \"react\";\n\n// @material-ui/core components\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n// core components\nimport GridContainer from \"components/Grid/GridContainer.js\";\nimport GridItem from \"components/Grid/GridItem.js\";\n\nimport styles from \"assets/jss/material-dashboard-pro-react/views/errorPageStyles.js\";\nimport { customApp, translate } from \"functions\";\n\nconst useStyles = makeStyles(styles);\n\nexport default function ErrorPage() {\n    const classes = useStyles();\n    return (\n        <div className={classes.contentCenter}>\n            <GridContainer>\n                <GridItem md={12}>\n                    <h1 className={classes.title} style={{ color: customApp(\"color\") }}>\\o/</h1>\n                    <h2 className={classes.subTitle} style={{ color: customApp(\"menu\") }}>{translate(\"$__accessDenied\", '*')}</h2>\n                    <h4 className={classes.description} style={{ color: customApp(\"menu\") }}>\n                        {translate(\"$__accessDeniedDescription\", '*')}\n                    </h4>\n                </GridItem>\n            </GridContainer>\n        </div>\n    );\n}\n","//VIEWS\r\nimport ActivateUserPage from \"views/Pages/ActivateUser\"\r\nimport BackOffice from \"views/BackOffice\"\r\nimport BrightAndConnected from \"views/BrightAndConnected\"\r\nimport Calendar from \"views/Calendar/Calendar\"\r\nimport Dashboard from \"views/Dashboard\"\r\nimport ErrorPage from \"views/Pages/ErrorPage\"\r\nimport Library from \"views/Library\"\r\nimport LoginPage from \"views/Pages/LoginPage\"\r\nimport MaintenancePage from \"views/Pages/MaintenancePage\"\r\nimport OfflinePage from \"views/Pages/OffLinePage\"\r\nimport MyTasks from \"views/MyTasks\"\r\nimport MasterAdmin from \"views/MasterAdmin\"\r\nimport Notifications from \"views/Notifications\"\r\nimport RegisterPage from \"views/Pages/RegisterPage\"\r\nimport StrategyAndPlans from \"views/StrategyAndPlans\"\r\nimport Tags from \"views/Tags\"\r\nimport Users from \"views/Users\"\r\nimport Profile from \"views/Profile/\"\r\nimport Account from \"views/Account/\"\r\nimport SubscriptionUpgrade from \"views/Pages/subscriptionPlan\"\r\nimport DeniedAccess from \"views/Pages/deniedAccess\"\r\n\r\n//ICONS\r\nimport Matrix from \"assets/icons/Matrix\"\r\nimport Bright from \"assets/icons/BrigthAndConnected\"\r\nimport Ideas from \"assets/icons/Ideas\"\r\n\r\n\r\nvar dashRoutes = [\r\n  {\r\n    path: \"/d\",\r\n    name: \"DASHBOARD\",\r\n    alias: 'Dashboard',\r\n    icon: 'dashboard',\r\n    component: Dashboard,\r\n    show: true,\r\n    auth: true,\r\n    search: false,\r\n    tabs: [\r\n      {\r\n        path: \"resume\",\r\n        name: \"RESUME\",\r\n        alias: \"home\",\r\n        icon: 'space_dashboard',\r\n        show: true,\r\n        auth: true,\r\n      },\r\n      {\r\n        path: \"dayTasks\",\r\n        name: \"DAYTASKS\",\r\n        alias: \"dayTasks\",\r\n        icon: 'hail',\r\n        show: true,\r\n        auth: true,\r\n        AppAccess: ['planAdmin', 'planModerate'],\r\n      },\r\n    ]\r\n  },\r\n  {\r\n    path: \"/bright-and-connected\",\r\n    name: \"BRIGHTANDCONNECTED\",\r\n    alias: \"brightandconnected\",\r\n    icon: Bright,\r\n    component: BrightAndConnected,\r\n    show: true,\r\n    auth: true,\r\n    subMenu: true,\r\n    searchFields: ['tags', 'text'],\r\n    tabs: [\r\n      {\r\n        path: \"home\",\r\n        name: \"home\",\r\n        alias: \"home\",\r\n        icon: \"home\",\r\n        show: true,\r\n        auth: true,\r\n      },\r\n      {\r\n        path: \"feeds\",\r\n        name: \"FEEDS\",\r\n        alias: \"feeds\",\r\n        icon: \"menu_book\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['tags', 'text'],\r\n      },\r\n\r\n      {\r\n        path: \"radar\",\r\n        name: \"radar\",\r\n        alias: \"radar\",\r\n        icon: \"settings_input_antenna\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['tags', 'text', 'users', 'priority'],\r\n      },\r\n      {\r\n        path: \"insight-boards\",\r\n        name: \"INSIGHTS\",\r\n        alias: \"insights\",\r\n        icon: Ideas,\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['tags', 'text', 'users', 'priority'],\r\n      },\r\n      {\r\n        path: \"allNews\",\r\n        name: \"allNews\",\r\n        alias: \"allNews\",\r\n        icon: \"feed\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['tags', 'text'],\r\n      }, {\r\n        path: \"hideFeeds\",\r\n        name: \"HIDEFEEDS\",\r\n        alias: \"hideFeeds\",\r\n        icon: \"visibility_off\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['tags', 'text'],\r\n      },\r\n    ]\r\n  },\r\n  {\r\n    path: \"/c\",\r\n    name: \"Users\",\r\n    alias: 'users',\r\n    icon: 'business',\r\n    component: Users,\r\n    show: true,\r\n    auth: true,\r\n    search: true,\r\n    subMenu: true,\r\n    searchFields: ['text', 'tags', 'users', 'userGroup'],\r\n    tabs: [\r\n      {\r\n        path: \"users\",\r\n        name: \"USERS\",\r\n        alias: \"users\",\r\n        icon: \"supervised_user_circle\",\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'userGroup'],\r\n      },\r\n      {\r\n        path: \"units\",\r\n        name: \"units\",\r\n        alias: \"units\",\r\n        icon: \"business\",\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'userGroup'],\r\n      },\r\n      {\r\n        path: \"departments\",\r\n        name: \"departments\",\r\n        alias: \"departments\",\r\n        icon: \"group_work\",\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    path: \"/sp\",\r\n    name: \"Strategy & Plans\",\r\n    alias: \"plan\",\r\n    icon: 'view_comfy',\r\n    component: StrategyAndPlans,\r\n    show: true,\r\n    auth: true,\r\n    search: true,\r\n    subMenu: true,\r\n    searchFields: ['text', 'tags', 'users', 'priority', 'units', 'status'],\r\n    tabs: [\r\n      {\r\n        path: \"home\",\r\n        name: \"home\",\r\n        alias: \"home\",\r\n        icon: \"home\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'units', 'status'],\r\n        hashId: false,\r\n      },\r\n      {\r\n        path: \"StrategyAndPlans\",\r\n        name: \"StrategyAndPlans\",\r\n        alias: \"StrategyAndPlans\",\r\n        icon: \"view_comfy\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'units', 'status'],\r\n        hashId: false,\r\n      },\r\n      {\r\n        path: \"archived\",\r\n        name: \"archivedPlans\",\r\n        alias: \"archivedPlans\",\r\n        icon: \"archive\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'units', 'status'],\r\n        hashId: false,\r\n      },\r\n      {\r\n        path: \"admin\",\r\n        name: \"admin\",\r\n        alias: \"admin\",\r\n        icon: \"admin_panel_settings\",\r\n        show: true,\r\n        auth: true,\r\n        AppAccess: ['planAdmin'],\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'units', 'status'],\r\n        hashId: false,\r\n      },\r\n      {\r\n        path: \"templates\",\r\n        name: \"templates\",\r\n        alias: \"templates\",\r\n        icon: \"smart_button\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'units', 'status'],\r\n        hashId: false,\r\n      },\r\n      {\r\n        path: \"completed\",\r\n        name: \"completed\",\r\n        alias: \"completed\",\r\n        icon: \"assignment_turned_in\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'units', 'status'],\r\n        hashId: false,\r\n      },\r\n      {\r\n        path: \"trash\",\r\n        name: \"trash\",\r\n        alias: \"trash\",\r\n        icon: \"recycling\",\r\n        show: true,\r\n        auth: true,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'units', 'status'],\r\n        hashId: false,\r\n      },\r\n      {\r\n        path: \"dashboard\",\r\n        name: \"dashboard\",\r\n        alias: \"home\",\r\n        icon: \"dashboard\",\r\n        show: true,\r\n        auth: true,\r\n        permission: 4,\r\n        search: false,\r\n        searchFields: [],\r\n        hashId: true,\r\n        templates: true,\r\n      },\r\n      {\r\n        path: \"overview\",\r\n        name: \"OVERVIEW\",\r\n        alias: \"overview\",\r\n        icon: \"select_all\",\r\n        show: true,\r\n        auth: true,\r\n        permission: 4,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'status', 'date'],\r\n        hashId: true,\r\n        templates: true,\r\n      },\r\n      {\r\n        path: \"board\",\r\n        name: \"board\",\r\n        alias: \"board\",\r\n        icon: \"view_week\",\r\n        show: true,\r\n        auth: true,\r\n        permission: 3,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'status', 'date'],\r\n        hashId: true,\r\n        templates: true,\r\n      },\r\n      {\r\n        path: \"matrix\",\r\n        name: \"MATRIX SWOT\",\r\n        alias: \"matrix\",\r\n        icon: Matrix,\r\n        show: true,\r\n        auth: true,\r\n        permission: 3,\r\n        search: false,\r\n        searchFields: ['text', 'tags', 'users'],\r\n        hashId: true,\r\n        templates: true,\r\n      },\r\n      {\r\n        path: \"guidelines\",\r\n        name: \"guidelines\",\r\n        alias: \"guidelines\",\r\n        icon: 'alt_route',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'groups', 'status', 'date'],\r\n        hashId: true,\r\n      },\r\n      {\r\n        path: \"objectives\",\r\n        name: \"objectives\",\r\n        alias: \"objectives\",\r\n        icon: 'gps_fixed',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'groups', 'status', 'date'],\r\n        hashId: true,\r\n      },\r\n      {\r\n        path: \"goals\",\r\n        name: \"goals\",\r\n        alias: \"goals\",\r\n        icon: 'flag',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'groups', 'status', 'date'],\r\n        hashId: true,\r\n      },\r\n      {\r\n        path: \"actions\",\r\n        name: \"ACTIONS\",\r\n        alias: \"actions\",\r\n        icon: \"playlist_play\",\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'priority', 'status', 'date'],\r\n        hashId: true,\r\n      },\r\n      {\r\n        path: \"bright-and-connected\",\r\n        name: \"feeds\",\r\n        alias: \"feeds\",\r\n        icon: 'menu_book',\r\n        show: true,\r\n        auth: true,\r\n        permission: 3,\r\n        search: false,\r\n        searchFields: ['tags', 'text'],\r\n        hashId: true,\r\n        templates: true,\r\n      },\r\n      {\r\n        path: \"radar\",\r\n        name: \"radar\",\r\n        alias: \"radar\",\r\n        icon: \"settings_input_antenna\",\r\n        show: true,\r\n        auth: true,\r\n        permission: 3,\r\n        search: true,\r\n        searchFields: ['tags', 'text'],\r\n        hashId: true,\r\n        templates: true,\r\n      },\r\n      {\r\n        path: \"insight-boards\",\r\n        name: \"INSIGHTS\",\r\n        alias: \"insights\",\r\n        icon: Ideas,\r\n        show: true,\r\n        auth: true,\r\n        permission: 3,\r\n        search: true,\r\n        searchFields: ['tags', 'text'],\r\n        hashId: true,\r\n        templates: true,\r\n      },\r\n      {\r\n        path: \"library\",\r\n        name: \"library\",\r\n        alias: \"library\",\r\n        icon: \"folder\",\r\n        show: true,\r\n        auth: true,\r\n        permission: 3,\r\n        search: true,\r\n        searchFields: ['text'],\r\n        hashId: true,\r\n      },\r\n    ]\r\n  },\r\n  {\r\n    path: \"/t\",\r\n    name: \"Tasks\",\r\n    alias: \"tasks\",\r\n    component: MyTasks,\r\n    icon: 'recent_actors',\r\n    show: true,\r\n    auth: true,\r\n    permission: 1,\r\n    hashId: false,\r\n    search: true,\r\n    subMenu: true,\r\n    searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n    tabs: [\r\n      {\r\n        path: \"myDay\",\r\n        name: \"myDay\",\r\n        alias: \"myDay\",\r\n        icon: 'today',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"ourDay\",\r\n        name: \"ourDay\",\r\n        alias: \"ourDay\",\r\n        icon: 'reduce_capacity',\r\n        show: true,\r\n        auth: true,\r\n        permission: 3,\r\n        AppAccess: ['planAdmin', 'planModerate'],\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"allTasks\",\r\n        name: \"allTasks\",\r\n        alias: \"allTasks\",\r\n        icon: 'how_to_reg',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"myTasks\",\r\n        name: \"myTasks\",\r\n        alias: \"myTasks\",\r\n        icon: 'admin_panel_settings',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"unreaded\",\r\n        name: \"unreaded\",\r\n        alias: \"unreaded\",\r\n        icon: 'notifications_active',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"private\",\r\n        name: \"private\",\r\n        alias: \"private\",\r\n        icon: 'private_connectivity',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"unlinkedCards\",\r\n        name: \"unlinkedCards\",\r\n        alias: \"unlinkedCards\",\r\n        icon: 'link_off',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"planningCards\",\r\n        name: \"planningCards\",\r\n        alias: \"planningCards\",\r\n        icon: 'apps',\r\n        show: true,\r\n        auth: true,\r\n        AppAccess: ['planAdmin', 'planModerate'],\r\n        permission: 5,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"guidelines\",\r\n        name: \"guidelines\",\r\n        alias: \"plansGuidelines\",\r\n        icon: Matrix,\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"objectives\",\r\n        name: \"objectives\",\r\n        alias: \"plansObjectives\",\r\n        icon: 'gps_fixed',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"goals\",\r\n        name: \"goals\",\r\n        alias: \"plansGoals\",\r\n        icon: 'flag',\r\n        show: true,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"lateTasks\",\r\n        name: \"lateTasks\",\r\n        alias: \"lateTasks\",\r\n        icon: 'playlist_play',\r\n        show: false,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n      {\r\n        path: \"nextTasks\",\r\n        name: \"nextTasks\",\r\n        alias: \"nextTasks\",\r\n        icon: 'playlist_play',\r\n        show: false,\r\n        auth: true,\r\n        permission: 1,\r\n        search: true,\r\n        searchFields: ['text', 'tags', 'users', 'plans', 'priority', 'units', 'groups', 'status', 'date'],\r\n      },\r\n    ]\r\n  },\r\n  {\r\n    path: \"/tags\",\r\n    name: \"Tags\",\r\n    alias: \"Tags\",\r\n    component: Tags,\r\n    icon: 'turned_in',\r\n    show: true,\r\n    auth: true,\r\n    search: true,\r\n    subMenu: true,\r\n    permission: 1,\r\n  },\r\n  {\r\n    path: \"/plataformAdministrator\",\r\n    name: \"BackOffice\",\r\n    alias: 'BackOffice',\r\n    icon: 'business',\r\n    component: BackOffice,\r\n    access: ['_isDeveloper'],\r\n    show: false,\r\n    auth: true,\r\n    search: false,\r\n    tabs: [\r\n      {\r\n        path: \"versions\",\r\n        name: \"versions\",\r\n        alias: \"versions\",\r\n        icon: \"app_registration\",\r\n        show: true\r\n      },\r\n      {\r\n        path: \"accounts\",\r\n        name: \"accounts\",\r\n        alias: \"accounts\",\r\n        icon: \"account_box\",\r\n        show: true\r\n      },\r\n      {\r\n        path: \"languages\",\r\n        name: \"languages\",\r\n        alias: \"languages\",\r\n        icon: 'translate',\r\n        show: true\r\n      },\r\n      {\r\n        path: \"feeds\",\r\n        name: \"feeds\",\r\n        alias: \"feeds\",\r\n        icon: \"rss_feed\",\r\n        show: true\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    path: \"/masterAdmin\",\r\n    name: \"masterAdmin\",\r\n    alias: 'masterAdmin',\r\n    icon: 'admin_panel_settings',\r\n    component: MasterAdmin,\r\n    show: false,\r\n    access: ['_isAdmin'],\r\n    auth: true,\r\n    search: false,\r\n    tabs: [\r\n      // {\r\n      //   path: \"accounts\",\r\n      //   name: \"accounts\",\r\n      //   alias: \"accounts\",\r\n      //   icon: \"account_box\",\r\n      //   show: true\r\n      // },\r\n      {\r\n        path: \"accounts\",\r\n        name: \"accounts\",\r\n        alias: \"accounts\",\r\n        icon: \"account_box\",\r\n        show: true\r\n      },\r\n      {\r\n        path: \"languages\",\r\n        name: \"languages\",\r\n        alias: \"languages\",\r\n        icon: 'translate',\r\n        show: true\r\n      },\r\n      {\r\n        path: \"feeds\",\r\n        name: \"feeds\",\r\n        alias: \"feeds\",\r\n        icon: \"rss_feed\",\r\n        show: true\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    path: \"/notifications\",\r\n    name: \"Notifications\",\r\n    alias: 'Notifications',\r\n    icon: 'notifications',\r\n    component: Notifications,\r\n    show: false,\r\n    auth: true,\r\n  },\r\n  {\r\n    collapse: true,\r\n    name: \"Pages\",\r\n    icon: 'image',\r\n    state: \"pageCollapse\",\r\n    show: false,\r\n    views: [\r\n      {\r\n        path: \"/activate\",\r\n        name: \"Activate User\",\r\n        mini: \"AU\",\r\n        component: ActivateUserPage,\r\n        show: true,\r\n        auth: false\r\n      },\r\n      {\r\n        path: \"/login\",\r\n        name: \"Login Page\",\r\n        mini: \"L\",\r\n        component: LoginPage,\r\n        show: true,\r\n        auth: false\r\n      },\r\n      {\r\n        path: \"/register\",\r\n        name: \"Register Page\",\r\n        mini: \"R\",\r\n        component: RegisterPage,\r\n        show: true,\r\n        auth: false\r\n      },\r\n      {\r\n        path: \"/error-page\",\r\n        name: \"Error Page\",\r\n        mini: \"E\",\r\n        component: ErrorPage,\r\n        show: true,\r\n        auth: true\r\n      },\r\n      {\r\n        path: \"/maintenance-mode\",\r\n        name: \"Maintenance Mode\",\r\n        mini: \"E\",\r\n        component: MaintenancePage,\r\n        show: false,\r\n        auth: false\r\n      },\r\n      {\r\n        path: \"/offline-detect\",\r\n        name: \"Offline detect\",\r\n        mini: \"O\",\r\n        component: OfflinePage,\r\n        show: false,\r\n        auth: false\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    path: \"/calendar\",\r\n    name: \"Calendar\",\r\n    icon: 'date_range',\r\n    component: Calendar,\r\n    show: true,\r\n    auth: true,\r\n    search: true,\r\n    subMenu: true,\r\n    permission: 1,\r\n    searchFields: ['text', 'tags', 'users', 'priority', 'risk', 'complexity', 'impact', 'groups', 'status'],\r\n  },\r\n  {\r\n    path: \"/acc\",\r\n    name: \"Account\",\r\n    icon: 'business',\r\n    alias: \"account\",\r\n    component: Account,\r\n    show: true,\r\n    auth: true,\r\n    subMenu: true,\r\n    permission: 1,\r\n    AppAccess: ['planAdmin'],\r\n    tabs: [\r\n      {\r\n        path: \"resume\",\r\n        name: \"resume\",\r\n        alias: \"resume\",\r\n        icon: 'home',\r\n        show: true,\r\n        auth: true,\r\n        AppAccess: ['planAdmin'],\r\n      },\r\n      {\r\n        path: \"profile\",\r\n        name: \"profile\",\r\n        alias: \"profile\",\r\n        icon: 'badge',\r\n        show: true,\r\n        auth: true,\r\n        AppAccess: ['masterAdmin'],\r\n      },\r\n      {\r\n        path: \"whiteLabel\",\r\n        name: \"whiteLabel\",\r\n        alias: \"whiteLabel\",\r\n        icon: 'palette',\r\n        show: true,\r\n        auth: true,\r\n        AppAccess: ['masterAdmin'],\r\n        accountHas: ['whiteLabel']\r\n      },\r\n      // {\r\n      //   path: \"integrations\",\r\n      //   name: \"integrations\",\r\n      //   alias: \"plataformsIntegrations\",\r\n      //   icon: 'integration_instructions',\r\n      //   show: true,\r\n      //   auth: true,\r\n      //   AppAccess: ['masterAdmin'],\r\n      // },\r\n      // {\r\n      //   path: \"invoicing\",\r\n      //   name: \"invoicing\",\r\n      //   alias: \"invoicing\",\r\n      //   icon: 'payment',\r\n      //   show: true,\r\n      //   auth: true,\r\n      //   AppAccess: ['masterAdmin'],\r\n      // },\r\n    ]\r\n  },\r\n  {\r\n    path: \"/library\",\r\n    name: \"library\",\r\n    alias: \"library\",\r\n    component: Library,\r\n    icon: 'folder',\r\n    show: true,\r\n    auth: true,\r\n    permission: 1,\r\n    hashId: false,\r\n    search: true,\r\n    subMenu: true,\r\n    searchFields: ['text'],\r\n  },\r\n  {\r\n    path: \"/subscriptionUpgrade\",\r\n    name: \"subscriptionUpgrade\",\r\n    alias: \"subscriptionUpgrade\",\r\n    component: SubscriptionUpgrade,\r\n    icon: 'upgrade',\r\n    show: true,\r\n    auth: true,\r\n    permission: 1,\r\n    hashId: false,\r\n  },\r\n  {\r\n    path: \"/deniedAccess\",\r\n    name: \"deniedAccess\",\r\n    alias: \"deniedAccess\",\r\n    component: DeniedAccess,\r\n    icon: 'upgrade',\r\n    show: true,\r\n    auth: true,\r\n    permission: 1,\r\n    hashId: false,\r\n  }\r\n]\r\n\r\nexport default dashRoutes","import {\r\n  defaultFont,\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst styles = (theme) => ({\r\n  ...defaultFont,\r\n  menu: {\r\n    position: 'relative',\r\n    borderRight: customApp('color'),\r\n    display: \"flex\",\r\n    flexDirection: \"column\",\r\n    alignItems: \"center\",\r\n  },\r\n  menuExpanded: {\r\n    position: 'relative',\r\n    borderRight: customApp('color'),\r\n    display: \"flex\",\r\n    flexDirection: \"column\",\r\n    alignItems: \"baseline\",\r\n  },\r\n  button: {\r\n    padding: '7px 0px',\r\n    display: \"flex\",\r\n    justifyContent: \"center\"\r\n  },\r\n  buttonExpanded: {\r\n    padding: '7px 0px',\r\n    display: \"flex\",\r\n    justifyContent: \"left\",\r\n    width: \"100%\"\r\n  },\r\n  buttonColor: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: 'calc(100% + 20px)',\r\n    padding: '20px 12px',\r\n    marginLeft: '-12px',\r\n    display: \"flex\",\r\n    justifyContent: \"center\",\r\n    backgroundColor: customApp('color')\r\n  },\r\n  buttonColorExpanded: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: 'calc(100% + 20px)',\r\n    padding: '12px 12px 12px 20px',\r\n    marginLeft: '-12px',\r\n    display: \"flex\",\r\n    backgroundColor: customApp('color')\r\n  },\r\n  separator: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    padding: '7px',\r\n    borderTop: `1px solid ${customApp('medium', 0.5)}`,\r\n    marginTop: '15px',\r\n    marginBottom: '0px',\r\n    height: '1px'\r\n  }\r\n});\r\n\r\nexport default styles;\r\n","// ID_CREATED*************************\n\n//CORE\nimport React from \"react\";\nimport Routes from \"routes\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\nimport history from \"store/history\";\n\n//COMPONENTS\nimport Filter from \"components/Filter\";\nimport HtmlTooltip from \"components/Tooltip/html\";\nimport IconButton from \"components/CustomButtons/IconButton\";\nimport MoreMenu from \"components/MoreMenu/\"\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport CircularProgress from \"@material-ui/core/CircularProgress\";\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n    getAppAccess,\n} from \"functions/\";\n\nimport { getUserAccess } from \"functions/cards\"\n\nimport {\n    loadCards\n} from \"functions/loadData\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sidebar-submenu\";\n\n//IMAGES\nimport defaultAvatar from \"assets/img/fundo-sonne.png\"\n\n\nfunction Component(props) {\n    const { db, search, session } = reduxStore.getState();\n    const [expandingCards, setExpandingCards] = React.useState(false);\n    const [adminViewLoading, setAdminViewLoading] = React.useState(false);\n    const useStyles = makeStyles(styles);\n    const classes = useStyles();\n    const locationPathName = window.location.pathname.split(\"/\");\n    const pathName = `/${locationPathName[1]}`;\n    const expanded = props.expanded\n\n    React.useEffect(() => {\n        if (search && search.users && search.users.selected && Object.keys(search.users.selected).filter(a => search.users.selected[a] === true).length > 0) {\n\n        } else {\n            props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                ...reduxStore.getState().session,\n                cards: {\n                    ...reduxStore.getState().session.cards,\n                    adminViewLoader: false,\n                    adminView: false\n                }\n            });\n        }\n        return () => {\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                ...reduxStore.getState().db,\n                viewList: false,\n            })\n        }\n    }, [search.users.selected])\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    const pageBase = `${pathName}#${hashs[0] ? hashs[0] : \"tab\"}`\n\n    let AppAccess = getAppAccess()\n    let CardAccess = hashs[0] && hashs[0].length === 36 && db.cards[hashs[0]] && db.cards[hashs[0]].type === \"plan\" ? getUserAccess(hashs[0]) : null\n\n    const expandingAllCards = (v) => {\n        setExpandingCards(v)\n        let cards = reduxStore.getState().db.cards\n        Object.keys(cards).map(a => {\n            if (v && cards[a] && !cards[a]._expanded)\n                cards[a][\"_expanded\"] = v\n            if (!v && cards[a] && cards[a]._expanded)\n                cards[a]._expanded = v\n        })\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cardsExpanded: v,\n            cards: cards\n        })\n    }\n\n    const setAdminView = async (enabled) => {\n        //CREAT A CONDITION USERS TO ADMINVIEW - Precisa estar ao menos com um usuário selecionado para ativar modo ADMIN ***************************************************\n        setAdminViewLoading(true)\n        if (!reduxStore.getState().session.cards.adminViewLoader) {\n            const response = await loadCards(props, null, true)\n            if (reduxStore.getState().session.cards.adminViewLoader || response) {\n                setAdminViewLoading(false)\n                props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                    ...reduxStore.getState().session,\n                    cards: {\n                        ...reduxStore.getState().session.cards,\n                        adminViewLoader: true,\n                        adminView: !reduxStore.getState().session.cards.adminView\n                    }\n                });\n            }\n        } else {\n            setAdminViewLoading(false)\n            props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                ...reduxStore.getState().session,\n                cards: {\n                    ...reduxStore.getState().session.cards,\n                    adminViewLoader: true,\n                    adminView: !reduxStore.getState().session.cards.adminView\n                }\n            });\n        }\n    }\n\n    const openPage = (page) => {\n        history.push(page)\n    }\n\n    return (\n        <React.Fragment>\n            <div className={expanded ? classes.menuExpanded : classes.menu}            >\n                <div className={expanded ? classes.buttonExpanded : classes.button}>\n                    <IconButton\n                        icon={expanded ? \"menu_open\" : \"read_more\"}\n                        text={expanded ? translate(\"$__collapsingMenu\", 1) : null}\n                        title={!expanded ? translate(\"$__expandingMenu\", 1) : null}\n                        iconColor={customApp(\"subMenuTextColor\")}\n                        textColor={customApp(\"subMenuTextColor\")}\n                        onClick={() => {\n                            //setExpanded(!expanded)\n                            props.subMenuExpanded(!expanded)\n                        }}\n                        size={\"21px\"}\n                    />\n                </div>\n                {Routes.filter(a => {\n                    if (hashs[1] && a.tabs && a.tabs.filter(tf => tf.path === hashs[1]).length > 0 && a.tabs.filter(tf => tf.path === hashs[1])[0].search === false)\n                        return false\n                    if (a.path === pathName && String(a.search) === \"true\")\n                        return true\n                }).length > 0\n                    && !props.chat\n                    &&\n                    <div\n                        className={expanded ? classes.buttonExpanded : classes.button}\n                        id={`sideBar_subMenu_filters`}\n                    >\n                        <IconButton\n                            icon=\"filter_alt\"\n                            text={expanded ? translate(\"$__filters\", 1) : null}\n                            title={!expanded ? translate(\"$__filters\", 1) : null}\n                            iconColor={customApp(\"subMenuTextColor\")}\n                            textColor={customApp(\"subMenuTextColor\")}\n                            onClick={() => {\n                                props.subMenuExpanded(!expanded)\n                            }}\n                            size={\"21px\"}\n                        />\n                    </div>\n                }\n                {expanded &&\n                    <React.Fragment>\n                        {Routes.filter(a => {\n                            if (hashs[1] && a.tabs && a.tabs.filter(tf => tf.path === hashs[1]).length > 0 && a.tabs.filter(tf => tf.path === hashs[1])[0].search === false)\n                                return false\n                            if (a.path === pathName && String(a.search) === \"true\")\n                                return true\n                        }).length > 0\n                            && !props.chat\n                            &&\n                            <div\n                                style={{\n                                    position: \"relative\",\n                                    width: \"100%\",\n                                    clear: \"both\"\n                                }}\n                                id={`sideBar_subMenu_filters_options`}\n                            >\n                                <Filter />\n                            </div>\n                        }\n                    </React.Fragment>\n                }\n                {(window.location.pathname === \"/files\" || window.location.pathname === \"/t\" || window.location.pathname === \"/d\" || (window.location.pathname === \"/sp\" && hashs[0] && hashs[0].length === 36)) &&\n                    <React.Fragment>\n                        {!expandingCards ?\n                            <div\n                                className={expanded ? classes.buttonExpanded : classes.button}\n                                id={`sideBar_subMenu_options_expandingCards`}\n                            >\n                                <IconButton\n                                    text={expanded ? translate(\"$__expandingCards\", 1) : null}\n                                    textColor={customApp(\"subMenuTextColor\")}\n                                    title={!expanded ? translate(\"$__expandingCards\", 1) : null}\n                                    icon=\"open_in_full\"\n                                    iconColor={customApp(\"subMenuTextColor\")}\n                                    onClick={() => { expandingAllCards(true) }}\n                                    size={\"21px\"}\n                                />\n                            </div>\n                            :\n                            <div\n                                className={expanded ? classes.buttonExpanded : classes.button}\n                                id={`sideBar_subMenu_options_collapseCards`}\n                            >\n                                <IconButton\n                                    text={expanded ? translate(\"$__collapseCards\", 1) : null}\n                                    textColor={customApp(\"subMenuTextColor\")}\n                                    title={!expanded ? translate(\"$__collapseCards\", 1) : null}\n                                    icon=\"close_fullscreen\"\n                                    iconColor={customApp(\"subMenuTextColor\")}\n                                    onClick={() => { expandingAllCards(false) }}\n                                    size={\"21px\"}\n                                />\n                            </div>\n                        }\n                    </React.Fragment>\n                }\n                {(\n                    (\n                        (\n                            pathName === \"/d\"\n                            && hashs[1] === \"dayTasks\"\n                        )\n                        ||\n                        (\n                            pathName === \"/t\"\n                            && search\n                            && search.users\n                            && search.users.selected\n                            && Object.keys(search.users.selected).filter(a => search.users.selected[a] === true).length > 0\n                        )\n                        ||\n                        (\n                            pathName === \"/sp\"\n                            && !hashs[0]\n                        )\n                    )\n                    && AppAccess\n                    &&\n                    (\n                        AppAccess.owner\n                        ||\n                        (\n                            AppAccess.plan\n                            &&\n                            (\n                                AppAccess.planAdmin\n                                || AppAccess.planModerate\n                            )\n                        )\n                    )\n                ) &&\n                    <div className={expanded ? classes.buttonExpanded : classes.button}\n                        style={{\n                            display: \"flex\"\n                        }}>\n                        {adminViewLoading ?\n                            <CircularProgress size={25} style={{ margin: \"auto\", display: \"flex\" }} />                                    // </div>\n                            :\n                            <IconButton\n                                text={expanded ? translate(\"$__adminViewDescription\", 1) : null}\n                                title={!expanded ? translate(\"$__adminViewDescription\", 1) : null}\n                                textColor={reduxStore.getState().session.cards.adminView ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                iconColor={reduxStore.getState().session.cards.adminView ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                icon=\"groups\"\n                                id={`sideBar_subMenu_options_setAdminView`}\n                                onClick={() => {\n                                    setAdminView()\n                                }}\n                                size={\"21px\"}\n                            />\n                        }\n                    </div>\n                }\n\n                {window.location.pathname === \"/t\" &&\n                    <React.Fragment>\n                        <div\n                            className={expanded ? classes.buttonExpanded : classes.button}\n                            id={`sideBar_subMenu_options_setAdminView`}\n                        >\n                            <IconButton\n                                text={expanded ? translate(\"$__viewInColumns\", 1) : null}\n                                textColor={!db.viewList ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                iconColor={!db.viewList ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                title={!expanded ? translate(\"$__viewInColumns\", 1) : null}\n                                icon=\"view_column\"\n                                onClick={() => {\n                                    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                                        ...reduxStore.getState().db,\n                                        viewList: false,\n                                    })\n                                }}\n                                size={\"21px\"}\n                            />\n                        </div>\n                        <div\n                            className={expanded ? classes.buttonExpanded : classes.button}\n                            id={`sideBar_subMenu_options_viewInList`}\n                        >\n                            <IconButton\n                                text={expanded ? translate(\"$__viewInList\", 1) : null}\n                                title={!expanded ? translate(\"$__viewInList\", 1) : null}\n                                icon=\"list\"\n                                iconColor={db.viewList ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                textColor={db.viewList ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                onClick={() => {\n                                    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                                        ...reduxStore.getState().db,\n                                        viewList: true,\n                                    })\n                                }}\n                                size={\"21px\"}\n                            />\n                        </div>\n                    </React.Fragment>\n                }\n                {\n                    <React.Fragment>\n                        <div\n                            className={classes.separator}\n                        ></div>\n                        {hashs[0] && hashs[0].length === 36 && db.cards[hashs[0]] &&\n                            <div\n                                style={{ zIndex: 1 }}\n                                id={`sideBar_subMenu_plan_infos`}\n                            >\n                                <PlanInfo\n                                    expanded={expanded}\n                                    {...props}\n                                />\n                            </div>\n                        }\n\n                        {Routes.filter(a => a.path === pathName).length > 0\n                            && Routes.filter(a => a.path === pathName)[0].tabs\n                            && Routes.filter(a => a.path === pathName)[0].tabs.length > 0\n                            && ((Routes.filter(a => a.path === pathName)[0].hashId && hashs[0] && hashs[0].length === 36) || !Routes.filter(a => a.path === pathName)[0].hashId) &&\n                            <React.Fragment>\n                                {Routes.filter(a =>\n                                    a.path === pathName\n                                )[0].tabs.filter(a =>\n                                (\n                                    (\n                                        !a.hashId\n                                        && (\n                                            !hashs[0]\n                                            ||\n                                            (\n                                                hashs[0]\n                                                && hashs[0].length < 36\n                                            )\n                                        )\n                                        ||\n                                        (a.hashId\n                                            && hashs[0]\n                                            && hashs[0].length === 36\n                                        )\n                                    )\n                                )\n                                ).map((a, i) => {\n                                    let render = false\n                                    let plan = hashs[0] && hashs[0].length === 36 ? db.cards[hashs[0]] : null\n                                    if (a && a.AppAccess && a.AppAccess.length > 0) {\n                                        a.AppAccess.map(acc => {\n                                            if (AppAccess[acc])\n                                                render = true\n                                        })\n                                    } else if (\n                                        a && !a.AppAccess\n                                    )\n                                        render = true\n\n                                    if (plan\n                                        && plan.isTemplate\n                                        && !a.templates\n                                    )\n                                        render = false\n\n                                    if (a\n                                        && a.AppAccess\n                                        && a.AppAccess.planAdmin\n                                        && !(\n                                            AppAccess\n                                            && AppAccess.plan\n                                            && AppAccess.planAdmin\n                                        )\n                                    )\n                                        render = false\n\n                                    if (\n                                        plan\n                                        && plan.planType\n                                        && (\n                                            a.alias === \"matrix\"\n                                            || a.alias === \"guidelines\"\n                                            || a.alias === \"objectives\"\n                                            || a.alias === \"goals\"\n                                        )\n                                    )\n                                        render = false\n\n                                    if (\n                                        plan\n                                        && a.alias === \"board\"\n                                        && (\n                                            !plan.planType\n                                            ||\n                                            (plan.planType\n                                                && plan.planType !== 'operational'\n                                            )\n                                        )\n                                    )\n                                        render = false\n                                    if (\n                                        plan\n                                        && a.alias === \"matrix\"\n                                        && plan.planType\n                                    )\n                                        render = false\n                                    if (\n                                        plan\n                                        && plan.planType === \"operational\"\n                                        && a.alias === 'overview'\n                                    )\n                                        render = false\n\n                                    if (a.accountHas && a.accountHas.filter(a => session[a]).length === 0)\n                                        render = false\n\n                                    if (\n                                        (\n                                            AppAccess.owner\n                                            ||\n                                            (\n                                                AppAccess\n                                                && AppAccess.enabled\n                                                && render\n                                            )\n                                        )\n                                        && a.show\n                                    )\n                                        return (\n                                            <div\n                                                className={expanded ? classes.buttonExpanded : classes.button}\n                                                key={i}\n                                                id={`sideBar_subMenu_plan_${a.alias}`}\n                                            >\n                                                <IconButton\n                                                    text={expanded ? a.alias === \"matrix\" ? \"MATRIX SWOT\" : translate(`$__${a.alias}`, 1) : null}\n                                                    title={!expanded ? a.alias === \"matrix\" ? \"MATRIX SWOT\" : translate(`$__${a.alias}`, 1) : null}\n                                                    icon={a.icon}\n                                                    iconColor={hashs[1] === a.path ? customApp(\"subMenuTextColorActive\") : customApp(\"subMenuTextColor\")}\n                                                    textColor={hashs[1] === a.path ? customApp(\"subMenuTextColorActive\") : customApp(\"subMenuTextColor\")}\n                                                    onClick={() => {\n                                                        openPage(`${pageBase}/${a.path}`)\n                                                    }}\n                                                    size={\"21px\"}\n                                                />\n                                            </div>\n                                        )\n\n                                }\n                                )}\n                            </React.Fragment>\n                        }\n                        {hashs[0] && hashs[0].length === 36 && db.cards[hashs[0]] && db.cards[hashs[0]].miroBoard &&\n                            <div\n                                className={expanded ? classes.buttonExpanded : classes.button}\n                                id={`sideBar_subMenu_plan_miroBoard`}\n                            >\n                                <IconButton\n                                    text={expanded ? translate(\"$__planningBoard\", 1) : null}\n                                    title={!expanded ? translate(\"$__planningBoard\", 1) : null}\n                                    icon={'developer_board'}\n                                    iconColor={hashs[1] === 'planningBoard' ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                    textColor={hashs[1] === 'planningBoard' ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                    onClick={() => {\n                                        openPage(`${pageBase}/${'planningBoard'}`)\n                                    }}\n                                    size={\"21px\"}\n                                />\n                            </div>\n                        }\n                        {\n                            window.location.pathname === \"/t\" &&\n                            <React.Fragment>\n                                <div\n                                    className={classes.separator}\n                                ></div>\n                                <div\n                                    className={expanded ? classes.buttonExpanded : classes.button}\n                                    id={\"sideBar_subMenu_lastTasks\"}\n                                >\n                                    <IconButton\n                                        text={expanded ? translate(\"$__lateTasks\", 1) : null}\n                                        title={!expanded ? translate(\"$__lateTasks\", 1) : null}\n                                        icon=\"event_busy\"\n                                        iconColor={hashs[1] === \"late\" ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                        textColor={hashs[1] === \"late\" ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                        onClick={() => {\n                                            history.push(\"t#tab/lateTasks\")\n                                        }}\n                                        size={\"21px\"}\n                                    />\n                                </div>\n                                <div\n                                    className={expanded ? classes.buttonExpanded : classes.button}\n                                    id={\"sideBar_subMenu_nextTasks\"}\n                                >\n                                    <IconButton\n                                        text={expanded ? translate(\"$__nextTasks\", 1) : null}\n                                        title={!expanded ? translate(\"$__nextTasks\", 1) : null}\n                                        icon=\"date_range\"\n                                        iconColor={hashs[1] === \"nextTasks\" ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                        textColor={hashs[1] === \"nextTasks\" ? customApp(\"color\") : customApp(\"subMenuTextColor\")}\n                                        onClick={() => {\n                                            history.push(\"t#tab/nextTasks\")\n                                        }}\n                                        size={\"21px\"}\n                                    />\n                                </div>\n                            </React.Fragment>\n                        }\n                    </React.Fragment>\n                }\n            </div>\n        </React.Fragment>\n    )\n}\n\nconst PlanInfo = (props) => {\n    const { db } = reduxStore.getState();\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    let AppAccess = getAppAccess()\n    let CardAccess = hashs[0] && hashs[0].length === 36 && db.cards[hashs[0]] && db.cards[hashs[0]].type === \"plan\" ? getUserAccess(hashs[0]) : null\n\n    let image = hashs && hashs.length > 0 && hashs[0].length === 36 && db.cards[hashs[0]] && db.cards[hashs[0]].image ? db.cards[hashs[0]].image : defaultAvatar\n\n    let planOptions = []\n    if (db.cards[hashs[0]] && db.cards[hashs[0]].client && Object.keys(db.cards).filter(card => !db.cards[card].deleted && db.cards[card].client && db.cards[card].client === db.cards[hashs[0]].client).length > 1)\n        Object\n            .keys(db.cards)\n            .filter(card =>\n                !db.cards[card].deleted\n                && db.cards[card].client === db.cards[hashs[0]].client\n                && db.cards[card].type === 'plan'\n            )\n            .map(card => {\n                planOptions.push({\n                    name: db.cards[card].name,\n                    ...db.cards[card].image ? { avatar: db.cards[card].image } : { icon: 'view_comfy' },\n                    onClick: () => {\n                        history.push(`sp#${db.cards[card]._id}/dashboard`)\n                    }\n                })\n            })\n    return (\n        <HtmlTooltip title={\n            <React.Fragment>\n                {db.cards[hashs[0]].name}\n            </React.Fragment>\n        } >\n            <div\n                style={{\n                    display: \"flex\",\n                    width: \"100%\",\n                    justifyContent: \"left\",\n                    alignItems: \"center\",\n                    ...((CardAccess && parseInt(CardAccess) > 3) || AppAccess.owner || AppAccess.planAdmin || AppAccess.planEdit || AppAccess.planModerate) ?\n                        { cursor: 'pointer' } : {}\n                }\n                }\n                id={\"plan_identification\"}\n                onClick={() => {\n                    if ((CardAccess && parseInt(CardAccess) > 3) || AppAccess.owner || AppAccess.planAdmin || AppAccess.planEdit || AppAccess.planModerate)\n                        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                            ...reduxStore.getState().sideModule,\n                            db: 'cards',\n                            id: hashs[0],\n                            module: \"cardEdit\",\n                            activeModule: 'cardEdit',\n                            data: db.cards[hashs[0]],\n                        })\n\n                }\n                }\n            >\n                <div\n                    style={{\n                        width: \"30px\",\n                        height: \"30px\",\n                        backgroundColor: \"black\",\n                        marginLeft: \"7px\",\n                        marginRight: \"3px\",\n                        borderRadius: \"11px\",\n                        backgroundImage: `url(\"${image}\")`,\n                        backgroundSize: \"cover\",\n                        backgroundPosition: \"center center\"\n                    }}></div>\n                {props.expanded &&\n                    <div style={{ width: \"100%\", zIndex: 1 }}>\n                        {db.cards[hashs[0]].client\n                            && db.users[db.cards[hashs[0]].client] &&\n                            <div\n                                style={{\n                                    fontSize: \"12px\",\n                                    fontWeight: \"bold\",\n                                    marginLeft: \"15px\"\n                                }}>\n                                {db.users[db.cards[hashs[0]].client].name}\n                            </div>\n                        }\n                        <div\n                            style={{\n                                fontSize: \"12px\",\n                                marginLeft: \"7px\",\n                                maxWidth: \"calc(100% - 60px)\",\n                                display: \"flex\",\n                                justifyContent: \"space-between\"\n                            }}\n                            id={\"client_plan_switch\"}\n                        >\n                            {planOptions.length === 0 ?\n                                db.cards[hashs[0]].name\n                                :\n                                <MoreMenu\n                                    text={db.cards[hashs[0]].name}\n                                    icon={'change_circle'}\n                                    transparent\n                                    maxWidth=\"200px\"\n                                    options={planOptions}\n                                />\n                            }\n                        </div>\n                    </div>\n                }\n            </div>\n        </HtmlTooltip>\n    )\n}\n\nconst mapStateToProps = (store, props) => ({\n    ...props,\n    store: {\n        search: store.search,\n        chat: store.chat\n    }\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)","// ID_CREATED*************************\n\n//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport TagsMenu from \"components/Tags/menu\"\nimport ChatCountIcon from \"components/Chat/countIcon\"\n\n//DEPENDENCIES\nimport SubMenu from \"./subMenu\"\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//IMAGES\nimport Bright from \"assets/icons/BrigthAndConnected\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/sidebarInteractive.js\"\n\n//FUNCTIONS\nimport { translate, customApp, getAppAccess } from \"functions/\"\nimport { countUnRead } from \"functions/chat\"\n\nimport packageJson from './../../../package.json';\n\nrequire(\"dotenv\").config()\n\nfunction Component(props) {\n    const { chat } = reduxStore.getState()\n    const { classes } = props\n    const [expanded, setExpanded] = React.useState(false)\n    const [viewModule, setViewModule] = React.useState(null);\n\n    React.useEffect(() => {\n\n    }, [])\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    let AppAccess = getAppAccess()\n    const count = countUnRead()\n\n    const openModule = async (route, vm) => {\n        if (vm === \"tags\") {\n            console.log(58)\n            setExpanded(props.subMenuExpanded)\n            props.setSubMenuExpanded(false)\n        } else {\n            props.setSubMenuExpanded(expanded)\n        }\n        if (route && (window.location.pathname !== route || vm === viewModule)) {\n            history.push(route)\n        }\n\n\n        if (vm === \"chat\") {\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...reduxStore.getState().chat,\n                open: true,\n            })\n        } else {\n            setViewModule(vm)\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...reduxStore.getState().chat,\n                open: false,\n            })\n        }\n    }\n\n    // document.title = `${count && count.total > 0 ? `(${count.total}) ` : ``}MACHEN`\n\n    return (\n        <div\n            className={classes.root}\n        >\n            <div\n                className={classes.bar}\n                style={{\n                    background: customApp(\"menuColor\")\n                }}\n                id=\"sideBar\"\n            >\n                <div className={classes.logoMini}\n                    id=\"sideBar_logoMini\"\n                    style={{\n                        width: \"100%\",\n                        justifyContent: \"space-between\",\n                        display: \"flex\",\n                        cursor: \"pointer\",\n                        color: customApp(\"menuButtonColor\"),\n                        alignItems: \"center\"\n                    }}\n\n                >\n                    <img src={customApp(\"customLogo\")} alt=\"logo\"\n                        style={{\n                            width: \"calc(100% - 70px)\",\n                            marginLeft: \"15px\",\n                            minHeight: \"min-content\"\n                        }}\n                        onClick={() => {\n                            openModule(\"/d#tab/resume\", \"dashboard\")\n                        }}\n                    />\n                    <div\n                        style={{\n                            padding: \"7px\",\n                            marginRight: \"7px\",\n                            cursor: \"pointer\"\n                        }}\n                        onClick={() => {\n                            props.menuExpand()\n                        }}\n                        id={\"sideBar_button_hideMenu\"}\n                    >\n                        <Icon\n                            icon={\"menu\"}\n                            color=\"parent\"\n                            title=\"$__hideMenu\"\n                            size={\"22px\"}\n                        />\n                    </div>\n                </div>\n                <div\n                    style={{\n                        position: \"absolute\",\n                        top: \"100px\",\n                        bottom: \"0px\",\n                        overflowX: \"auto\",\n                        width: \"100%\"\n                    }}\n                >\n\n\n                    <div className={classes.item} id=\"sideBar_button_dashboard\">\n                        <div\n                            className={window.location.pathname === \"/d\" ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule(\"/d#tab/resume\", \"dashboard\")\n                            }\n                            }\n                            style={{\n                                color: customApp(\"menuButtonColor\")\n                            }}\n                        >\n                            <Icon\n                                icon=\"dashboard\"\n                                badgeColor={\"primary\"}\n                                color={\"parent\"}\n                                badgeVisible\n                                title=\"$__dashboard\"\n                                size={\"21px\"}\n                                style={{\n                                    marginBottom: \"0px\",\n                                    marginRight: \"7px\"\n                                }}\n                            />\n                            {translate(`$__dashboard`, \"*\")}\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_brightAndConnected\">\n                        <div className={window.location.pathname === \"/bright-and-connected\" ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule(\"/bright-and-connected#tab/home\", \"bright-and-connected\")\n                            }\n                            }\n                            style={{\n                                color: customApp(\"menuButtonColor\")\n                            }}\n                        >\n                            <Icon\n                                icon={Bright}\n                                badgeColor={\"primary\"}\n                                color={\"parent\"}\n                                badgeVisible\n                                title={\"BRIGHT & CONNECTED\"}\n                                size={\"21px\"}\n                                style={{\n                                    marginRight: \"7px\"\n                                }}\n                            />\n                            BRIGHT & CONNECTED\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_StrategyAndPlans\">\n                        <div className={window.location.pathname === \"/sp\" ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule(\"/sp#tab/home\", \"StrategyAndPlans\")\n                            }\n                            }\n                            style={{\n                                color: customApp(\"menuButtonColor\")\n                            }}\n                        >\n                            <Icon\n                                icon=\"view_comfy\"\n                                badgeColor={\"primary\"}\n                                color={\"parent\"}\n                                badgeVisible\n                                title={translate(\"$__StrategyAndPlans\")}\n                                size={\"21px\"}\n                                style={{\n                                    marginBottom: \"0px\",\n                                    marginRight: \"7px\"\n                                }}\n                            />\n                            {translate(`$__StrategyAndPlans`, \"*\")}\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_myTasks\">\n                        <div className={window.location.pathname === \"/t\" ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule(\"/t#tab/myTasks\", \"myTasks\")\n                            }\n                            }\n                            style={{\n                                color: customApp(\"menuButtonColor\")\n                            }}\n                        >\n                            <Icon\n                                icon=\"task\"\n                                badgeColor={\"primary\"}\n                                color={\"parent\"}\n                                badgeVisible\n                                title={translate(\"$__activities\")}\n                                size={\"21px\"}\n                                style={{\n                                    marginBottom: \"0px\",\n                                    marginRight: \"7px\"\n                                }}\n                            />\n                            {translate(`$__activities`, \"*\")}\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_library\">\n                        <div className={window.location.pathname === \"/library\" ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule(\"/library\", \"library\")\n                            }\n                            }\n                            style={{\n                                color: customApp(\"menuButtonColor\")\n                            }}\n                        >\n                            <Icon\n                                icon=\"folder\"\n                                badgeColor={\"primary\"}\n                                color={\"parent\"}\n                                badgeVisible\n                                title={translate(\"$__library\")}\n                                size={\"21px\"}\n                                style={{\n                                    marginBottom: \"0px\",\n                                    marginRight: \"7px\"\n                                }}\n                            />\n                            {translate(`$__library`, \"*\")}\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_tags\">\n                        <div\n                            className={window.location.pathname === \"/tags\" ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule(\"/tags\", \"tags\")\n                            }\n                            }\n                            style={{\n                                color: customApp(\"menuButtonColor\")\n                            }}\n                        >\n                            <Icon\n                                icon={\"turned_in\"}\n                                badgeColor={\"primary\"}\n                                color={\"parent\"}\n                                badgeVisible\n                                title={translate(\"$__tags\")}\n                                size={\"21px\"}\n                                style={{\n                                    marginBottom: \"0px\",\n                                    marginRight: \"7px\"\n                                }}\n                            />\n                            {translate(\"$__tags\", \"*\")}\n                        </div>\n                    </div>\n                    {/* {console.log(session)} */}\n                    {/* {session && session._isBeta && */}\n                    <div className={classes.item} id=\"sideBar_button_calendar\">\n                        <div className={window.location.pathname === \"/calendar\" ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule(\"/calendar\", \"calendar\")\n                            }\n                            }\n                            style={{\n                                color: customApp(\"menuButtonColor\")\n                            }}\n                        >\n                            <Icon\n                                icon={\"event\"}\n                                badgeColor={\"primary\"}\n                                color={\"parent\"}\n                                badgeVisible\n                                title={translate(\"$__calendar\")}\n                                size={\"21px\"}\n                                style={{\n                                    marginBottom: \"0px\",\n                                    marginRight: \"7px\"\n                                }}\n                            />\n                            {translate(\"$__calendar\", \"*\")}\n                            {/* <div style={{\n                                    position: \"absolute\",\n                                    top: -5,\n                                    right: 5,\n                                    padding: \"1px 6px\",\n                                    backgroundColor: \"green\",\n                                    color: \"white\",\n                                    fontSize: 8,\n                                    fontWeight: \"bold\"\n                                }}>BETA</div> */}\n                        </div>\n                    </div>\n                    {/* } */}\n                    <div className={classes.separator}></div>\n                    <div className={classes.item} id=\"sideBar_button_chat\">\n                        <div className={reduxStore.getState().chat.open ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                                    ...reduxStore.getState().chat,\n                                    open: !reduxStore.getState().chat.open,\n                                })\n                            }\n                            }\n                            style={{\n                                color: customApp(\"menuButtonColor\")\n                            }}\n                        >\n                            <ChatCountIcon>\n                                <Icon\n                                    icon={\"chat\"}\n                                    color={\"parent\"}\n                                    title=\"$__chat\"\n                                    size={\"21px\"}\n                                    style={{\n                                        marginBottom: \"0px\",\n                                        marginRight: \"7px\"\n                                    }}\n                                />\n                            </ChatCountIcon>\n                            {translate(`$__chat`, \"*\")}\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_calendar\">\n                        <div className={classes.itemButtom}\n                            onClick={() => {\n                                window.open(\"https://support.machen.ai\", \"_blank\")\n                            }\n                            }\n                            style={{\n                                color: customApp(\"menuButtonColor\")\n                            }}\n                        >\n                            <Icon\n                                icon={\"help_outline\"}\n                                badgeColor={\"primary\"}\n                                color={\"parent\"}\n                                badgeVisible\n                                title={translate(\"$__support\")}\n                                size={\"21px\"}\n                                style={{\n                                    marginBottom: \"0px\",\n                                    marginRight: \"7px\"\n                                }}\n                            />\n                            {translate(\"$__support\", \"*\")}\n                        </div>\n                    </div>\n\n                </div>\n                {(\n                    viewModule !== \"myDay\"\n                    && viewModule !== \"timer\"\n                    && viewModule !== \"chat\"\n                )\n                    &&\n                    (\n                        window.location.pathname === \"/t\"\n                        || window.location.pathname === \"/sp\"\n                        || window.location.pathname === \"/c\"\n                        || window.location.pathname === \"/d\"\n                        || window.location.pathname === \"/p\"\n                        || window.location.pathname === \"/acc\"\n                        || window.location.pathname === \"/bright-and-connected\"\n                        || window.location.pathname === \"/library\"\n                        || window.location.pathname === \"/notifications\"\n                        || window.location.pathname === \"/calendar\"\n                        || window.location.pathname === \"/masterAdmin\"\n                    )\n                    &&\n                    <div\n                        className={props.subMenuExpanded ? classes.moduleExpanded : classes.module}\n                        id=\"sideBar_subMenu\"\n                        style={{\n                            background: customApp(\"subMenuColor\"),\n                            borderRight: `4px solid ${customApp('color')}`\n                        }}\n                    >\n                        <SubMenu\n                            hashs={hashs}\n                            subMenuExpanded={(a) => { props.setSubMenuExpanded(a) }}\n                            expanded={props.subMenuExpanded}\n                        />\n                    </div>\n                }\n                {(\n                    viewModule !== \"myDay\"\n                    && viewModule !== \"timer\"\n                    && viewModule !== \"chat\"\n                )\n                    &&\n                    (\n                        window.location.pathname === \"/tags\"\n                    )\n                    &&\n                    <div\n                        className={classes.moduleExpanded}\n                        id=\"sideBar_session_tags\"\n                    >\n                        <TagsMenu\n                            onLoad={() => { props.setSubMenuExpanded(true) }}\n                            onExit={() => props.setSubMenuExpanded(false)}\n                        />\n                    </div>\n                }\n                <div style={{ position: \"absolute\", bottom: 0, left: 15, color: \"#c0b283\", fontSize: \"10px\" }}>V:{packageJson.version}</div>\n            </div>\n        </div>\n    )\n}\n\n\n// const mapStateToProps = (store) => ({\n//     store: {\n//         chat: store.chat,\n//         session: store.session\n//     }\n// });\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(null, mapDispatchToProps)(withStyles(styles)(Component))","//CORE\nimport React from 'react'\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport CountIcon from \"./countIcon\"\n\n//@MATERIAL\nimport Button from '@material-ui/core/Button'\n\nfunction Component(props) {\n    const { chat } = reduxStore.getState()\n    const { unreadeds } = props\n\n    return (\n        <div id=\"chatNotificationsBt\"\n            style={{\n                zIndex: '100 !important'\n            }}>\n            <Button\n                aria-haspopup=\"true\"\n                onClick={() => {\n                    props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                        ...chat,\n                        open: !chat.open\n                    })\n                }}\n            >\n                <CountIcon>\n                    <Icon\n                        icon={'chat_bubble_outline'}\n                        color={'parent'}\n                        title=\"$__chat\"\n                    />\n                </CountIcon>\n            </Button>\n        </div >\n    )\n}\n\nconst mapStateToProps = (store, props) => ({\n    ...props,\n    unreadeds: store.chats.unreadeds,\n    chats: store.chats.timelines,\n    chat: store.chat\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","//CORE\nimport React from 'react';\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\nimport { bindActionCreators } from \"redux\";\nimport { connect } from \"react-redux\";\n\n//COMPONENTS\nimport Checklist from \"components/Checklist\";\nimport Icon from \"components/Icon\";\n\n//@MATERIAL\nimport Badge from '@material-ui/core/Badge';\nimport Button from '@material-ui/core/Button';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport Grow from '@material-ui/core/Grow';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport { makeStyles } from '@material-ui/core/styles';\nimport IconButton from '@material-ui/core/IconButton';\n\n\n//FUNCTIONS\nimport { translate, customApp, getAppAccess } from 'functions/';\n\nfunction Component(props) {\n    const { db, timeline, session } = reduxStore.getState()\n    const [open, setOpen] = React.useState(false);\n    const [count, setCount] = React.useState({})\n    const [view, setView] = React.useState('users')\n    const anchorRef = React.useRef(null)\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\n\n    let AppAccess = getAppAccess()\n\n    const handleToggle = () => {\n        setOpen((prevOpen) => !prevOpen);\n    };\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n\n        setOpen(false);\n    };\n\n    let cards = Object.keys(db.cards).filter(a =>\n        !db.cards[a].deleted\n        && !db.cards[a].checklist\n        && db.cards[a]._users\n        && db.cards[a]._users[session._id]\n        && db.cards[a]._users[session._id].myDay\n        && (\n            moment(new Date(db.cards[a]._users[session._id].myDay * 1000)).tz('America/Sao_Paulo').format('YYYY/MM/DD') === today\n        )\n    ).map(a => db.cards[a])\n\n    if (cards.length === 0)\n        return (<React.Fragment></React.Fragment>)\n\n    return (\n        <div id=\"notificationsBt\"\n            style={{\n                zIndex: '100 !important'\n            }}>\n            <Button\n                ref={anchorRef}\n                aria-controls={open ? 'menu-list-grow' : undefined}\n                aria-haspopup=\"true\"\n                onClick={handleToggle}\n            >\n                <Badge\n                    overlap=\"rectangular\"\n                    badgeContent={cards.filter(fil => fil.status !== 'completed').length}\n                    color=\"secondary\"\n                >\n                    <Icon\n                        icon={'hourglass_empty'}\n                        color={'parent'}\n                        title=\"$__myDay\"\n                    />\n                </Badge>\n            </Button>\n            {cards.length > 0 &&\n                <Popper open={open} anchorEl={anchorRef.current} role={undefined} transition disablePortal\n                    style={{ width: '400px' }}\n                >\n                    {({ TransitionProps, placement }) => (\n                        <Grow\n                            {...TransitionProps}\n                            style={{ transformOrigin: placement === 'bottom' ? 'center top' : 'center bottom' }}\n                        >\n                            <Paper>\n                                <ClickAwayListener onClickAway={handleClose}>\n                                    <div style={{\n                                        height: 'auto',\n                                        maxHeight: 'calc(90vh - 80px)',\n                                        width: '100%',\n                                        overflowY: 'auto'\n                                    }}>\n                                        <div\n                                            style={{\n                                                display: 'flex',\n                                                justifyContent: 'space-between',\n                                                alignItems: 'center',\n                                                padding: '7px'\n                                            }}\n                                        >\n                                            {translate('$__myDay')}\n                                        </div>\n                                        <Checklist\n                                            noChecklist\n                                            noDelete\n                                            showCard\n                                            myDay\n                                            db={\"cards\"}\n                                        />\n                                    </div>\n                                </ClickAwayListener>\n                            </Paper>\n                        </Grow>\n                    )}\n                </Popper>\n            }\n        </div >\n    )\n}\n\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","//CORE\nimport React from 'react';\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\nimport { bindActionCreators } from \"redux\";\nimport { connect } from \"react-redux\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport Card from \"components/Card\"\nimport Approve from \"components/Card/approval\"\n\n//@MATERIAL\nimport Badge from '@material-ui/core/Badge';\nimport Button from '@material-ui/core/Button';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport Grow from '@material-ui/core/Grow';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport { makeStyles } from '@material-ui/core/styles';\nimport IconButton from '@material-ui/core/IconButton';\n\n\n//FUNCTIONS\nimport { translate, customApp, getAppAccess } from 'functions/';\n\nfunction Component(props) {\n    const { db, timeline, session } = reduxStore.getState()\n    const [open, setOpen] = React.useState(false);\n    const [count, setCount] = React.useState({})\n    const [view, setView] = React.useState('users')\n    const [cards, setCards] = React.useState([])\n    const anchorRef = React.useRef(null)\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\n\n    React.useEffect(() => {\n        let newCards = Object.keys(db.cards).filter(a =>\n            !db.cards[a].deleted\n            && !db.cards[a].checklist\n            && !db.cards[a].type !== \"chatGroup\"\n            && db.cards[a].status !== \"completed\"\n            && db.cards[a]._requireApproval\n            && (\n                (\n                    db.cards[a]._users[session._id]\n                    && db.cards[a]._users[session._id].approvalResponsible\n                )\n                ||\n                (\n                    Object.keys(db.cards[a]._users).filter(u =>\n                        db.cards[a]._users[u].approvalResponsible\n                    ).length === 0\n                    && db.cards[a]._users[session._id]\n                    && db.cards[a]._users[session._id].isResponsible\n                )\n            )\n        ).map(a => db.cards[a])\n        if (JSON.stringify(newCards) !== JSON.stringify(cards))\n            setCards(newCards)\n        if (newCards.length === 0)\n            setOpen(false)\n    }, [props.cards])\n\n    let AppAccess = getAppAccess()\n\n    const handleToggle = () => {\n        setOpen((prevOpen) => !prevOpen);\n    };\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n\n        setOpen(false);\n    };\n\n    if (cards.length === 0)\n        return (<React.Fragment></React.Fragment>)\n\n    return (\n        <div id=\"notificationsApprovalBt\"\n            style={{\n                zIndex: '100 !important'\n            }}>\n            <Button\n                ref={anchorRef}\n                aria-controls={open ? 'menu-list-grow' : undefined}\n                aria-haspopup=\"true\"\n                onClick={handleToggle}\n            >\n                <Badge\n                    overlap=\"rectangular\"\n                    badgeContent={cards.filter(fil => fil.status !== 'completed').length}\n                    color=\"secondary\"\n                >\n                    <Icon\n                        icon={'approval'}\n                        color={'parent'}\n                        title=\"$__forApproval\"\n                    />\n                </Badge>\n            </Button>\n            {cards.length > 0 &&\n                <Popper open={open} anchorEl={anchorRef.current} role={undefined} transition disablePortal\n                    style={{ width: '400px' }}\n                >\n                    {({ TransitionProps, placement }) => (\n                        <Grow\n                            {...TransitionProps}\n                            style={{\n                                transformOrigin: placement === 'bottom' ? 'center top' : 'center bottom',\n                                padding: 11,\n                            }}\n                        >\n                            <Paper>\n                                <ClickAwayListener onClickAway={handleClose}>\n                                    <div style={{\n                                        height: 'auto',\n                                        maxHeight: 'calc(90vh - 80px)',\n                                        width: '100%',\n                                        overflowY: 'auto'\n                                    }}>\n                                        <div\n                                            style={{\n                                                color: \"red\",\n                                                fontWeight: \"bold\",\n                                                fontSize: 14\n                                            }}\n                                        >{translate(\"$__attention\", 1)}: <span style={{ color: customApp('menu') }}>{translate(\"$__thisActivityRequireApproval\", 1)}</span></div>\n                                        {cards.map((card, cardIndex) => {\n                                            return (\n                                                <div\n                                                    key={card._id}\n                                                    style={{\n                                                        display: \"grid\",\n                                                        width: \"100%\",\n                                                        border: \"solid 1px rgba(0,0,0,0.1)\",\n                                                        padding: 12,\n                                                        marginTop: 7,\n                                                        borderRadius: 7,\n                                                    }}\n                                                >\n                                                    <Card\n                                                        db=\"cards\"\n                                                        data={card}\n                                                        onlyOption={true}\n                                                    />\n                                                    <Approve nodeId={card._id} />\n                                                </div>\n                                            )\n                                        })}\n                                    </div>\n                                </ClickAwayListener>\n                            </Paper>\n                        </Grow>\n                    )}\n                </Popper>\n            }\n        </div >\n    )\n}\n\nconst mapStateToProps = (store, ownProps) => ({\n    cards: store.db.cards\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","//CORE\nimport React from \"react\"\nimport moment from \"moment-timezone\"\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport Card from \"components/Card\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Message from \"components/Timeline/message\"\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\"\n\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp\n} from \"functions/\"\n\nimport {\n    countNotifications\n} from \"functions/cards\"\nimport {\n    loadTimeline,\n    chatReaded,\n} from \"functions/chat\"\n\nconst useStyles = makeStyles(() => ({\n    unReaded: {\n        padding: \"7px\",\n        borderBottom: \"solid 1px rgba(0,0,0,0.1)\",\n        width: \"100%\",\n        maxWidth: \"100%\",\n        opacity: 1,\n        borderLeft: `solid red 2px`\n    },\n    Readed: {\n        padding: \"7px\",\n        borderBottom: \"solid 1px rgba(0,0,0,0.1)\",\n        width: \"100%\",\n        opacity: 0.5,\n        maxWidth: \"100%\",\n    }\n}))\n\nfunction CardNotification(props) {\n    const { chat, notifications, timeline, functions, session } = reduxStore.getState()\n    const { socket } = functions;\n    const { data } = props\n    const [mounted, setMounted] = React.useState(false)\n\n    const [showPrivate, setShowPrivate] = React.useState(false)\n    const classes = useStyles()\n\n    React.useEffect(() => {\n        // setMounted(true)\n        return () => {\n            // setMounted(false)\n        }\n    }, [])\n\n    let dbNotify = \"cards\"\n    if (data && data.cardId && reduxStore.getState().db.users[data.cardId]) {\n        dbNotify = \"users\"\n    }\n\n    const markAsRead = () => {\n        let notifications = countNotifications(data.cardId)\n        props.reduxFunction(\"ASYNC\", \"SET_NOTIFICATIONS\", {\n            ...reduxStore.getState().notifications,\n            total: reduxStore.getState().notifications.total - notifications.total,\n        })\n        chatReaded(props, {\n            readedBy: session._id,\n            id: props.cardId,\n            db: 'cards',\n            type: 'all'\n        })\n\n\n        socket.emit(\"data\", {\n            module: \"chat\",\n            method: \"put\",\n            action: \"read\"\n        }, {\n            readedBy: session._id,\n            id: data.cardId,\n            db: 'cards',\n            type: 'all'\n        }, () => {\n        })\n\n        if (reduxStore.getState().db && reduxStore.getState().db.cards && reduxStore.getState().db.cards[data.cardId])\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                ...reduxStore.getState().db,\n                cards: {\n                    ...reduxStore.getState().db.cards,\n                    [data.cardId]: {\n                        ...reduxStore.getState().db.cards[data.cardId],\n                        _notifications: {\n                            comment: 0,\n                            kpi: 0,\n                            timer: 0,\n                            log: 0\n                        }\n                    }\n\n                }\n            })\n\n        if (props.onRead) {\n            setTimeout(() => {\n                props.onRead()\n            }, 1000)\n        }\n\n    }\n\n    let cardTimeline = Object.keys(timeline[data.cardId]).filter(a =>\n        session\n        && session._id\n        && timeline[data.cardId]\n        && timeline[data.cardId][a]\n        && timeline[data.cardId][a].user\n        && timeline[data.cardId][a].user._id\n        && timeline[data.cardId][a].user._id !== session._id\n        && (\n            !timeline[data.cardId][a].readedBy\n            ||\n            (\n                timeline[data.cardId][a].readedBy\n                && !timeline[data.cardId][a].readedBy[session._id]\n            )\n        )\n    )\n\n    return (\n        <div className={data.readed ? classes.Readed : classes.unReaded}\n            style={{ width: 369, overflow: \"auto\" }}\n        >\n            {(\n                data.cardId && reduxStore.getState().db.cards[data.cardId]\n            )\n                &&\n                <div\n                    style={reduxStore.getState().db.cards[data.cardId] && reduxStore.getState().db.cards[data.cardId].type === \"chatGroup\" ? { cursor: \"pointer\" } : {}}\n                >\n                    <Card\n                        setPrivate={(a) => {\n                            setShowPrivate(a)\n                        }}\n                        db=\"cards\"\n                        data={reduxStore.getState().db.cards[data.cardId]}\n                        onlyOption={reduxStore.getState().db.cards[data.cardId] && reduxStore.getState().db.cards[data.cardId].type === \"chatGroup\" ? true : false}\n                    />\n\n                </div>\n            }\n\n            {cardTimeline.length > 0\n                && (\n                    (\n                        !reduxStore.getState().db.cards[data.cardId].private\n                    )\n                    ||\n                    (\n                        reduxStore.getState().db.cards[data.cardId].private\n                        &&\n                        (\n                            reduxStore.getState().controls.lockPrivate\n                            ||\n                            showPrivate\n                        )\n                    )\n                ) ?\n                <React.Fragment>\n                    {cardTimeline.sort((a, b) => {\n                        if (parseInt(timeline[data.cardId][a].created_at) > parseInt(timeline[data.cardId][b].created_at))\n                            return -1\n                        if (parseInt(timeline[data.cardId][a].created_at) < parseInt(timeline[data.cardId][b].created_at))\n                            return 1\n                        return 0\n                    }).map((tm, tmi) => {\n                        // console.log(tm)\n                        return (\n                            <div key={`${tm}`} style={{ position: \"relative\", marginBottom: \"33px\", paddingBottom: 15, display: \"-webkit-box\" }}>\n                                <Message\n                                    storie={{\n                                        ...reduxStore.getState().timeline && reduxStore.getState().timeline[data.cardId] && reduxStore.getState().timeline[data.cardId][tm] ? reduxStore.getState().timeline[data.cardId][tm] : {},\n                                        idRel: tm,\n                                    }}\n                                    boxStyle={{ width: \"calc(100% - 10px) !important\", maxWidth: \"285px\" }}\n                                    db={dbNotify}\n                                    noReactions\n                                    noReply\n                                    openLightBox={(f) => {\n                                        props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n                                            open: true,\n                                            files: reduxStore.getState().timeline[data.cardId][tm].files ? reduxStore.getState().timeline[data.cardId][tm].files : [],\n                                            file: f\n                                        })\n                                    }}\n                                />\n                                {(tmi + 1 === cardTimeline.length) ?\n                                    <div style={{\n                                        position: \"absolute\",\n                                        height: \"93px\",\n                                        left: 0, bottom: \"-33px\", right: 8,\n                                        background: 'linear-gradient(0deg, rgba(255,255,255,1) 34%, rgba(255,255,255,0) 100%)',\n                                    }}>\n                                        <div style={{ position: \"absolute\", bottom: \"0px\", display: \"flex\", justifyContent: \"space-between\", width: \"100%\" }}>\n                                            <CustomButton\n                                                title={translate(`$__open`, 1)}\n                                                text={translate(`$__open`, 1)}\n                                                color={customApp('color')}\n                                                icon={'launch'}\n                                                onClick={() => {\n                                                    props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                        ...reduxStore.getState().sideModule,\n                                                        db: 'cards',\n                                                        id: data.cardId,\n                                                        module: \"cardEdit\",\n                                                        activeModule: \"cardEdit\",\n                                                        data: reduxStore.getState().db.cards[data.cardId],\n                                                    })\n                                                    markAsRead()\n                                                }\n                                                }\n                                                size={'13px'}\n                                                textSize={'13px'}\n                                                style={{ padding: \"0px !important\" }}\n                                            />\n                                            <CustomButton\n                                                title={translate(`$__markAsRead`, 1)}\n                                                text={translate(`$__markAsRead`, 1)}\n                                                color={customApp('color')}\n                                                icon={'mark_chat_read'}\n                                                onClick={() => {\n                                                    markAsRead()\n                                                }}\n                                                size={'13px'}\n                                                textSize={'13px'}\n                                                style={{ padding: \"0px !important\" }}\n                                            />\n                                        </div>\n                                    </div> : <React.Fragment></React.Fragment>\n                                }\n                            </div>\n                        )\n                    })\n                    }\n                </React.Fragment>\n                : <React.Fragment></React.Fragment>\n            }\n        </div>\n    )\n}\n\nconst mapStateToProps = (store) => ({\n    store\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(CardNotification)\n","//CORE\nimport React from \"react\"\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport Notification from \"components/NotificationsV2/card\"\nimport CustomButton from \"components/Buttons/custom\"\nimport LinearProgress from \"components/Progress/linear\"\n\n\n//@MATERIAL\nimport Badge from \"@material-ui/core/Badge\"\nimport Button from \"@material-ui/core/Button\"\nimport ClickAwayListener from \"@material-ui/core/ClickAwayListener\"\nimport Grow from \"@material-ui/core/Grow\"\nimport Paper from \"@material-ui/core/Paper\"\nimport Popper from \"@material-ui/core/Popper\"\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n    appAlert\n} from \"functions/\"\nimport { mountCards } from \"functions/loadData\"\nimport apims from \"apims\"\n\nfunction Component(props) {\n    const pgLimit = 7\n    const { notifications, session, timeline, functions } = reduxStore.getState()\n    const { socket } = functions\n    const [mounted, setMounted] = React.useState(false)\n    const [loading, setLoading] = React.useState(false)\n    const [countShow, setCountShow] = React.useState(pgLimit)\n    const [open, setOpen] = React.useState(false)\n    const anchorRef = React.useRef()\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true)\n            iniNotifications()\n        }\n        return () => {\n            setMounted(false)\n        }\n    }, [])\n\n    React.useEffect(() => {\n        iniNotifications(0, 0, true)\n        return () => {\n\n        }\n    }, [props.store.timeline, props.store.notifications, props.store.cards])\n\n    // console.log(loading)\n\n\n    const iniNotifications = async (s = 0, limit = 0, ignoreWS = false) => {\n        let skip = s\n        if (ntCount < skip) {\n            skip = 0\n        }\n        let reqTimeline = ignoreWS ? { data: [] } : await apims.post(`/M_UnReadedList`,\n            {\n                skip: skip,\n                limit: limit\n            }\n        )\n        let total = 0\n        let lastDate = 0\n        let iniDate = 0\n        try {\n            if (ignoreWS || (reqTimeline && reqTimeline.data && reqTimeline.data.length > 0)) {\n                let timelines = { ...reduxStore.getState().timeline }\n                let notCards = []\n                let rt = await new Promise((resolve, reject) => {\n                    reqTimeline.data.map((notification, i) => {\n                        total = notification.total\n                        notCards.push(notification.card)\n                        if (notification.timeline && notification.timeline.length > 0) {\n                            notification.timeline.map(tm => {\n                                let readedBy = {}\n                                let reactions = {}\n\n                                if (tm && tm.params && tm.params.readedBy && tm.params.readedBy.filter(u => u._id).length > 0)\n                                    tm.params.readedBy.map(u => {\n                                        readedBy = {\n                                            ...readedBy,\n                                            [u._id]: u\n                                        }\n                                    })\n\n                                if (tm && tm.params && tm.params.reactions && tm.params.reactions.filter(u => u._id).length > 0)\n                                    tm.params.reactions.map(r => {\n                                        reactions = {\n                                            ...reactions,\n                                            [r.type]: {\n                                                ...reactions[r.type],\n                                                [r._id]: r,\n                                            }\n                                        }\n                                    })\n                                if (parseInt(lastDate) < parseInt(tm.data.created_at))\n                                    lastDate = parseInt(tm.data.created_at)\n\n                                if (iniDate === 0 || iniDate > parseInt(tm.data.created_at))\n                                    iniDate = parseInt(tm.data.created_at)\n\n                                timelines = {\n                                    ...timelines,\n                                    [tm.nodeId]: {\n                                        ...timelines && timelines[tm.nodeId] ? timelines[tm.nodeId] : {},\n                                        [tm.data._id]: {\n                                            ...tm.data,\n                                            ...tm.params,\n                                            readedBy: readedBy,\n                                            _reactions: reactions\n                                        }\n                                    }\n                                }\n                            })\n                        }\n                        if (i + 1 === reqTimeline.data.length)\n                            resolve(true)\n                    })\n                })\n                if (rt) {\n                    props.reduxFunction(\"ASYNC\", \"SET_NOTIFICATIONS\", {\n                        total: total > 0 ? total : 0,\n                        lastNotification: lastDate, //Aqui vai a data da notificação mais nova sendo exibida\n                        firstNotification: iniDate, // Aqui vai a data da notificação mais antiga carregada\n                    })\n                }\n                props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", {\n                    ...reduxStore.getState().timeline,\n                    ...timelines,\n                })\n                mountCards(props, notCards)\n                setLoading(false)\n            } else {\n                setLoading(false)\n            }\n        } catch (e) {\n            console.log(e)\n        }\n        setLoading(false)\n    }\n\n    const clearNotifications = async () => {\n        appAlert({\n            message: translate(\"$__confirmClearAllNotifications\", 1),\n            variant: \"warning\",\n            persist: false,\n            horizontal: \"right\",\n            confirm: () => {\n                setOpen(false)\n                let timeline = { ...reduxStore.getState().timeline }\n                Object.keys(timeline).map(t => {\n                    if (timeline && timeline[t])\n                        Object.keys(timeline[t])\n                            .filter(fil =>\n                                reduxStore.getState().db.cards[t]\n                                && reduxStore.getState().db.cards[t].type !== 'chatGroup'\n                                && (\n                                    !timeline[t][fil].readedBy\n                                    ||\n                                    (timeline[t][fil].readedBy\n                                        && !timeline[t][fil].readedBy[session._id])\n                                )\n                            )\n                            .map(ms => {\n                                delete timeline[t][ms]\n                            })\n                })\n                props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", {\n                    timeline: timeline\n                });\n                props.reduxFunction(\"ASYNC\", \"SET_NOTIFICATIONS\", {\n                    total: 0,\n                    lastNotification: 0, //Aqui vai a data da notificação mais nova sendo exibida\n                    firstNotification: 0, // Aqui vai a data da notificação mais antiga carregada\n                })\n                try {\n                    socket.emit(\"data\", {\n                        module: \"notifications\",\n                        method: \"put\",\n                        action: \"readedAll\"\n                    }, {\n\n                    })\n                } catch (e) {\n                    console.log(e)\n                }\n            }\n        })\n    }\n\n    const handleToggle = (h) => {\n        setOpen((prevOpen) => !prevOpen)\n    }\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return\n        }\n        setOpen(false)\n    }\n\n    let ntCount = 0\n    let ntCountShow = 0\n    Object.keys(reduxStore.getState().db.cards)\n        .filter(n => {\n            let card = reduxStore.getState().db.cards[n]\n            if (\n                card.type !== 'chatGroup'\n                && card._users\n                && card._users[session._id]\n                && timeline[n]\n                && Object.keys(timeline[n]).filter(a =>\n                    session\n                    && session._id\n                    && timeline\n                    && timeline[n]\n                    && timeline[n][a]\n                    && timeline[n][a].user\n                    && timeline[n][a].user._id\n                    && timeline[n][a].user._id !== session._id\n                    && (\n                        !timeline[n][a].readedBy\n                        ||\n                        (\n                            timeline[n][a].readedBy\n                            && !timeline[n][a].readedBy[session._id]\n                        )\n                    )\n                ).length > 0)\n                return true\n        })\n        .map((n, ci) => {\n            if (timeline[n])\n                Object.keys(timeline[n]).filter(a =>\n                    session\n                    && session._id\n                    && timeline[n]\n                    && timeline[n][a]\n                    && timeline[n][a].user\n                    && timeline[n][a].user._id\n                    && timeline[n][a].user._id !== session._id\n                    && (\n                        !timeline[n][a].readedBy\n                        ||\n                        (\n                            timeline[n][a].readedBy\n                            && !timeline[n][a].readedBy[session._id]\n                        )\n                    )\n                ).map(() => {\n                    if (ci <= countShow)\n                        ntCountShow = ntCountShow + 1\n                    ntCount = ntCount + 1\n                })\n        })\n\n    if (notifications.total > ntCount)\n        ntCount = notifications.total\n\n    if (ntCount === 0 && open)\n        setOpen(false)\n\n    if (ntCount === 0)\n        return (<React.Fragment></React.Fragment>)\n\n    return (\n        <div id=\"notificationsBt\"\n            style={{\n                zIndex: \"100 !important\",\n                // display: ntCount === 0 ? \"none\" : \"flex\"\n            }}>\n            <Button\n                ref={anchorRef}\n                aria-controls={open ? \"menu-list-grow\" : undefined}\n                aria-haspopup=\"true\"\n                onClick={() => {\n                    handleToggle(ntCount > 0)\n                }}\n            >\n                <Badge overlap=\"rectangular\"\n                    badgeContent={ntCount} color=\"secondary\">\n                    <Icon\n                        icon={ntCount === 0 ? \"notifications_none\" : \"notifications_active\"}\n                        color={\"parent\"}\n                        title=\"$__notifications\"\n                    />\n                </Badge>\n            </Button>\n            <Popper open={open} anchorEl={anchorRef.current} role={undefined} transition disablePortal>\n                {({ TransitionProps, placement }) => (\n                    <Grow\n                        {...TransitionProps}\n                        style={{ transformOrigin: placement === \"bottom\" ? \"center top\" : \"center bottom\" }}\n                    >\n                        <Paper>\n                            <ClickAwayListener onClickAway={handleClose}>\n                                <div style={{\n                                    height: \"auto\",\n                                    maxHeight: \"calc(90vh - 80px)\",\n                                    width: \"369px\",\n                                    overflowY: \"auto\"\n                                }}>\n                                    <div\n                                        style={{\n                                            display: \"flex\",\n                                            justifyContent: \"space-between\",\n                                            alignItems: \"center\",\n                                            padding: \"7px\",\n                                            width: \"-webkit-fill-available\"\n                                        }}\n                                    >\n                                        <div>{translate(\"$__notifications\")}</div>\n                                        {ntCount > 0 ?\n                                            <CustomButton\n                                                title={translate(`$__clearNotifications`, 1)}\n                                                text={translate(`$__clearNotifications`, 1)}\n                                                color={customApp('color')}\n                                                icon={'clear_all'}\n                                                onClick={() => {\n                                                    clearNotifications()\n                                                }}\n                                                size={'21px'}\n                                                style={{ padding: \"0px !important\" }}\n                                            />\n                                            : <React.Fragment></React.Fragment>\n                                        }\n                                    </div>\n                                    {Object.keys(reduxStore.getState().db.cards)\n                                        .filter(n => {\n                                            let card = reduxStore.getState().db.cards[n]\n                                            if (card.type !== 'chatGroup'\n                                                && card._users\n                                                && card._users[session._id]\n                                                && timeline[n]\n                                                && Object.keys(timeline[n]).filter(a =>\n                                                    session\n                                                    && session._id\n                                                    && timeline\n                                                    && timeline[n]\n                                                    && timeline[n][a]\n                                                    && timeline[n][a].user\n                                                    && timeline[n][a].user._id\n                                                    && timeline[n][a].user._id !== session._id\n                                                    && (\n                                                        !timeline[n][a].readedBy\n                                                        ||\n                                                        (\n                                                            timeline[n][a].readedBy\n                                                            && !timeline[n][a].readedBy[session._id]\n                                                        )\n                                                    )\n                                                ).length > 0)\n                                                return true\n                                        })\n                                        .sort((na, nb) => {\n                                            let lna = 0\n                                            let lnb = 0\n                                            //LAST LNA MESSAGE\n                                            if (timeline[na])\n                                                Object.keys(timeline[na]).filter(a =>\n                                                    session\n                                                    && session._id\n                                                    && timeline\n                                                    && timeline[na]\n                                                    && timeline[na][a]\n                                                    && timeline[na][a].user\n                                                    && timeline[na][a].user._id\n                                                    && timeline[na][a].user._id !== session._id\n                                                    && (\n                                                        !timeline[na][a].readedBy\n                                                        ||\n                                                        (\n                                                            timeline[na][a].readedBy\n                                                            && !timeline[na][a].readedBy[session._id]\n                                                        )\n                                                    )\n                                                ).map(a => {\n                                                    if (parseInt(timeline[na][a].created_at) > lna)\n                                                        lna = parseInt(timeline[na][a].created_at)\n                                                })\n\n                                            //LAST LNB MESSAGE\n                                            if (timeline[nb])\n                                                Object.keys(timeline[nb]).filter(a =>\n                                                    timeline[nb][a].user._id !== session._id\n                                                    && (\n                                                        !timeline[nb][a].readedBy\n                                                        ||\n                                                        (\n                                                            timeline[nb][a].readedBy\n                                                            && !timeline[nb][a].readedBy[session._id]\n                                                        )\n                                                    )\n                                                ).map(a => {\n                                                    if (parseInt(timeline[nb][a].created_at) > lna)\n                                                        lnb = parseInt(timeline[nb][a].created_at)\n                                                })\n                                            if (lna > lnb) {\n                                                return -1\n                                            } else if (lna < lnb) {\n                                                return 1\n                                            } else {\n                                                return 0\n                                            }\n                                        })\n                                        .map((n, nti) => {\n                                            if (nti <= countShow) {\n                                                return (<div key={`${n}`}>\n                                                    <Notification data={{\n                                                        cardId: n\n                                                    }} onRead={() => {\n                                                        setTimeout(() => {\n                                                            iniNotifications(0, 8)\n                                                        }, 2000)\n                                                    }}\n                                                        onClick={() => {\n                                                            setOpen(false)\n                                                        }} />\n                                                </div>)\n                                            } else {\n                                                return (<React.Fragment key={`${nti}${n}`}></React.Fragment>)\n                                            }\n                                        })}\n                                    {/* {console.log(parseInt(reduxStore.getState().notifications.total), ntCountShow, loading)} */}\n                                    {parseInt(reduxStore.getState().notifications.total) > ntCountShow ?\n                                        <div style={{ width: \"calc(100% - 14px)\", display: \"flex\", justifyContent: \"center\", padding: 7 }}>\n                                            {!loading ?\n                                                <CustomButton\n                                                    title={translate(`$__seeMoreNotifications`, 1)}\n                                                    text={translate(`$__seeMoreNotifications`, 1)}\n                                                    color={customApp('menu')}\n                                                    icon={'notifications_active'}\n                                                    onClick={() => {\n                                                        iniNotifications(countShow)\n                                                        setCountShow(countShow + pgLimit)\n                                                    }}\n                                                    size={'21px'}\n                                                    style={{ padding: \"0px !important\" }}\n                                                />\n                                                :\n                                                <div style={{ width: \"100%\", display: \"flex\", justifyContent: \"center\", alignItems: \"center\" }}>\n                                                    <span style={{ color: customApp('menu'), fontSize: \"12px\", paddingRight: \"15px\", whiteSpace: \"nowrap\" }}>{translate('$__loadingNotifications')}</span>\n                                                    <LinearProgress />\n                                                </div>\n                                            }\n                                        </div>\n                                        : <React.Fragment></React.Fragment>\n                                    }\n                                </div>\n                            </ClickAwayListener>\n                        </Paper>\n                    </Grow>\n                )}\n            </Popper>\n        </div>\n    )\n}\n\nconst mapStateToProps = (store) => ({\n    store: {\n        notifications: store.notifications,\n        timeline: store.timeline,\n        session: store.session,\n        cards: store.db.cards\n    }\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","import React from \"react\";\n\n//@MATERIAL\nimport Icon from \"components/Icon\";\nimport Button from '@material-ui/core/Button';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport Grow from '@material-ui/core/Grow';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport MenuList from '@material-ui/core/MenuList';\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\nimport history from \"store/history\";\n\n//FUNCTIONS\nimport { translate, customApp, getAppAccess } from \"functions/\";\nimport { countUsers } from \"functions/account\";\nimport { InsertDriveFileOutlined } from \"@material-ui/icons\";\n\nfunction Comp(props) {\n    const [open, setOpen] = React.useState(false);\n    const anchorRef = React.useRef(null)\n    const { db } = reduxStore.getState();\n    const { users } = db;\n\n    let AppAccess = getAppAccess()\n\n    let hashs = window.location.hash.split(\"/\");\n    hashs[0] = hashs[0].replace(\"#\", \"\");\n\n    let idRel = null\n    if (hashs[0].length !== 36 && (!hashs[2] || hashs[2].length !== 36)) {\n        idRel = null;\n    } else if (hashs[0].length === 36) {\n        idRel = hashs[0];\n    } else if (hashs[2].length === 36) {\n        idRel = hashs[2];\n    }\n\n    const pathName = window.location.pathname.replace(\"/\", \"\").toLowerCase();\n    let types = db.dataType.filter(a => {\n        if (\n            (\n                pathName === \"sp\"\n                ||\n                (\n                    (\n                        !a.hash &&\n                        !idRel\n                    ) ||\n                    (\n                        a.hash &&\n                        idRel\n                    )\n                )\n            ) &&\n            a.view &&\n            Object.keys(a.view).filter(a => a === pathName).length > 0 &&\n            (!a.view[pathName].pages ||\n                (hashs[1] && a.view[pathName].pages.indexOf(hashs[1]) > -1) ||\n                (!hashs[1] && a.view[pathName].pages.indexOf(\"none\") > -1))\n        ) {\n            return a;\n        }\n    });\n\n    const handleToggle = () => {\n        if (types.length === 1) {\n            openModule(types[0], hashs[1] && hashs[1] === 'template' ? true : false)\n        } else if (types.length > 1) {\n            setOpen((prevOpen) => !prevOpen);\n        }\n    };\n\n    const openModule = (i, template = false) => {\n        let accountUsersCount = countUsers()\n\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...reduxStore.getState().sideModule,\n            id: 'new',\n            activeModule: i.iniModule,\n            db: i.db,\n            data: {\n                type: i.name,\n                _parent: hashs[0] && db.cards[hashs[0]] ? hashs[0] : null,\n                ...i.data.type === \"user\" ? {\n                }\n                    : {\n                        status: 'notStarted',\n                        ...template ? { isTemplate: true } : {},\n                    }\n            }\n        })\n        // }\n    }\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n        setOpen(false);\n    };\n\n    function handleListKeyDown(event) {\n        if (event.key === 'Tab') {\n            event.preventDefault();\n            setOpen(false);\n        }\n    }\n\n\n\n\n    if (types.length === 0)\n        return (<React.Fragment></React.Fragment>)\n\n\n\n\n    return (\n        <div id=\"QuickAddBt\">\n            <Button\n                ref={anchorRef}\n                aria-controls={open ? 'menu-list-grow' : undefined}\n                aria-haspopup=\"true\"\n                onClick={handleToggle}\n            >\n                <Icon usePropagation size={\"27px\"} color={customApp('menu')}>add_box</Icon>\n            </Button>\n            <Popper open={open} anchorEl={anchorRef.current} role={undefined} transition disablePortal>\n                {({ TransitionProps, placement }) => (\n                    <Grow\n                        {...TransitionProps}\n                        style={{ transformOrigin: placement === 'bottom' ? 'center top' : 'center bottom' }}\n                    >\n                        <Paper>\n                            <ClickAwayListener onClickAway={handleClose}>\n                                <MenuList autoFocusItem={open} id=\"menu-list-grow\" onKeyDown={handleListKeyDown}>\n                                    {types\n                                        .sort((a, b) => {\n                                            if (a.name > b.name) return -1;\n                                            return 0;\n                                        })\n                                        .map((a, i) => (\n                                            <MenuItem\n                                                key={i}\n                                                style={{\n                                                    color: customApp('menu')\n                                                }}\n                                                onClick={() => {\n                                                    setOpen(false);\n                                                    openModule(a)\n                                                }}>\n                                                <Icon icon={a.icon} style={{ margin: 'none !important' }} color={customApp('menu')} /><span style={{ marginLeft: '7px' }}>{translate(`$__${a.name}`, 1)}</span></MenuItem>\n                                        ))\n                                    }\n                                </MenuList>\n                            </ClickAwayListener>\n                        </Paper>\n                    </Grow>\n                )}\n            </Popper>\n        </div >\n    )\n}\n\nconst mapStateToProps = (store) => ({\n    users: store.users\n});\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(Comp);\n","//CORE\nimport React from 'react';\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\nimport { bindActionCreators } from \"redux\";\nimport { connect } from \"react-redux\";\n\n//COMPONENTS\nimport Card from \"components/Card\";\nimport Checklist from \"components/Checklist\";\nimport Icon from \"components/Icon\";\n\n\n//@MATERIAL\nimport Badge from '@material-ui/core/Badge';\nimport Button from '@material-ui/core/Button';\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport Grow from '@material-ui/core/Grow';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport { makeStyles } from '@material-ui/core/styles';\nimport IconButton from '@material-ui/core/IconButton';\n\n\n//FUNCTIONS\nimport { translate, customApp, getAppAccess } from 'functions/';\nimport { countUnRead } from \"functions/chat\";\n\nfunction Component(props) {\n    const { db, timeline, session, chat } = reduxStore.getState()\n    const [mounted, setMounted] = React.useState(false)\n    const [open, setOpen] = React.useState(false);\n    const [count, setCount] = React.useState({})\n    const [view, setView] = React.useState('users')\n    const anchorRef = React.useRef(null)\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\n\n    let AppAccess = getAppAccess()\n\n    React.useEffect(() => {\n        setMounted(true)\n        iniChatNotification()\n    }, [timeline])\n\n    const iniChatNotification = async () => {\n        const reqCount = countUnRead()\n        setCount(reqCount)\n        if (count.total > 0 && count.users === 0)\n            setView('groups')\n        if (view === 'groups' && count.total > 0 && count.groups === 0)\n            setView('users')\n    }\n\n    const handleToggle = () => {\n        setOpen((prevOpen) => !prevOpen);\n    };\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n\n        setOpen(false);\n    };\n\n    let timerCards = Object.keys(db.cards).filter(a =>\n        db.cards[a]\n        && db.cards[a]._kpiTimer\n        && db.cards[a]\n        && db.cards[a]._users\n        && Object.keys(db.cards[a]._kpiTimer).filter(t =>\n            db.cards[a]._kpiTimer &&\n            db.cards[a]._kpiTimer[t] &&\n            db.cards[a]._kpiTimer[t].userId &&\n            session &&\n            session._id &&\n            db.cards[a]._kpiTimer[t].userId === session._id\n        ).length > 0\n        && Object.keys(db.cards[a]._users).filter(u => session && session._id && u === session._id).length > 0\n    ).map(a => db.cards[a])\n\n    if (timerCards.length === 0)\n        return (<React.Fragment></React.Fragment>)\n\n    return (\n        <div id=\"notificationsBt\"\n            style={{\n                zIndex: '100 !important'\n            }}>\n            <Button\n                ref={anchorRef}\n                aria-controls={open ? 'menu-list-grow' : undefined}\n                aria-haspopup=\"true\"\n                onClick={handleToggle}\n            >\n                <Badge badgeContent={timerCards.length} color=\"secondary\" overlap=\"rectangular\">\n                    <Icon\n                        icon={'timer'}\n                        color={'parent'}\n                        title=\"$__timersInProgress\"\n                    />\n                </Badge>\n            </Button>\n            {timerCards.length > 0 &&\n                <Popper\n                    open={open}\n                    anchorEl={anchorRef.current}\n                    role={undefined}\n                    transition\n                    disablePortal\n                    style={{ width: '400px' }}\n                >\n                    {({ TransitionProps, placement }) => (\n                        <Grow\n                            {...TransitionProps}\n                            style={{ transformOrigin: placement === 'bottom' ? 'center top' : 'center bottom' }}\n                        >\n                            <Paper>\n                                <ClickAwayListener onClickAway={handleClose}>\n                                    <div style={{\n                                        height: 'auto',\n                                        maxHeight: 'calc(90vh - 80px)',\n                                        width: '100%',\n                                        overflowY: 'auto'\n                                    }}>\n                                        <div\n                                            style={{\n                                                display: 'flex',\n                                                justifyContent: 'space-between',\n                                                alignItems: 'center',\n                                                padding: '7px'\n                                            }}\n                                        >\n                                            {translate('$__timersInProgress')}\n                                        </div>\n                                        {\n                                            timerCards.map((card, i) => (\n                                                <Card db=\"cards\" key={i} data={card} notGlobalExpanded viewTimer />\n                                            ))\n                                        }\n                                    </div>\n                                </ClickAwayListener>\n                            </Paper>\n                        </Grow>\n                    )}\n                </Popper>\n            }\n        </div >\n    )\n}\n\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","import React from \"react\"\n\n//REDUX\nimport { connect } from 'react-redux'\nimport { bindActionCreators } from 'redux'\nimport * as reduxActions from 'store/actions'\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Card from \"components/Card\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport HeaderWithIcon from \"components/Header/withIcon\"\nimport CustomButton from \"components/Buttons/custom\"\nimport LinearProgress from \"components/Progress/linear\"\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\n\n//DEPENDENCIES\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/search.js\"\n\n//FUNCTIONS\nimport { translate, customApp, getAppAccess } from \"functions/\"\nimport { loadCardsV2 } from \"functions/loadData\"\nimport { planAccountVerify } from \"functions/cards\"\n\nfunction SearchComponent(props) {\n  const [lastChange, setLastChange] = React.useState(\"\")\n  const [loader, setLoader] = React.useState(false)\n  const [filteredItems, setfilteredItems] = React.useState([])\n  const [searchCompleted, setSearchCompleted] = React.useState(false)\n  const [searchDeleted, setSearchDeleted] = React.useState(false)\n  const [cardsType, setCardsType] = React.useState('all')\n  const { db, session } = reduxStore.getState()\n\n  let AppAccess = getAppAccess()\n\n  let hashs = window.location.hash.split('/')\n  hashs[0] = hashs[0].replace('#', '')\n\n  React.useEffect(() => {\n    return () => {\n\n    }\n  }, [])\n\n  React.useEffect(() => {\n    let timer = setTimeout(() => { }, 15000)\n    if (props.text.length > 1 && props.text !== lastChange) {\n      setLastChange(props.text)\n      clearTimeout(timer)\n      timer = setTimeout(() => searchCardsOnLine(), 500)\n      setLoader(true)\n    }\n    return () => clearTimeout(timer)\n  }, [props.text])\n\n  React.useEffect(() => {\n    let timer = setTimeout(() => { }, 15000)\n    if (props.completed !== searchCompleted && props.text && props.text.length > 1) {\n      setLoader(true)\n      setSearchCompleted(!searchCompleted)\n      setSearchDeleted(true)\n      timer = setTimeout(() => searchCardsOnLine(), 500)\n    }\n    return () => clearTimeout(timer)\n  }, [props.completed])\n\n  React.useEffect(() => {\n    let timer = setTimeout(() => { }, 15000)\n    if (props.deleted !== searchDeleted && props.text && props.text.length > 1) {\n      // setfilteredItems([])\n      setLoader(true)\n      setSearchDeleted(!searchDeleted)\n      setSearchCompleted(true)\n      timer = setTimeout(() => searchCardsOnLine(), 500)\n    }\n    return () => clearTimeout(timer)\n  }, [props.deleted])\n\n  const searchCardsOnLine = async () => {\n    let lc = await loadCardsV2(props, {\n      search: props.text,\n      ignoreLoader: true,\n      deleted: props.deleted,\n      completed: props.completed,\n      cardLoad: \"search\"\n    })\n    if (lc) {\n      setTimeout(() => {\n        searchCards(lc)\n      }, 1000)\n    }\n  }\n\n  const searchCards = async (result) => {\n    let userData = reduxStore.getState().db.users[session._id] || {}\n    console.log(session, userData)\n    let cards = {\n      ...reduxStore.getState().db.cards,\n      ...result\n    }\n\n    let groups = userData.groups || []\n    let searchResult = new Promise((resolve, reject) => {\n      resolve(Object.keys(cards).filter(card =>\n        cards[card].type !== 'chatGroup'\n        && (\n          !cards[card].checklist\n          ||\n          (\n            cards[card].checklist\n            && cards[card].showCard\n          )\n        )\n        &&\n        (\n          (\n            props.deleted\n            && cards[card].deleted\n          )\n          || (\n            !props.deleted\n            && !cards[card].deleted\n            && (\n              (\n                !props.completed\n                && cards[card]\n                && cards[card].status !== 'completed'\n              )\n              ||\n              (\n                props.completed\n                && cards[card]\n                && cards[card].status === 'completed'\n              )\n            )\n          )\n        )\n        && (\n          (\n            (\n              (\n                AppAccess.owner\n                || AppAccess.planAdmin\n              )\n              && (\n                cards[card].type !== 'plan'\n                || (\n                  cards[card].type === 'plan'\n                  && planAccountVerify(card)\n                )\n              )\n            )\n            ||\n            (\n              session._id\n              && cards[card]._users\n              && cards[card]._users[session._id]\n            )\n            ||\n            (\n              cards[card]._groups\n              && cards[card]._groups.filter(gr =>\n                userData\n                && userData.groups\n                && userData.groups.filter(xg => xg.value === gr.value).length > 0\n              )\n            )\n          )\n          &&\n          (\n            props.text\n            &&\n            (\n              (\n                cards[card].name\n                && props.text\n                && cards[card]\n                && cards[card].name\n                && cards[card].name.toLowerCase().indexOf(props.text.toLowerCase()) > -1\n              )\n              ||\n              (\n                cards[card]\n                && props.text\n                && cards[card].description\n                && cards[card].description.toLowerCase().indexOf(props.text.toLowerCase()) > -1\n              )\n            )\n          )\n          &&\n          (\n            !cards[card].private\n            ||\n            (\n              cards[card].private\n              && cards[card]._users\n              && cards[card]._users[session._id]\n            )\n          )\n        ))\n      )\n    })\n\n    let response = await searchResult.then(a => {\n      return a\n    })\n    if (response) {\n      setfilteredItems(response)\n      setLoader(false)\n      if (props.onFinish)\n        props.onFinish(response.length)\n    }\n  }\n\n  return (\n    <div\n      style={{ width: \"100%\" }}\n    >\n      <div style={{ positin: 'relative', width: '100%', minHeight: \"100px\" }}>\n        {loader &&\n          <GridContainer>\n            <GridItem\n              xs={12}\n              sm={12}\n              md={12}\n              lg={12}\n              xl={12}\n            >\n              <div style={{ display: \"flex\", alignItems: \"center\" }}>\n                <LinearProgress />\n              </div>\n            </GridItem>\n          </GridContainer>\n        }\n        <div\n          style={{\n            position: \"relative\",\n            width: \"100%\",\n            display: \"flex\"\n          }}\n        >\n          <div\n            style={{\n              width: \"177px\",\n              padding: 7,\n              display: \"flex\",\n              flexDirection: \"column\",\n              marginRight: \"solid 1px lightgray\"\n            }}\n          >\n            {filteredItems.length > 1 ?\n              <div\n                style={{\n                  backgroundColor: cardsType === 'all' ? \"rgba(0,0,0,0.08)\" : \"\",\n                  padding: \"0 3px\"\n                }}\n              >\n                <CustomButton\n                  title={translate(`$__allResults`, '*')}\n                  text={translate(`$__allResults`, '*')}\n                  color={cardsType === 'all' ? customApp('menu') : 'lightGray'}\n                  icon={'manage_search'}\n                  onClick={() => {\n                    setCardsType('all')\n                  }}\n                  size={'17px'}\n                  style={{ padding: \"0px 3px !important\" }}\n                  transparent\n                />\n              </div>\n              : <React.Fragment></React.Fragment>\n            }\n            {db.type.filter(tp =>\n              filteredItems\n                .filter(card =>\n                  db.cards[card].type === tp.value).length > 0\n            ).map((tp, i) => {\n              return (\n                <div\n                  key={`${i}-${tp}`}\n                  style={{\n                    backgroundColor: cardsType === 'asset' ? \"rgba(0,0,0,0.08)\" : \"\",\n                    padding: \"0 3px\",\n                    display: \"flex\",\n                    justifyContent: \"space-between\",\n                    alignItems: \"center\"\n                  }}\n                >\n                  <CustomButton\n                    title={translate(`${tp.label}`, '*')}\n                    text={translate(`${tp.label}`, '*')}\n                    color={cardsType === tp.value ? customApp('menu') : 'lightGray'}\n                    icon={tp.icon}\n                    onClick={() => {\n                      setCardsType(tp.value)\n                    }}\n                    size={'17px'}\n                    style={{ padding: \"0px 3px !important\" }}\n                    transparent\n                  />\n                  <div style={{\n                    backgroundColor: cardsType === tp.value ? customApp(\"menu\", 1) : customApp(\"menu\", 0.5),\n                    fontSize: 9,\n                    color: \"#FFFFFF\",\n                    borderRadius: 11,\n                    width: 22,\n                    height: 22,\n                    display: \"flex\",\n                    alignItems: \"center\",\n                    justifyContent: \"center\"\n                  }}>\n                    {filteredItems.filter(card => db.cards[card].type === tp.value).length}\n                  </div>\n                </div>\n              )\n            })}\n          </div>\n          <div\n            style={{\n              width: \"calc(100% - 177px)\",\n              padding: 7,\n              display: \"flex\",\n              flexDirection: \"column\",\n            }}\n          >\n            <GridContainer>\n              {db.type.filter(tp =>\n                (cardsType !== 'all'\n                  && tp.value === cardsType\n                )\n                || (\n                  cardsType === 'all'\n                  &&\n                  filteredItems\n                    .filter(card =>\n                      db.cards[card].type === tp.value).length > 0\n                )\n              ).map((tp, i) => {\n                return (\n                  <div key={`${tp}-${i}`}>\n                    <GridItem\n                      xs={12}\n                      sm={12}\n                      md={12}\n                      lg={12}\n                      xl={12}\n                    >\n                      <HeaderWithIcon\n                        title={translate(tp.label, 1)}\n                        icon={tp.icon}\n                        color={customApp('menu')}\n                        style={{\n                          padding: '7px'\n                        }}\n                      />\n                      {filteredItems\n                        .filter(card => db.cards[card].type === tp.value)\n                        .sort((a, b) => {\n                          if (db.cards[a].name < db.cards[b].name)\n                            return -1\n                          if (db.cards[a].name > db.cards[b].name)\n                            return 1\n                          return 0\n                        })\n                        .map((card, i) => {\n                          return (\n                            <GridItem\n                              key={card}\n                              md={12}\n                              style={{ minWidth: '300px' }}\n                            >\n                              <Card data={db.cards[card]} db='cards' showConnectedIn searchText={props.text} expanded={false} onAction={() => { props.onAction() }} />\n                            </GridItem>\n                          )\n                        })}\n                    </GridItem>\n                  </div>\n                )\n              })}\n            </GridContainer>\n          </div>\n        </div>\n\n      </div>\n    </div >\n  )\n}\n\nconst mapStateToProps = (store, ownProps) => {\n  return {\n    cards: store.db.cards\n  }\n}\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(SearchComponent))","import React from \"react\";\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Card from \"components/Card\";\nimport LinearProgress from \"components/Progress/linear\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\nimport HeaderWithIcon from \"components/Header/withIcon\";\nimport AgileStatus from \"components/Agile/status\";\n\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\nimport Pagination from '@material-ui/lab/Pagination';\n\n//DEPENDENCIES\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/search.js\";\nimport Bright from \"assets/icons/BrigthAndConnected\";\n\n//FUNCTIONS\nimport { removeSeats, translate, customApp, getAppAccess } from \"functions/\";\n\nfunction SearchComponent(props) {\n  return <React.Fragment></React.Fragment>\n  const [lastChange, setLastChange] = React.useState(\"\")\n  const [loader, setLoader] = React.useState(false)\n  const [page, setPage] = React.useState(1);\n  const [filteredItems, setfilteredItems] = React.useState([]);\n  const { db, session, search } = reduxStore.getState()\n  const { dataType } = db\n\n  const limit = 7\n\n  const expanded = db.myTasksMenuExpanded ? true : false\n  let AppAccess = getAppAccess()\n\n  let searchTimer = setTimeout(() => {\n  }, 1000)\n\n  let hashs = window.location.hash.split('/')\n  hashs[0] = hashs[0].replace('#', '')\n\n  React.useEffect(() => {\n    if (props.text.length > 1 && props.text !== lastChange) {\n      setLastChange(props.text)\n      const timer = setTimeout(() => searchCards(), 1000);\n      setLoader(true)\n      return () => clearTimeout(timer);\n    }\n  }, [props.text])\n\n  const searchCards = async () => {\n    let searchResult = new Promise((resolve, reject) => {\n      resolve(Object.keys(db.cards).filter(card =>\n      (\n        (\n          (\n            AppAccess.owner\n            || AppAccess.planAdmin\n            || AppAccess.planModerate\n            || AppAccess.planRead\n          )\n          ||\n          (\n            session._id\n            && db.cards[card]._users\n            && db.cards[card]._users[Object.keys(db.cards[card]._users).find(a => a.indexOf(session._id) > -1)]\n          )\n        )\n        &&\n        (\n          props.text\n          && removeSeats(db.cards[card].name).toLowerCase().indexOf(props.text) > -1\n        )\n        &&\n        (\n          !db.cards[card].deleted\n          &&\n          (\n            !db.cards[card]._planId\n            ||\n            (\n              db.cards[card]._planId\n              && db.cards[db.cards[card]._planId]\n              && !db.cards[db.cards[card]._planId].deleted\n            )\n          )\n        )\n        &&\n        (\n          !db.cards[card]._parent\n          ||\n          (\n            db.cards[card]._parent\n            && db.cards[db.cards[card]._parent]\n            && !db.cards[db.cards[card]._parent].deleted\n          )\n        )\n      ))\n      )\n    })\n\n    let response = await searchResult.then(a => {\n      return a\n    })\n    if (response) {\n      setfilteredItems(response)\n      setLoader(false)\n      console.log(response)\n      if (props.onFinish)\n        props.onFinish()\n    }\n  }\n  return <React.Fragment></React.Fragment>\n  return (\n    <div\n      style={{ width: \"100%\" }}\n    >\n      <div style={{ positin: 'relative', width: '100%' }}>\n        {/* {loader &&\n          <div style={{ display: \"flex\", alignItems: \"center\" }}>\n            <LinearProgress />\n          </div>\n        } */}\n        {filteredItems.length > 25 &&\n          <div style={{ width: '100%', display: 'flex', justifyContent: 'center' }}>\n            <Pagination\n              count={filteredItems.length}\n              size=\"small\"\n              page={page} onChange={(e, newPage) => {\n                setPage(newPage)\n              }} />\n          </div>\n        }\n        <GridContainer>\n\n          {filteredItems\n            .filter(card => db.cards[card].type.indexOf('plan') > -1).length > 0 &&\n            <GridItem\n              xs={12}\n              sm={12}\n              md={12}\n              lg={12}\n              xl={12}\n            >\n              <HeaderWithIcon\n                title={translate('$__plans', 1)}\n                icon={dataType.filter(a => a.name === 'plan')[0].icon}\n                color={customApp('menu')}\n                filterText={props.text}\n                style={{\n                  padding: '7px'\n                }}\n              />\n              {filteredItems\n                .filter(card => db.cards[card].type === 'plan')\n                .map((card, i) => {\n                  if (i >= (page - 1) * limit && i <= (page * limit))\n                    return (\n                      <GridItem\n                        key={card}\n                        md={12}\n                      >\n                        <Card db=\"cards\" data={db.cards[card]} db='cards' showConnectedIn />\n                      </GridItem>\n                    )\n                })}\n            </GridItem>\n          }\n          {filteredItems\n            .filter(card => db.cards[card].type.indexOf('guideline') > -1).length > 0 &&\n            <GridItem\n              xs={12}\n              sm={12}\n              md={12}\n              lg={12}\n              xl={12}\n            >\n              <HeaderWithIcon\n                title={translate('$__guidelines', 1)}\n                icon={dataType.filter(a => a.name === 'guideline')[0].icon}\n                color={customApp('menu')}\n                style={{\n                  padding: '7px'\n                }}\n              />\n              {filteredItems\n                .filter(card => db.cards[card].type.indexOf('guideline') > -1)\n                .map((card, i) => {\n                  if (i >= (page - 1) * limit && i <= (page * limit))\n                    return (\n                      <GridItem\n                        key={card}\n                        md={12}\n                      >\n                        <Card db=\"cards\" data={db.cards[card]} db='cards' showConnectedIn />\n                      </GridItem>\n                    )\n                })}\n            </GridItem>\n          }\n\n          {filteredItems\n            .filter(card => db.cards[card].type.indexOf('objective') > -1).length > 0 &&\n            <GridItem\n              xs={12}\n              sm={12}\n              md={12}\n              lg={12}\n              xl={12}\n            >\n              <HeaderWithIcon\n                title={translate('$__objectives', 1)}\n                icon={dataType.filter(a => a.name === 'objective')[0].icon}\n                color={customApp('menu')}\n                style={{\n                  padding: '7px'\n                }}\n              />\n              {filteredItems\n                .filter(card => db.cards[card].type.indexOf('objective') > -1)\n                .map((card, i) => {\n                  if (i >= (page - 1) * limit && i <= (page * limit))\n                    return (\n                      <GridItem\n                        key={card}\n                        md={12}\n                      >\n                        <Card db=\"cards\" data={db.cards[card]} db='cards' showConnectedIn />\n                      </GridItem>\n                    )\n                })}\n            </GridItem>\n          }\n\n          {filteredItems\n            .filter(card => db.cards[card].type.indexOf('goal') > -1).length > 0 &&\n            <GridItem\n              xs={12}\n              sm={12}\n              md={12}\n              lg={12}\n              xl={12}\n            >\n              <HeaderWithIcon\n                title={translate('$__goals', 1)}\n                icon={dataType.filter(a => a.name === 'goal')[0].icon}\n                color={customApp('menu')}\n                style={{\n                  padding: '7px'\n                }}\n              />\n              {filteredItems\n                .filter(card => db.cards[card].type.indexOf('goal') > -1)\n                .map((card, i) => {\n                  if (i >= (page - 1) * limit && i <= (page * limit))\n                    return (\n                      <GridItem\n                        key={card}\n                        md={12}\n                      >\n                        <Card db=\"cards\" data={db.cards[card]} db='cards' showConnectedIn />\n                      </GridItem>\n                    )\n                })}\n            </GridItem>\n          }\n\n          {filteredItems\n            .filter(card =>\n              dataType.filter(dt => dt.name === db.cards[card].type)[0].myTasks\n              && db.cards[card].type !== 'objective'\n              && db.cards[card].type !== 'goal'\n              && db.cards[card].type !== 'plan'\n              && db.cards[card].type.indexOf('guideline') === -1\n            ).length > 0 &&\n            <GridItem\n              xs={12}\n              sm={12}\n              md={12}\n              lg={12}\n              xl={12}\n            >\n              <HeaderWithIcon\n                title={translate('$__actions', 1)}\n                icon={'double_arrow'}\n                color={customApp('menu')}\n                style={{\n                  padding: '7px'\n                }}\n              />\n              {filteredItems\n                .filter(card =>\n                  dataType.filter(dt => dt.name === db.cards[card].type)[0].myTasks\n                  && db.cards[card].type !== 'objective'\n                  && db.cards[card].type !== 'goal'\n                  && db.cards[card].type !== 'plan'\n                  && db.cards[card].type.indexOf('guideline') === -1\n                )\n                .map((card, i) => {\n                  if (i >= (page - 1) * limit && i <= (page * limit))\n                    return (\n                      <GridItem\n                        key={card}\n                        md={12}\n                      >\n                        <Card db=\"cards\" data={db.cards[card]} db='cards' showConnectedIn />\n                      </GridItem>\n                    )\n                })}\n            </GridItem>\n          }\n\n          {filteredItems\n            .filter(card =>\n              db.cards[card].type === 'insight'\n              || db.cards[card].type === 'link'\n            ).length > 0 &&\n            <GridItem\n              xs={12}\n              sm={12}\n              md={12}\n              lg={12}\n              xl={12}\n            >\n              <HeaderWithIcon\n                title={'BRIGHT & CONNECTED'}\n                icon={Bright}\n                color={customApp('menu')}\n                style={{\n                  padding: '7px'\n                }}\n              />\n              <GridContainer>\n                {filteredItems\n                  .filter(card =>\n                    db.cards[card].type === 'insight'\n                    || db.cards[card].type === 'link'\n                  )\n                  .map((card, i) => {\n                    if (i >= (page - 1) * limit && i <= (page * limit))\n                      return (\n                        <GridItem\n                          key={card}\n                          xs={12}\n                          sm={6}\n                          md={4}\n                          lg={3}\n                          xl={2}\n                        >\n                          <Card db=\"cards\" data={db.cards[card]} db='cards' showConnectedIn expanded Avatar Resume />\n                        </GridItem>\n                      )\n                  })}\n              </GridContainer>\n            </GridItem>\n          }\n        </GridContainer>\n      </div>\n    </div >\n  );\n}\n\nconst mapStateToProps = (store, ownProps) => {\n  return {\n    store,\n    ownProps\n  }\n};\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch);\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(SearchComponent))","//CORE\nimport React from 'react'\nimport moment from \"moment-timezone\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Card from \"components/Card\";\nimport Icon from \"components/Icon\";\nimport Message from \"components/Timeline/message\";\nimport TextField from \"components/TextField\";\nimport Tooltip from \"@material-ui/core/Tooltip\";\nimport HeaderWithIcon from \"components/Header/card\";\n\n//@MATERIAL\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\";\nimport Avatar from \"components/Avatar\";\n\n//FUNCTIONS\nimport {\n    customApp,\n    getDate,\n    Highlighted,\n    translate,\n} from 'functions';\n\nfunction Component(props) {\n    const { timeline, functions } = reduxStore.getState()\n    const { socket } = functions\n    const { db } = reduxStore.getState()\n    const [viewMessage, setViewMessage] = React.useState(false)\n\n    const [file, setFile] = React.useState(props.data)\n    const fileName = file.name.split('.')\n    let ext = fileName[fileName.length - 1]\n\n    const [edit, setEdit] = React.useState(false)\n    const [name, setName] = React.useState(fileName[0])\n    const [mounted, setMounted] = React.useState(fileName[0])\n\n\n    React.useEffect(() => {\n        if (!mounted)\n            setMounted(true)\n    }, [props.data])\n\n    if (file.name === 'blob') {\n        file.name = `${translate('$__coverImage', '*')}.jpg`\n        ext = 'jpg'\n    }\n\n    let img = `attachment`\n    if (reduxStore.getState().db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1).length > 0)\n        img = reduxStore.getState().db.fileExtensions.filter(a => a.ext.indexOf(ext.toLowerCase()) > -1)[0].icon\n            || `https://machen.azureedge.net/${file.file}`\n\n\n    const update = async (dataUpdate) => {\n        try {\n            socket.emit(\"data\", {\n                module: \"node\",\n                method: \"put\",\n                action: \"update\"\n            }, {\n                _id: file._id,\n                ...dataUpdate\n            }, async () => {\n                setFile({ ...file, ...dataUpdate })\n                setEdit(false)\n            })\n        } catch (e) {\n            console.log(e)\n        }\n    }\n\n    let timelineData = {\n        ...db.cards[file.cardId] && timeline[file.cardId] && timeline[file.cardId][file.timelineId] ? timeline[file.cardId][file.timelineId] : file.message,\n    }\n    if (timelineData && !timelineData.message)\n        timelineData = {\n            ...timelineData,\n            message: translate(\"$__onlyAttachment\")\n        }\n\n\n    return (\n        <div\n            style={{\n                width: '100%'\n            }}\n        >\n            <div\n                style={{\n                    position: 'relative',\n                    float: 'left',\n                    width: '100%',\n                    marginBottom: '5px',\n                    cursor: 'pointer',\n                }}\n            >\n                {props.resume ?\n                    <React.Fragment>\n                        <div\n                            style={{\n                                position: 'relative',\n                                width: '100%',\n                                display: 'flex',\n                                alignItems: 'center',\n                                // justifyContent: 'space-between'\n                            }}\n                            onClick={(e) => {\n                                if (props.openLightBox)\n                                    props.openLightBox()\n                            }}\n                        >\n                            <div\n                                style={{\n                                    position: 'relative',\n                                    float: 'left',\n                                    width: '33px',\n                                    height: '33px',\n                                    // marginRight: '7px',\n                                    alignItems: 'center',\n                                    display: 'flex',\n                                    overflow: 'hidden'\n                                }}\n                            >\n                                {typeof img === 'string' && img.indexOf('https') === -1 && img.indexOf('svg') === -1 ?\n                                    <Icon icon={img} size='33px' />\n                                    :\n                                    <img src={img} width='100%' style={{ width: 'auto', height: 'auto', maxHeight: '77%' }} onError={(e) => e.target.src = img} />\n                                }\n                            </div>\n\n                            <div style={{\n                                marginLeft: '7px',\n                                width: \"calc(100% - 80px)\",\n                                maxWidth: \"calc(100% - 80px)\",\n                                minWidth: '150px',\n                                textOverflow: 'ellipsis',\n                                overflow: 'hidden',\n                                whiteSpace: 'nowrap',\n                            }}\n                            >\n                                {Highlighted(file.name, props.searchText)}\n                            </div>\n                            {db.users[file.createdBy] &&\n                                <div style={{\n                                    position: 'absolute', right: '10px', top: '7px', zIndex: '10'\n                                }}>\n                                    <AvatarGroup max={7}>\n                                        <Tooltip\n                                            title={db.users[file.createdBy].displayName ? db.users[file.createdBy].displayName : db.users[file.createdBy].name}\n                                        >\n                                            <Avatar\n                                                alt={db.users[file.createdBy].displayName ? db.users[file.createdBy].displayName : db.users[file.createdBy].name}\n                                                src={`${db.users[file.createdBy].image}`}\n                                                style={{ width: '15px', height: '15px' }}\n                                            >\n                                                {db.users[file.createdBy].name.substr(0, 1)}\n                                            </Avatar>\n                                        </Tooltip>\n                                    </AvatarGroup>\n                                </div>\n\n                            }\n                        </div>\n                        {props.showParent &&\n                            (\n                                file.timelineId\n                                || file.message\n                            )\n                            // && viewMessage\n                            &&\n                            (\n                                (\n                                    db.cards[file.cardId]\n                                    && timeline[file.cardId]\n                                    && timeline[file.cardId][file.timelineId]\n                                )\n                                ||\n                                (\n                                    file.message\n                                )\n                            )\n                            &&\n                            <div style={{ width: '100%', marginBottom: \"33px\" }} >\n                                <Message\n                                    openLightBox={(e) => {\n                                        if (props.openLightBox)\n                                            props.openLightBox(e)\n                                    }}\n                                    storie={timelineData}\n                                    db={'cards'} nodeId={file.cardId}\n                                />\n                                <div style={{ clear: \"both\" }}></div>\n                            </div>\n                        }\n                        {props.showParent && file.cardId && db.cards[file.cardId] &&\n                            <div style={{ width: '100%', top: \"33px\" }}>\n                                <Card db=\"cards\" data={db.cards[file.cardId]} showConnectedIn />\n                            </div>\n                        }\n                        <div style={{ width: \"100%\", height: \"1px\", backgroundColor: \"rgba(0,0,0,0.1)\", marginTop: \"15px\" }}></div>\n                    </React.Fragment>\n                    :\n                    <div style={{\n                        position: \"relative\",\n                        float: 'left',\n                        width: '100%',\n                        marginTop: '7px',\n                        padding: '15px',\n                        display: 'flex',\n                        alignItems: 'center',\n                        height: '70px'\n                    }}>\n                        <div style={{\n                            position: 'absolute',\n                            top: '0px',\n                            width: 'calc(100% - 30px)',\n                            borderBottom: `solid 1.5px ${customApp('color')}`,\n                            alignItems: 'center',\n                            display: 'flex',\n                            color: customApp('color'),\n                        }}>\n                            <div\n                                style={{\n                                    width: '357px',\n                                    textAlign: 'center',\n                                    alignItems: 'center',\n                                    justifyContent: 'center',\n                                    display: 'flex',\n                                    cursor: 'pointer'\n                                }}\n                                onClick={(e) => {\n                                    if (props.onClick)\n                                        props.onClick()\n                                }}\n                                onDoubleClick={() => {\n                                    setEdit(true)\n                                }}\n                            >\n                                {edit ?\n                                    <React.Fragment>\n                                        <div\n                                            style={{ position: 'relative', float: 'left', width: '100%', padding: '7px', display: 'flex', alignItems: 'center' }}>\n                                            <div style={{ width: 'calc(100% - 50px)', display: 'flex' }}>\n                                                <TextField\n                                                    label={translate('$__taskTitle')}\n                                                    variant={customApp('fieldVariant')}\n                                                    name={'name'}\n                                                    InputLabelProps={{\n                                                        shrink: true,\n                                                    }}\n                                                    InputProps={{\n                                                        autoComplete: 'new-password',\n                                                        onChange: (d) => {\n                                                            setName(d.target.value)\n                                                        },\n                                                        onBlur: (d) => {\n                                                            if (d.target.value === '')\n                                                                setEdit(!edit)\n                                                        },\n                                                        onKeyDown: (e) => {\n                                                            if (e.keyCode === 13 && name) {\n                                                                update({\n                                                                    name: `${name}.${ext}`\n                                                                })\n                                                            }\n                                                            if (e.keyCode === 27) {\n                                                                setEdit(!edit)\n                                                                setName()\n                                                            }\n                                                        }\n                                                    }}\n                                                    autoFocus\n                                                    value={name}\n                                                    placeholder={translate('$__taskTitlePlaceholder')}\n                                                />\n                                            </div>\n                                            <div style={{ display: 'flex' }}>\n                                                <div\n                                                    onClick={() => update({\n                                                        name: `${name}.${ext}`\n                                                    })}\n                                                >\n                                                    <Icon color='green' icon={'save'} title={translate('$__save', '*')} size={props.actionsSize || '25px'} />\n                                                </div>\n                                                <div\n                                                    onClick={() => {\n                                                        setEdit(!edit)\n                                                        setName('')\n                                                    }}\n                                                >\n                                                    <Icon color={customApp('medium')} icon={'cancel'} title={translate(\"$__cancel\", \"*\")} size={props.actionsSize || '25px'} />\n                                                </div>\n                                            </div>\n                                        </div>\n                                    </React.Fragment>\n                                    :\n                                    <div style={{ width: '100%' }}>\n\n                                        {file.in && file.in.name &&\n                                            <div style={{ display: 'flex', alignItems: \"center\", }}>\n                                                {file.in.db === 'User' ?\n                                                    <Tooltip\n                                                        title={file.in.name}\n                                                    >\n                                                        <Avatar\n                                                            alt={file.in.name}\n                                                            src={file.in.image}\n                                                            style={{ width: '15px', height: '15px' }}\n                                                        >\n                                                            {file.in.name}\n                                                        </Avatar>\n                                                    </Tooltip>\n                                                    : <React.Fragment></React.Fragment>}\n                                                <HeaderWithIcon\n                                                    title={file.in.name}\n                                                    icon={file.in.db === 'User' ? null : (file.in.type && db && db.dataType && db.dataType.filter(a => a.name === file.in.type)[0] && db.dataType.filter(a => a.name === file.in.type)[0].icon) || \"$__topic\"}\n                                                    color={customApp('medium')}\n                                                    style={{\n                                                        padding: '7px',\n                                                        width: 'calc(100% - 30px)',\n                                                        textAlign: 'left'\n                                                    }}\n                                                    textStyle\n                                                />\n                                            </div>\n                                        }\n                                        <div\n                                            style={{\n                                                width: '100%',\n                                                display: \"flex\",\n                                                alignItems: 'center',\n                                                padding: '0 15px'\n                                            }}>\n                                            <div\n                                                style={{\n                                                    position: 'relative',\n                                                    float: 'left',\n                                                    width: '33px',\n                                                    height: '33px',\n                                                    marginRight: '7px',\n                                                    alignItems: 'center',\n                                                    height: '50px',\n                                                    display: 'flex',\n                                                    justifyContent: 'center'\n                                                }}\n                                            >\n                                                {typeof img === 'string' && img.indexOf('https') === -1 && img.indexOf('svg') === -1 ?\n                                                    <Icon icon={img} size='33px' />\n                                                    :\n                                                    <div\n                                                        style={{\n                                                            position: 'absolute',\n                                                            width: '33px',\n                                                            height: '33px',\n                                                            margin: '7px',\n                                                            borderRadius: '50%',\n                                                            overflow: 'hidden',\n                                                            backgroundImage: `url(\"${img}\")`,\n                                                            backgroundPosition: 'center center',\n                                                            backgroundSize: 'cover'\n                                                        }}\n\n                                                    >\n                                                    </div>\n                                                }\n                                            </div>\n                                            {file.name}\n                                        </div>\n                                        {file.createdBy &&\n                                            <div style={{\n                                                position: 'relative',\n                                                display: \"flex\",\n                                                alignItems: \"center\",\n                                                color: props.dark ? \"lightgray\" : \"gray\",\n                                                fontSize: 10,\n                                                marginLeft: '42px',\n                                                clear: 'both'\n                                            }}>\n                                                <Avatar\n                                                    alt={file.createdBy.name}\n                                                    src={file.createdBy.image}\n                                                    style={{ width: '15px', height: '15px' }}\n                                                >\n                                                    {file.createdBy.name}\n                                                </Avatar>\n                                                <span style={{ marginLeft: 3 }}>\n                                                    {file.createdBy.name} - ({getDate(file.created_at)})\n                                                </span>\n                                            </div>\n                                        }\n                                    </div>\n                                }\n                            </div>\n                            <div\n                                style={{\n                                    width: '130px',\n                                    textAlign: 'center',\n                                    borderRight: `solid 1.5px ${customApp('color')}`,\n                                    alignItems: 'center',\n                                    justifyContent: 'center',\n                                    display: 'flex',\n                                    fontSize: '12px',\n                                }}\n                            >\n                                {moment(new Date(file.created_at * 1000)).format(\"DD/MM/YYYY HH:mm\")}\n                            </div>\n                            <div\n                                style={{\n                                    width: '130px',\n                                    borderRight: `solid 1.5px ${customApp('color')}`,\n                                    alignItems: 'center',\n                                    justifyContent: 'center',\n                                    display: 'flex',\n                                    overflow: 'visible'\n                                }}\n                            >\n                                {db.users[file.createdBy] &&\n                                    <Tooltip\n                                        title={db.users[file.createdBy].name}\n                                    >\n                                        <React.Fragment>\n                                            <Avatar size=\"sm\" src={`${db.users[file.createdBy].image}`} >\n                                                {db.users[file.createdBy].name.substr(0, 1)}\n                                            </Avatar>\n                                        </React.Fragment>\n                                    </Tooltip>\n                                }\n                            </div>\n                            <div\n                                style={{\n                                    width: '300px',\n                                    textAlign: 'left',\n                                    borderRight: `solid 1.5px ${customApp('color')}`,\n                                    paddingLeft: '15px',\n                                    alignItems: 'center',\n                                    justifyContent: 'center',\n                                    display: 'flex'\n                                }}\n                            >\n\n                            </div>\n                            <div\n                                style={{\n                                    width: '130px',\n                                    textAlign: 'left',\n                                    paddingLeft: '15px',\n                                    alignItems: 'center',\n                                    justifyContent: 'center',\n                                    display: 'flex'\n                                }}>\n                                <Tooltip\n                                    title={translate('$__showFile')}>\n                                    <Icon\n                                        onClick={props.openLightBox ? () => {\n                                            props.openLightBox()\n                                        } : null\n                                        }\n                                    >\n                                        pageview\n                                    </Icon>\n                                </Tooltip>\n                                {(file.timelineId || file.message) &&\n                                    <Tooltip\n                                        title={translate('$__viewMessage')}>\n                                        <Icon\n                                            size=\"20px\"\n                                            onClick={() => {\n                                                setViewMessage(!viewMessage)\n                                            }}\n                                        >feedback</Icon>\n                                    </Tooltip>\n                                }\n                            </div>\n                        </div>\n                    </div>\n                }\n            </div >\n            {\n                (file.timelineId || file.message)\n                && viewMessage\n                &&\n                (\n                    (\n                        db.cards[file.cardId]\n                        && timeline[file.cardId]\n                        && timeline[file.cardId][file.timelineId]\n                    )\n                    ||\n                    (\n                        file.message\n                    )\n                )\n                &&\n                <div style={{ width: '100%' }} >\n                    <Message\n                        openLightBox={(e) => {\n                            if (props.openLightBox)\n                                props.openLightBox(e)\n                        }}\n                        storie={timelineData}\n                        db={'cards'} nodeId={file.cardId}\n                    />\n                </div>\n            }\n        </div >\n    )\n}\nconst mapStateToProps = () => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)\n","import React from \"react\";\n\n//REDUX\nimport { connect } from 'react-redux';\nimport { bindActionCreators } from 'redux';\nimport * as reduxActions from 'store/actions';\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport File from \"components/Files/file\";\nimport LinearProgress from \"components/Progress/linear\";\nimport GridContainer from \"components/Grid/GridContainer\";\nimport GridItem from \"components/Grid/GridItem\";\nimport HeaderWithIcon from \"components/Header/withIcon\";\n\n// @MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//DEPENDENCIES\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/search.js\";\n\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\";\nimport apims from \"apims\"\n\nfunction SearchComponent(props) {\n  const [lastChange, setLastChange] = React.useState(\"\")\n  const [loader, setLoader] = React.useState(false)\n  const [filteredItems, setfilteredItems] = React.useState([]);\n  const { db, functions } = reduxStore.getState()\n  const { dataType } = db\n  const { socket } = functions\n\n  let searchTimer = setTimeout(() => {\n  }, 1000)\n\n  let lightBoxfiles = [];\n  let hashs = window.location.hash.split('/')\n  hashs[0] = hashs[0].replace('#', '')\n\n  React.useEffect(() => {\n    if (props.text.length > 1 && props.text !== lastChange) {\n      setLastChange(props.text)\n      const timer = setTimeout(() => searchFiles(), 1000);\n      setLoader(true)\n      return () => clearTimeout(timer);\n    }\n  }, [props.text])\n\n  const searchFiles = async () => {\n    const res = await apims.get(`/M_Files_Search/?text=${props.text}`)\n    if (res && res.data) {\n      if (props.onFinish)\n        props.onFinish(Object.keys(res.data).length)\n      setfilteredItems(res.data)\n      setLoader(false)\n    }\n  }\n\n  const openLightBox = (f) => {\n    props.reduxFunction(\"ASYNC\", \"LIGHTBOX\", {\n      open: true,\n      files: lightBoxfiles,\n      file: f\n    })\n  }\n\n  return (\n    <div\n      style={{ width: \"100%\" }}\n    >\n      <div style={{ positin: 'relative', width: '100%' }}>\n        {loader &&\n          <div style={{ display: \"flex\", alignItems: \"center\" }}>\n            <LinearProgress />\n          </div>\n        }\n        <GridContainer>\n          {Object.keys(filteredItems).length > 0 &&\n            <GridItem\n              xs={12}\n              sm={12}\n              md={12}\n              lg={12}\n              xl={12}\n            >\n              <HeaderWithIcon\n                title={translate('$__files', 1)}\n                icon={dataType.filter(a => a.name === 'plan')[0].icon}\n                color={customApp('menu')}\n                filterText={props.text}\n                style={{\n                  padding: '7px'\n                }}\n              />\n              {Object.keys(filteredItems)\n                .map((file, i) => {\n                  lightBoxfiles.push(filteredItems[file])\n                  return (\n                    <GridItem\n                      key={file}\n                      md={12}\n                    >\n                      <File\n                        data={filteredItems[file]}\n                        searchText={props.text}\n                        resume\n                        showParent\n                        openLightBox={() => {\n                          openLightBox(filteredItems[file]._id)\n                          if (props.onAction)\n                            props.onAction()\n                        }\n                        }\n                      />\n                    </GridItem>\n                  )\n                })}\n            </GridItem>\n          }\n        </GridContainer>\n      </div>\n    </div >\n  );\n}\n\nconst mapStateToProps = (store, ownProps) => {\n  return {\n    store,\n    ownProps\n  }\n};\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch);\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(SearchComponent))","\r\nconst adminNavbarLinksStyle = theme => ({\r\n  avatar: {\r\n    width: \"30px\",\r\n    height: \"30px\",\r\n    backgroundSize: \"cover\",\r\n    borderRadius: \"50%\"\r\n  },\r\n  component: {\r\n    marginTop: '15px',\r\n    marginRight: '8px',\r\n    marginBottom: '15px',\r\n    zIndex: '10',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    justifyContent: 'center'\r\n  },\r\n  selectedName: {\r\n    display: \"inline-flex\", cursor: \"pointer\"\r\n  },\r\n  selectedNameText: {\r\n    textDecoration: \"none\",\r\n    fontSize: \"12px\",\r\n    fontFamily: \"Soleto\",\r\n  },\r\n});\r\n\r\nexport default adminNavbarLinksStyle;\r\n","//REACT\nimport React from \"react\";\nimport PropTypes from \"prop-types\";\n//import api from \"api/\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store\";\n\n//COMPONENTS\nimport HtmlTooltip from \"components/Tooltip/html\"\n\n//@MATERIAL\nimport ClickAwayListener from \"@material-ui/core/ClickAwayListener\";\nimport Grow from \"@material-ui/core/Grow\";\nimport MenuItem from \"@material-ui/core/MenuItem\";\nimport MenuList from \"@material-ui/core/MenuList\";\nimport Paper from \"@material-ui/core/Paper\";\nimport Popper from \"@material-ui/core/Popper\";\nimport withStyles from \"@material-ui/core/styles/withStyles\";\n\n//STYLES\nimport headerLinksStyle from \"assets/jss/material-dashboard-pro-react/components/SideBarMenuUser\";\n\n//FUNCTIONS\nimport { customApp, translate } from \"functions/\";\n\nfunction HeaderLinks(props) {\n    const { db, session } = reduxStore.getState();\n    const { socket } = reduxStore.getState().functions\n    const [open, setOpen] = React.useState(false);\n    const anchorRef = React.useRef(null);\n\n    const handleToggle = i => {\n        setOpen((prevOpen) => !prevOpen);\n    };\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n        setOpen(false);\n    };\n\n    function handleListKeyDown(event) {\n        if (event.key === 'Tab') {\n            event.preventDefault();\n            setOpen(false);\n        }\n    }\n\n    const prevOpen = React.useRef(open);\n    React.useEffect(() => {\n        if (prevOpen.current === true && open === false) {\n            anchorRef.current.focus();\n        }\n\n        prevOpen.current = open;\n    }, [open]);\n\n    const logout = async () => {\n        socket.emit(\"data\", {\n            module: \"user\",\n            method: \"post\",\n            action: \"logout\"\n        }, {},\n            () => {\n\n            })\n\n        // handleToggle()\n        localStorage.clear()\n        setTimeout(() => {\n            window.location.href = '/login'\n        }, 500)\n    };\n\n    const { classes } = props\n    const { users } = db\n    const user = users && Object.keys(users).length > 0 ? users[Object.keys(users).find(a => session && session._id && users[a] && users[a]._id && users[a]._id.indexOf(session._id) > -1)] : {}\n\n    if (!user || !user.name)\n        return null\n\n    return (\n        <div className={classes.component}>\n            <div className={classes.selectedName} onClick={handleToggle}>\n                <div\n                    ref={anchorRef}\n                    className={classes.selectedNameText}\n                    style={{\n                        color: customApp('light') || '#FFFFFF',\n                        display: \"flex\",\n                        alignItems: 'center',\n                        justifyContent: 'center',\n                    }}>\n                    <HtmlTooltip title={\n                        <React.Fragment>\n                            {user.name ? user.name : user.name}\n                        </React.Fragment>\n                    } >\n                        <React.Fragment>\n                            <div\n                                style={{\n                                    display: 'flex',\n                                    alignItems: 'center',\n                                    justifyContent: 'center',\n                                    width: '33px',\n                                    height: '33px',\n                                    borderRadius: '50%',\n                                    border: `solid 1px ${customApp('menu')}`,\n                                }}\n                            >\n                                <div\n                                    style={{\n                                        display: 'flex',\n                                        width: '90%',\n                                        height: '90%',\n                                        backgroundImage: `url(\"${user.image}\")`,\n                                        backgroundSize: 'cover',\n                                        backgroundRepeat: 'no-repeat',\n                                        backgroundPosition: 'center center',\n                                        borderRadius: '50%',\n                                    }}\n                                ></div>\n                            </div>\n                        </React.Fragment>\n                    </HtmlTooltip>\n                </div>\n            </div>\n            <div style={{ zIndex: 10 }}>\n                <Popper open={open} anchorEl={anchorRef.current} role={undefined} transition disablePortal>\n                    {({ TransitionProps, placement }) => (\n                        <Grow\n                            {...TransitionProps}\n                            style={{ transformOrigin: placement === 'bottom' ? 'center top' : 'center bottom' }}\n                        >\n                            <Paper>\n                                <ClickAwayListener onClickAway={handleClose}>\n                                    <MenuList autoFocusItem={open} id=\"menu-list-grow\" onKeyDown={handleListKeyDown}>\n                                        {/* <MenuItem onClick={handleClose}>Profile</MenuItem> */}\n                                        <MenuItem onClick={() => {\n                                            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                ...db.sideModule,\n                                                id: session._id,\n                                                activeModule: 'userEdit',\n                                                db: 'users',\n                                                data: {\n                                                    type: 'user',\n                                                    ...db.users[session._id],\n                                                }\n                                            })\n                                        }}>{translate(\"$__myProfile\", 1)}</MenuItem>\n                                        <MenuItem onClick={() => logout()}>{translate(\"$__logout\", 1)}</MenuItem>\n                                    </MenuList>\n                                </ClickAwayListener>\n                            </Paper>\n                        </Grow>\n                    )}\n                </Popper>\n            </div>\n        </div>\n    );\n\n}\n\nHeaderLinks.propTypes = {\n    classes: PropTypes.object.isRequired\n};\n\nconst mapStateToProps = (store) => ({\n    users: store.db.users\n});\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch);\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(withStyles(headerLinksStyle)(HeaderLinks));","// ID_CREATED*************************\n\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n//COMPONENTS\nimport ChatNotifications from \"components/Chat/notifications\"\nimport CustomButton from \"components/Buttons/custom\"\nimport GridContainer from \"components/Grid/GridContainer\"\nimport GridItem from \"components/Grid/GridItem\"\nimport Icon from \"components/Icon\"\nimport MoreVert from \"components/MoreMenu/\"\nimport MyDayNotifications from \"components/NotificationsV2/myDay\"\nimport MyRequireApproval from \"components/NotificationsV2/requireApproval\"\nimport Notifications from \"components/NotificationsV2\"\nimport QuickAdd from \"components/QuickAdd/\"\nimport TextField from \"components/TextField\"\nimport TimersNotifications from \"components/Timer/notifications\"\nimport ErrorBoundary from \"components/ErrorBoundary/index.js\"\n\n// @MATERIAL\nimport Badge from '@material-ui/core/Badge';\nimport Button from \"@material-ui/core/Button\";\nimport ClickAwayListener from \"@material-ui/core/ClickAwayListener\";\nimport Grow from \"@material-ui/core/Grow\";\nimport InputAdornment from \"@material-ui/core/InputAdornment\";\nimport Paper from \"@material-ui/core/Paper\";\nimport Popper from \"@material-ui/core/Popper\";\nimport { withStyles } from \"@material-ui/core/styles\";\n\n\n//DEPENDENCIES\nimport SearchCards from \"components/TopSearch/cards\"\nimport SearchMessages from \"components/TopSearch/messages\"\nimport SearchFiles from \"components/TopSearch/files\"\nimport User from \"./User.js\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/views/search.js\"\n\n//ROUTES\nimport routes from \"routes\"\n\n//FUNCTIONS\nimport {\n  customApp,\n  getAppAccess,\n  translate,\n} from \"functions/\"\n\n\nfunction SearchComponent(props) {\n  const { db, session, chat } = reduxStore.getState()\n  const [searchValue, setSearchValue] = React.useState(\"\")\n  const [cardsLoader, setCardsLoader] = React.useState(0)\n  const [messagesLoader, setMessagesLoader] = React.useState(0)\n  const [filesLoader, setFilesLoader] = React.useState(0)\n  const [searchCardsLoading, setSearchCardsLoading] = React.useState(false)\n  const [searchFilesLoading, setSearchFilesLoading] = React.useState(false)\n  const [cardsStatusSearch, setCardsStatusSearch] = React.useState(\"asset\")\n  const [adminView, setAdminView] = React.useState(false)\n  const AppAccess = getAppAccess()\n\n  const [properties, setProperties] = React.useState({\n    title: null,\n    icon: null,\n    sTitle: null,\n    sIcon: null\n  })\n  const anchorRef = React.useRef(null)\n\n  let hashs = window.location.hash.split(\"/\")\n  hashs[0] = hashs[0].replace(\"#\", \"\")\n\n  React.useEffect(() => {\n    init()\n    return () => { }\n  }, [props])\n\n  const init = () => {\n    let route = {}\n\n    if (routes.filter(fil =>\n      fil.path === window.location.pathname\n    ).length > 0)\n      route = routes.filter(fil =>\n        fil.path === window.location.pathname\n      )[0]\n    let title = translate(`$__${route.alias}`, 1)\n    let icon = route.icon\n    let sTitle = \"\"\n    let sIcon = null\n\n    if (route.alias === \"plan\" && hashs[0] && db.cards[hashs[0]])\n      title = `${translate(`$__${route.alias}`, 1)}: ${db.cards[hashs[0]].name}`\n\n    if (\n      route.tabs\n      && route.tabs.length > 0\n      && route.tabs.filter(fil =>\n        fil.path === hashs[1]\n      ).length > 0\n    ) {\n      sTitle = translate(`$__${route.tabs.filter(fil => fil.path === hashs[1])[0].alias}`, 1)\n      icon = route.tabs.filter(fil => fil.path === hashs[1])[0].icon\n    }\n\n    setProperties({\n      title: title,\n      icon: icon,\n      sTitle: sTitle,\n      sIcon: sIcon\n    })\n\n  }\n\n  return (\n    <div\n      style={{\n        position: \"absolute\",\n        top: \"-4px\",\n        right: 0,\n        left: 0,\n        display: \"flex\",\n        alignItems: \"center\",\n        zIndex: \"10 !important\"\n      }\n      }\n      id={'top_'}\n    >\n      <GridContainer>\n        <GridItem\n          xs={10}\n          sm={4}\n          md={4}\n          lg={4}\n          xl={4}\n          style={{\n            display: \"flex\",\n            alignItems: \"center\"\n          }}\n          id={'top_menuHideShow'}\n        >\n          {!props.expanded &&\n            <Button\n              style={{ width: \"50px\" }}\n              onClick={() => {\n                props.menuExpand()\n              }}\n            >\n              <Icon\n                icon={\"menu\"}\n                title=\"$__showMenu\"\n                size={\"27px\"}\n                color={customApp(\"menu\")}\n              />\n            </Button>\n          }\n          <div\n            id={\"top_pageTitle\"}\n            style={{\n              color: customApp(\"menu\"),\n              marginLeft: \"22px\",\n              fontSize: \"12px\",\n              fontWeight: \"bold\"\n            }}>\n            {properties.sTitle ? `${properties.title} - ${properties.sTitle.toLowerCase() === \"matrix\" ? \"MATRIX SWOT\" : properties.sTitle}` : properties.title}\n          </div>\n        </GridItem>\n        <ErrorBoundary>\n          <GridItem\n            xs={12}\n            sm={4}\n            md={4}\n            lg={4}\n            xl={4}\n            style={{\n              display: \"flex\",\n              justifyContent: \"flex-start\",\n              alignItems: \"center\",\n              zIndex: \"10 !important\"\n            }}\n            id={\"top_search\"}\n          >\n            <div style={{ position: \"relative\", width: \"calc(100% - 15px)\", zIndex: \"10 !important\" }}>\n              <TextField\n                ref={anchorRef}\n                label={translate('$__search', 1)}\n                variant={customApp('fieldVariant')}\n                name={'name'}\n                InputLabelProps={{\n                  shrink: true,\n                }}\n                InputProps={{\n                  autoComplete: 'new-password',\n                  endAdornment: searchValue !== \"\" ? (\n                    <InputAdornment position=\"end\">\n                      <Icon icon='close' onClick={() => {\n                        setSearchValue(\"\")\n                        // setSearchLoading(false)\n                        setSearchCardsLoading(false)\n                        setSearchFilesLoading(false)\n                      }} />\n                    </InputAdornment>\n                  ) : null,\n                  onChange: (e) => {\n                    setSearchValue(e.target.value)\n                    // setSearchLoading(true)\n                    setSearchCardsLoading(true)\n                    setSearchFilesLoading(true)\n                  }\n                }}\n                value={searchValue}\n                placeholder={translate(\"$__searchInMachen\")}\n              />\n              {searchValue !== \"\" && searchValue.length > 1 &&\n                <ClickAwayListener\n                  onClickAway={() => {\n                    setSearchValue(\"\")\n                    // setSearchLoading(false)\n                    setSearchCardsLoading(false)\n                    setSearchFilesLoading(false)\n                  }}\n                >\n                  <Popper\n                    open={searchValue ? true : false}\n                    anchorEl={anchorRef.current}\n                    role={undefined}\n                    transition\n                    disablePortal\n                    style={{\n                      position: \"absolute\",\n                      zIndex: 10,\n                      bottom: 0,\n                      left: \"5px\",\n                      right: \"5px\",\n                      minWidth: \"500px\",\n\n                    }}\n                  >\n                    {({ TransitionProps, placement }) => (\n                      <Grow\n                        {...TransitionProps}\n                        style={{\n                          transformOrigin: \"center bottom\",\n                          zIndex: \"3\",\n                          maxHeight: \"calc(100vh - 177px)\",\n                          overflowY: \"auto\"\n                        }}\n                      >\n                        <Paper style={{ zIndex: \"3\", boxShadow: \"0 7px 15px rgba(0,0,0,0.33) !important\" }}>\n\n                          <React.Fragment>\n                            <div style={{\n                              display: \"flex\",\n                              borderBottom: \"solid 2px rgba(0,0,0,0.22)\",\n                              backgroundColor: \"#f1f1f1\",\n                              justifyContent: \"space-between\"\n                            }}>\n                              <div\n                                style={{\n                                  backgroundColor: cardsStatusSearch === 'asset' ? \"rgba(0,0,0,0.08)\" : \"\",\n                                  padding: \"0 3px\"\n                                }}\n                              >\n                                <CustomButton\n                                  title={translate(`$__asset`, '*')}\n                                  text={translate(`$__asset`, '*')}\n                                  color={cardsStatusSearch === 'asset' ? customApp('menu') : 'lightGray'}\n                                  icon={\"play_circle_outline\"}\n                                  onClick={() => {\n                                    setCardsStatusSearch('asset')\n                                    setSearchCardsLoading(true)\n                                    setSearchFilesLoading(true)\n                                    setCardsLoader(0)\n                                    setMessagesLoader(0)\n                                    setFilesLoader(0)\n                                  }}\n                                  size={'17px'}\n                                  style={{ padding: \"0px 3px !important\" }}\n                                  transparent\n                                />\n                              </div>\n                              <div\n                                style={{\n                                  backgroundColor: cardsStatusSearch === 'completed' ? \"rgba(0,0,0,0.08)\" : \"\",\n                                  padding: \"0 3px\"\n                                }}\n                              >\n                                <CustomButton\n                                  title={translate(`$__completed`, '*')}\n                                  text={translate(`$__completed`, '*')}\n                                  color={cardsStatusSearch === 'completed' ? customApp('menu') : 'lightGray'}\n                                  icon={\"verified\"}\n                                  onClick={() => {\n                                    setCardsStatusSearch('completed')\n                                    setSearchCardsLoading(true)\n                                    setSearchFilesLoading(true)\n                                    setCardsLoader(0)\n                                    setMessagesLoader(0)\n                                    setFilesLoader(0)\n                                  }}\n                                  size={'17px'}\n                                  style={{ padding: \"0px 3px !important\" }}\n                                  transparent\n                                />\n                              </div>\n                              <div\n                                style={{\n                                  backgroundColor: cardsStatusSearch === 'deleted' ? \"rgba(0,0,0,0.08)\" : \"\",\n                                  padding: \"0 3px\"\n                                }}\n                              >\n                                <CustomButton\n                                  title={translate(`$__deleted`, '*')}\n                                  text={translate(`$__deleted`, '*')}\n                                  color={cardsStatusSearch === 'deleted' ? customApp('menu') : 'lightGray'}\n                                  icon={\"delete_forever\"}\n                                  onClick={() => {\n                                    setCardsStatusSearch('deleted')\n                                    setSearchCardsLoading(true)\n                                    setSearchFilesLoading(true)\n                                    setCardsLoader(0)\n                                    setMessagesLoader(0)\n                                    setFilesLoader(0)\n                                  }}\n                                  size={'17px'}\n                                  style={{ padding: \"0px 3px !important\" }}\n                                  transparent\n                                />\n                              </div>\n                            </div>\n                            {(\n                              String(cardsLoader) === '0'\n                              && String(filesLoader) === '0'\n                              && !searchCardsLoading && !searchFilesLoading\n                            ) ?\n                              <div style={{\n                                textAlign: \"center\",\n                                fontSize: \"16px\",\n                                color: \"red\",\n                                marginTop: 33,\n                                marginBottom: 33\n                              }}>{translate('$__noResultsFound')}</div>\n                              :\n                              <React.Fragment></React.Fragment>\n                            }\n                            {searchValue ?\n                              <React.Fragment>\n                                <ErrorBoundary>\n                                  <SearchCards\n                                    text={searchValue || \"\"}\n                                    onFinish={(n) => {\n                                      setCardsLoader(n)\n                                      setSearchCardsLoading(false)\n                                    }}\n                                    onAction={() => {\n                                      setSearchValue(\"\")\n                                      setSearchCardsLoading(false)\n                                      setCardsLoader(0)\n                                      setMessagesLoader(0)\n                                      setFilesLoader(0)\n                                    }}\n                                    completed={cardsStatusSearch === 'completed' ? true : false}\n                                    deleted={cardsStatusSearch === 'deleted' ? true : false}\n                                    adminView={adminView}\n                                  />\n                                </ErrorBoundary>\n                                <ErrorBoundary>\n                                  <SearchFiles\n                                    text={searchValue || \"\"}\n                                    onFinish={(n) => {\n                                      setFilesLoader(n)\n                                      setSearchFilesLoading(false)\n                                    }}\n                                    onAction={() => {\n                                      setSearchValue(\"\")\n                                      setCardsLoader(0)\n                                      setMessagesLoader(0)\n                                      setFilesLoader(0)\n                                    }}\n                                  />\n                                </ErrorBoundary>\n                              </React.Fragment>\n                              : <React.Fragment></React.Fragment>\n                            }\n                          </React.Fragment>\n                        </Paper>\n                      </Grow>\n                    )\n                    }\n                  </Popper>\n                </ClickAwayListener>\n              }\n            </div>\n          </GridItem >\n        </ErrorBoundary>\n        <GridItem\n          xs={5}\n          sm={4}\n          md={4}\n          lg={4}\n          xl={4}\n          style={{\n            display: \"flex\",\n            justifyContent: \"flex-end\",\n            alignItems: \"center\",\n            zIndex: 2001,\n          }}\n        >\n          <div id=\"top_quickAdd\">\n            <ErrorBoundary>\n              <QuickAdd hashs={hashs} />\n            </ErrorBoundary>\n          </div>\n          <ErrorBoundary>\n            <ChatNotifications />\n          </ErrorBoundary>\n          <div id=\"top_notifications\">\n            <ErrorBoundary>\n              <Notifications loader={props.loaders && props.loaders.notifications ? true : false} />\n            </ErrorBoundary>\n          </div>\n          <div id=\"top_timers\">\n            <ErrorBoundary>\n              <TimersNotifications />\n            </ErrorBoundary>\n          </div>\n          <div id=\"top_requireApproval\">\n            <ErrorBoundary>\n              <MyRequireApproval />\n            </ErrorBoundary>\n          </div>\n          <div id=\"top_myDay\">\n            <ErrorBoundary>\n              <MyDayNotifications />\n            </ErrorBoundary>\n          </div>\n          <div id=\"top_moreOptions\">\n            <Badge\n              overlap=\"rectangular\"\n              badgeContent={reduxStore.getState().controls.unlockedPrivates}\n              color=\"secondary\"\n            >\n              <MoreVert\n                transparent\n                count={50}\n                size={\"27px\"}\n                icon={\"settings\"}\n                title={translate(\"$__settings\")}\n                btColor={\"lightgray\"}\n                options={[\n                  ...AppAccess && AppAccess.user && (\n                    AppAccess.userAdmin\n                    || AppAccess.userModerate\n                  ) ? [\n                    {\n                      name: \"$__users\",\n                      icon: \"account_box\",\n                      onClick: () => {\n                        history.push(\"c#tab/users\")\n                        props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                          ...chat,\n                          open: false,\n                        })\n                      }\n                    },\n                    {\n                      name: \"$__units\",\n                      icon: \"business\",\n                      onClick: () => {\n                        history.push(\"c#tab/units\")\n                        props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                          ...chat,\n                          open: false,\n                        })\n                      }\n                    }] : [],\n                  {\n                    name: \"$__support\",\n                    icon: \"help_outline\",\n                    onClick: () => {\n                      window.open(\"https://support.machen.ai\", \"_blank\")\n                    }\n                  },\n                  session &&\n                  (\n                    (\n                      session._access &&\n                      session._access.master\n                    ) ||\n                    session.isAdmin\n                  )\n                  &&\n                  {\n                    name: \"$__APPSettings\",\n                    icon: \"engineering\",\n                    onClick: () => {\n                      window.open(\"/masterAdmin#tab/languages\", \"_self\")\n                    },\n                    show: \"hover\"\n                  },\n                  session &&\n                  session._id === '701bbca1-e1e4-4ea0-ada8-30f74ae74894'\n                  &&\n                  {\n                    name: \"DEV\",\n                    icon: \"code\",\n                    onClick: () => {\n                      history.push(\"plataformAdministrator\")\n                      props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                        ...chat,\n                        open: false,\n                      })\n                    },\n                    show: \"hover\"\n                  },\n                  ...!reduxStore.getState().controls.hidePrivate ? [\n                    {\n                      name: translate(!reduxStore.getState().controls.lockPrivate ? `$__unlockMyPrivateActivities` : `$__lockMyPrivateActivities`, 1),\n                      icon: !reduxStore.getState().controls.lockPrivate ? `lock_open` : `private_connectivity`,\n                      color: reduxStore.getState().controls.lockPrivate ? 'lightgray' : null,\n                      onClick: () => {\n                        props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\n                          ...reduxStore.getState().controls,\n                          lockPrivate: !reduxStore.getState().controls.lockPrivate,\n                          ...!reduxStore.getState().controls.lockPrivate ? { unlockedPrivates: 0 } : {},\n                        })\n                      },\n                      show: \"hover\"\n                    }] : [],\n                  {\n                    name: translate(!reduxStore.getState().chat.notifications ? `$__chatNotificationsOff` : `$__chatNotificationsActive`, 1),\n                    icon: !reduxStore.getState().chat.notifications ? `notifications_off` : `notifications_active`,\n                    color: !reduxStore.getState().chat.notifications ? 'lightgray' : 'green',\n                    count: reduxStore.getState().controls.unlockedPrivates,\n                    onClick: () => {\n                      props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                        ...chat,\n                        notifications: !reduxStore.getState().chat.notifications,\n                      })\n                    },\n                    show: \"hover\"\n                  },\n                  ...reduxStore.getState().controls.unlockedPrivates > 0 ? [{\n                    name: translate(`$__lockMyPrivateActivities`, 1),\n                    icon: `private_connectivity`,\n                    color: 'red',\n                    count: reduxStore.getState().controls.unlockedPrivates,\n                    onClick: () => {\n                      props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\n                        ...reduxStore.getState().controls,\n                        unlockedPrivates: 0,\n                        lockPrivate: false\n                      })\n                    },\n                    show: \"hover\"\n                  }] : [],\n                  ...reduxStore.getState().session && reduxStore.getState().session._access && reduxStore.getState().session._access[\"masterAdmin\"] > 0 ? [{\n                    name: translate(`$__accountSettings`, 1),\n                    icon: `settings_applications`,\n                    color: 'lightgray',\n                    onClick: () => {\n                      history.push(\"acc#tab/resume\");\n                    },\n                    show: \"hover\"\n                  }] : [],\n\n                ]}\n              />\n            </Badge>\n          </div>\n          <div\n            style={{ marginLeft: \"15px\" }}\n            id={\"top_user\"}\n          >\n            <User />\n          </div>\n        </GridItem>\n      </GridContainer >\n\n    </div >\n  )\n}\n\nconst mapStateToProps = (store) => ({\n  controls: store.controls,\n  chatNotifications: store.chat.notifications\n})\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(SearchComponent))","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst styles = theme => ({\r\n  root: {\r\n    position: 'relative',\r\n    width: '100%',\r\n    cursor: 'pointer',\r\n  },\r\n  user: {\r\n    display: 'flex',\r\n    margin: 'auto',\r\n    height: '37px',\r\n    alignItems: 'center',\r\n  },\r\n  userExtended: {\r\n    display: 'flex',\r\n    height: '37px',\r\n    alignItems: 'center',\r\n  },\r\n  userActive: {\r\n    display: 'inherit',\r\n    height: '37px',\r\n    alignItems: 'center',\r\n    justifyContent: 'center',\r\n    backgroundColor: customApp('color', 0.33),\r\n  },\r\n  userActiveExtended: {\r\n    display: 'inherit',\r\n    height: '37px',\r\n    alignItems: 'center',\r\n    justifyContent: 'center',\r\n    backgroundColor: customApp('color', 0.33),\r\n    justifyContent: 'left',\r\n  },\r\n  name: {\r\n    position: 'absolute',\r\n    top: '5px',\r\n    left: '36px',\r\n    right: '0px',\r\n    height: '30px',\r\n    border: `1px solid ${customApp('color', 0.2)}`,\r\n    backgroundColor: '#FFFFFF',\r\n    borderRadius: '5px',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    paddingLeft: '22px',\r\n    fontWeight: 'bold',\r\n    fontSize: '14px',\r\n    color: customApp('darkText'),\r\n    boxShadow: '-5px 3px 7px 1px rgba(0,0,0,0.05)',\r\n  },\r\n  lastMessage: {\r\n    position: 'absolute',\r\n    top: '30px',\r\n    left: '36px',\r\n    right: '15px',\r\n    height: '30px',\r\n    border: `1px solid ${customApp('color', 0.2)}`,\r\n    backgroundColor: '#FFFFFF',\r\n    borderRadius: '5px',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    paddingLeft: '22px',\r\n    paddingTop: '3px',\r\n    fontSize: '12px',\r\n    color: customApp('medium'),\r\n    boxShadow: '-5px 3px 7px 1px rgba(0,0,0,0.05)',\r\n    textOverflow: 'ellipsis',\r\n    overflow: 'hidden',\r\n    whiteSpace: 'nowrap',\r\n  },\r\n  lastMessageUnReaded: {\r\n    position: 'absolute',\r\n    top: '30px',\r\n    left: '36px',\r\n    right: '15px',\r\n    height: '30px',\r\n    border: `1px solid ${customApp('color', 0.2)}`,\r\n    backgroundColor: '#FFFFFF',\r\n    borderRadius: '5px',\r\n    display: 'flex',\r\n    fontWeight: 'bold',\r\n    alignItems: 'center',\r\n    paddingLeft: '22px',\r\n    paddingTop: '3px',\r\n    fontSize: '12px',\r\n    color: customApp('medium'),\r\n    boxShadow: '-5px 3px 7px 1px rgba(0,0,0,0.05)',\r\n    textOverflow: 'ellipsis',\r\n    overflow: 'hidden',\r\n    whiteSpace: 'nowrap',\r\n  },\r\n  access: {\r\n    position: 'absolute',\r\n    top: '33px',\r\n    left: '45px',\r\n    right: '0px',\r\n    height: '30px',\r\n    border: `1px solid ${customApp('color', 0.2)}`,\r\n    borderRadius: '0 0 5px 5px',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    paddingLeft: '16px',\r\n    fontSize: '14px',\r\n    color: customApp('color'),\r\n    boxShadow: '0px 3px 7px 1px rgba(0,0,0,0.05)'\r\n  },\r\n  accessEditing: {\r\n    position: 'absolute',\r\n    top: '33px',\r\n    left: '45px',\r\n    right: '0px',\r\n    height: 'auto',\r\n    minHeight: '290px',\r\n    padding: '7px',\r\n    border: `1px solid ${customApp('color', 0.2)}`,\r\n    borderRadius: '0 0 5px 5px',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    paddingLeft: '16px',\r\n    fontSize: '14px',\r\n    fontWeight: 'bold',\r\n    color: customApp('color'),\r\n    backgroundColor: '#FFFFFF',\r\n    boxShadow: '0px 3px 7px 1px rgba(0,0,0,0.05)',\r\n    '& ul': {\r\n      fontSize: '12px'\r\n    }\r\n  },\r\n});\r\n\r\nexport default styles;\r\n","//CORE\nimport React from \"react\"\nimport { FixedSizeList, VariableSizeList } from \"react-window\"\nimport AutoSizer from \"react-virtualized-auto-sizer\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport HtmlTooltip from \"components/Tooltip/html\"\nimport UserBadge from \"components/Badge/user\"\n\n//@MATERIAL\nimport Avatar from '@material-ui/core/Avatar'\nimport Badge from '@material-ui/core/Badge'\nimport { withStyles } from \"@material-ui/core/styles\"\n\n\n//STYLES\nimport styles from \"./chatsStyles.js\"\n\n//FUNCTIONS\nimport {\n    getAppAccess,\n    customApp\n} from \"functions/\"\n\nfunction Component(props) {\n    const { classes } = props\n    const { chat, session, timeline, db, usersStatus } = props.store\n    const expanded = props.expanded ? true : false\n\n    let AppAccess = getAppAccess()\n\n    let users = { ...reduxStore.getState().db.users }\n    let chats = {}\n\n    users = Object.keys(users).filter(a => a !== session._id && users[a].type === 'user')\n        .map(a => props.store.users[a])\n        .sort((a, b) => {\n            if (a.name < b.name) {\n                return -1\n            } else if (a.name > b.name) {\n                return 1\n            } else {\n                return 0\n            }\n        })\n\n    users = users.map(us => {\n        us.unReadedCount = 0\n        let myStories = {\n            // ...timeline[session._id] || {}\n        }\n        myStories = Object.keys(myStories).filter(a => myStories[a] && myStories[a].user && myStories[a].user._id === us._id && myStories[a].type === 'comment').map(a => myStories[a])\n\n        let userStories = {\n            ...props.store.users[us._id] && timeline[us._id] ? props.store.users[us._id] && timeline[us._id] : {}\n        }\n        userStories = Object.keys(userStories).filter(a => userStories[a] && userStories[a].type === 'comment').map(a => userStories[a])\n        let stories = [\n            ...myStories,\n            ...userStories\n        ]\n\n        stories = stories.sort((a, b) => {\n            if (Math.ceil(a.created_at) < Math.ceil(b.created_at))\n                return -1\n            return 1\n        }).map(a => a)\n        if (typeof us !== 'boolean') {\n            chats = {\n                ...chats,\n                [us._id]: {\n                    ...props.store.users[us._id],\n                    type: \"user\",\n                    _lastMessage: stories[stories.length - 1] ? stories[stories.length - 1] : null,\n                    unReadedCount: myStories.filter(a => a.type === \"comment\" && !a.deleted && (!a.readedBy || (a.readedBy && !a.readedBy[session._id]))).length\n                }\n            }\n            us._lastMessage = stories[stories.length - 1] ? stories[stories.length - 1] : null\n            us.unReadedCount = myStories.filter(a => a.type === \"comment\" && !a.deleted && (!a.readedBy || (a.readedBy && !a.readedBy[session._id]))).length\n        } else {\n            us._lastMessage = null\n            us.unReadedCount = 0\n        }\n        return us\n    })\n\n    let groups = Object.keys(reduxStore.getState().db.cards)\n        .filter(a =>\n            reduxStore.getState().db.cards[a].type === 'chatGroup'\n            && !reduxStore.getState().db.cards[a].deleted\n            && (\n                (\n                    reduxStore.getState().db.cards[a]._users\n                    && reduxStore.getState().db.cards[a]._users[session._id]\n                )\n                ||\n                (\n                    !reduxStore.getState().db.cards[a].private\n                    && props.store.adminView\n                    && AppAccess\n                    && (\n                        AppAccess.owner\n                        || AppAccess.admin\n                    )\n                )\n            )\n        )\n        .map(a => reduxStore.getState().db.cards[a])\n\n\n\n    if (groups && groups.length > 0)\n        groups\n            .filter(fil => {\n                if (\n                    fil._users\n                    && fil._users[session._id]\n                )\n                    return true\n            }\n            )\n            .map(gr => {\n                let lastMessage\n                if (timeline[gr._id] && Object.keys(timeline[gr._id]).length > 0)\n                    lastMessage = Object.keys(timeline[gr._id])\n                        .filter(tm => timeline[gr._id]\n                            && timeline[gr._id][tm]\n                            && timeline[gr._id][tm].type === 'comment'\n                        )\n                        .sort((a, b) => {\n                            if (timeline[gr._id][a]\n                                && timeline[gr._id][b]\n                                && String(timeline[gr._id][a].created_at)\n                                && String(timeline[gr._id][b].created_at)\n                                && parseInt(timeline[gr._id][a].created_at) > parseInt(timeline[gr._id][b].created_at)) {\n                                return -1\n                            } else if (timeline[gr._id][a]\n                                && timeline[gr._id][b]\n                                && String(timeline[gr._id][a].created_at)\n                                && String(timeline[gr._id][b].created_at)\n                                && parseInt(timeline[gr._id][a].created_at) < parseInt(timeline[gr._id][b].created_at)) {\n                                return 1\n                            } else {\n                                return 0\n                            }\n                        }\n                        )\n                if (gr\n                    && gr._id\n                    && lastMessage\n                    && lastMessage.length > 0\n                    && timeline[gr._id]\n                    && timeline[gr._id][lastMessage[0]]\n                    && timeline[gr._id][lastMessage[0]].created_at\n                ) {\n                    chats = {\n                        ...chats,\n                        [gr._id]: {\n                            ...reduxStore.getState().db.cards[gr._id],\n                            type: \"group\",\n                            _lastMessage: timeline[gr._id][lastMessage[0]],\n                        }\n                    }\n                } else {\n                    chats = {\n                        ...chats,\n                        [gr._id]: {\n                            ...reduxStore.getState().db.cards[gr._id],\n                            type: \"group\",\n                        }\n                    }\n                }\n            })\n\n    const listChats = Object.keys(chats).filter(ch =>\n        (!reduxStore.getState().db.cards[ch]\n            ||\n            (\n                reduxStore.getState().db.cards[ch]\n                && !reduxStore.getState().db.cards[ch].deleted\n            )\n        ) &&\n        (\n            (!props.find || props.find === '')\n            || (\n                props.find\n                && (\n                    chats[ch].name.toLowerCase().indexOf(props.find.toLowerCase()) > -1\n                    ||\n                    (\n                        chats[ch]._parent\n                        && reduxStore.getState().db.users[chats[ch]._parent]\n                        && reduxStore.getState().db.users[chats[ch]._parent].name\n                        && reduxStore.getState().db.users[chats[ch]._parent].name.toLowerCase().indexOf(props.find.toLowerCase()) > -1\n                    )\n                )\n            )\n        )\n        &&\n        (\n            expanded\n            ||\n            (\n                !expanded\n                && chats[ch]\n                && chats[ch]._lastMessage\n            )\n        )\n        &&\n        (\n            !props.onLine\n            || (\n                props.onLine\n                && usersStatus.users && usersStatus.users[ch]\n            )\n        )\n    ).sort((a, b) => {\n        let lastMessageA = chats[a]._lastMessage && String(chats[a]._lastMessage.created_at) ? Math.ceil(chats[a]._lastMessage.created_at) : 0\n        let lastMessageB = chats[b]._lastMessage && String(chats[b]._lastMessage.created_at) ? Math.ceil(chats[b]._lastMessage.created_at) : 0\n        if (!expanded) {\n            if (lastMessageA > lastMessageB) {\n                return -1\n            } else if (lastMessageA < lastMessageB) {\n                return 1\n            } else {\n                return 0\n            }\n        } else {\n            if (chats[a].name.toLowerCase() < chats[b].name.toLowerCase())\n                return -1\n            if (chats[a].name.toLowerCase() > chats[b].name.toLowerCase())\n                return 1\n            return 0\n        }\n    }).map((ch, i) => {\n        let u = chats[ch]\n        let countMessages = 0\n        if (timeline[u._id])\n            countMessages = countMessages + Object.keys(timeline[u._id]).filter(a =>\n                timeline[u._id]\n                && timeline[u._id][a]\n                && !timeline[u._id][a].deleted\n                && timeline[u._id][a].user\n                && timeline[u._id][a].user._id\n                && session\n                && session._id\n                && timeline[u._id][a].user._id !== session._id\n                && timeline[u._id][a].type === \"comment\"\n                &&\n                (\n                    !timeline[u._id][a].readedBy\n                    || !timeline[u._id][a].readedBy[session._id]\n                )\n            ).length\n\n        if (timeline[session._id])\n            countMessages = countMessages + Object.keys(timeline[session._id]).filter(a =>\n                timeline[session._id] &&\n                timeline[session._id][a] &&\n                !timeline[session._id][a].deleted &&\n                timeline[session._id][a].user &&\n                timeline[session._id][a].user._id === u._id\n                && timeline[session._id][a].type === \"comment\"\n                &&\n                (\n                    !timeline[session._id][a].readedBy\n                    || !timeline[session._id][a].readedBy[session._id]\n                )\n            ).length\n        return ({\n            _id: ch,\n            name: u.name,\n            image: u.image || null,\n            countMessages,\n            lastMessage: u.lastMessage || null,\n            deleted: u.deleted || false,\n            _parent: u._parent || null,\n        })\n    })\n\n    const Row = ({ index, style }) => {\n        let u = listChats[index]\n        return (\n            <div style={style}>\n                <div\n                    className={chat && chat.nodeId === u._id ? expanded ? classes.userActiveExtended : classes.userActive : expanded ? classes.userExtended : classes.user}\n                    style={{\n                        height: 55,\n                        display: \"flex\",\n                        justifyContent: \"center\",\n                        alignItems: \"center\",\n                        margin: \"auto\",\n                        cursor: \"pointer\",\n                        ...chat && chat.nodeId === u._id ? {\n                            backgroundColor: \"rgba(250,250,250,0.1)\"\n                        } : {}\n                    }}\n                    onClick={() => {\n                        props.openChat(u._id)\n                    }}\n                >\n                    <HtmlTooltip\n                        title={(\n                            <React.Fragment>\n                                {u.name\n                                    ? u.name\n                                    : u.name\n                                        ? u.name.split(' ').lenth > 0 ? u.name.split(' ')[0]\n                                            : ''\n                                        : ''\n                                }\n                                {!u.name && u.name\n                                    ? u.name.split(' ').lenth > 0 ? u.name.split(' ')[0]\n                                        : ''\n                                    : ''\n                                }\n                            </React.Fragment>\n                        )\n                        } >\n                        <div style={{ width: \"100%\" }}>\n                            {!expanded ?\n                                <Badge\n                                    overlap=\"rectangular\"\n                                    badgeContent={u.countMessages}\n                                    color=\"secondary\"\n                                    style={{\n                                        display: 'flex',\n                                        alignItems: 'center',\n                                        padding: 0,\n                                        width: \"80%\",\n                                        marginTop: \"16px\",\n                                    }}\n                                >\n                                    <UserBadge\n                                        overlap=\"circular\"\n                                        anchorOrigin={{\n                                            vertical: 'bottom',\n                                            horizontal: 'right',\n                                        }}\n                                        userId={u._id}\n                                    >\n                                        <React.Fragment>\n                                            <div\n                                                style={{\n                                                    width: 33,\n                                                    height: 33,\n                                                    marginTop: \"-10px\",\n                                                    ...u.deleted ? { border: \"solid 2px red\" } : {},\n                                                    borderRadius: \"50%\",\n                                                    backgroundColor: u.image ? \"none\" : \"lightgray\",\n                                                    backgroundImage: `url(\"${u.image}\")`,\n                                                    backgroundSize: \"cover\",\n                                                    backgroundRepeat: \"no-repeat\",\n                                                    backgroundPosition: \"center center\",\n                                                    display: \"flex\",\n                                                    justifyContent: \"center\",\n                                                    alignItems: \"center\",\n                                                }}\n                                            ><span style={{\n                                                color: customApp(\"menu\"),\n                                                fontWeight: \"bold\",\n                                                letterSpacing: \"-2px !important\"\n                                            }}>{!u.image ? `${u.name.substr(0, 1).toUpperCase()}${u.name.split(\" \").length > 1 ? ` ${u.name.split(\" \")[1].substr(0, 1).toUpperCase()}` : ``}` : ``}</span>\n                                            </div>\n                                            {u._parent &&\n                                                props.store.users[u._parent] &&\n                                                props.store.users[u._parent].image ?\n                                                <div\n                                                    style={{\n                                                        position: \"absolute\",\n                                                        bottom: 4,\n                                                        right: -7,\n                                                        width: 15,\n                                                        height: 15,\n                                                        borderRadius: \"50%\",\n                                                        backgroundImage: `url(${props.store.users[u._parent].image})`,\n                                                        backgroundSize: \"cover\",\n                                                        backgroundRepeat: \"no-repeat\"\n                                                    }}></div>\n                                                : <React.Fragment></React.Fragment>}\n                                        </React.Fragment>\n                                    </UserBadge>\n                                </Badge>\n                                :\n                                <div\n                                    style={{\n                                        display: 'flex',\n                                        width: '100%',\n                                        justifyContent: 'left',\n                                        alignItems: 'center',\n                                        marginTop: \"10px\"\n                                    }\n                                    }>\n                                    <Badge\n                                        overlap=\"rectangular\"\n                                        badgeContent={u.countMessages}\n                                        color=\"secondary\"\n                                        style={{\n                                            width: '37px',\n                                            display: 'flex',\n                                            alignItems: 'center',\n                                            // marginTop: '-10px',\n                                        }}\n                                    >\n                                        <UserBadge\n                                            overlap=\"circular\"\n                                            anchorOrigin={{\n                                                vertical: 'bottom',\n                                                horizontal: 'right',\n                                            }}\n                                            userId={u._id}\n                                        >\n                                            <React.Fragment>\n                                                <Avatar alt={u.displayName ? u.displayName : u.name} src={`${u.image}`}\n                                                    style={{\n                                                        width: '29px',\n                                                        height: '29px',\n                                                        marginTop: '-10px',\n                                                    }} />\n                                                {u._parent &&\n                                                    props.store.users[u._parent] &&\n                                                    props.store.users[u._parent].image ?\n                                                    <div\n                                                        style={{\n                                                            position: \"absolute\",\n                                                            bottom: 4,\n                                                            right: -7,\n                                                            width: 15,\n                                                            height: 15,\n                                                            borderRadius: \"50%\",\n                                                            backgroundImage: `url(${props.store.users[u._parent].image})`,\n                                                            backgroundSize: \"cover\",\n                                                            backgroundRepeat: \"no-repeat\"\n                                                        }}></div>\n                                                    : <React.Fragment></React.Fragment>}\n                                            </React.Fragment>\n                                        </UserBadge>\n                                    </Badge>\n                                    <div\n                                        style={{\n                                            fontSize: '14px',\n                                            maxWidth: \"calc(100% - 30px)\",\n                                            paddingLeft: \"7px\",\n                                            color: 'gray',\n                                            whiteSpace: \"nowrap\",\n                                            textOverflow: \"ellipsis\",\n                                            overflow: \"hidden\"\n                                        }}>\n                                        {u.name\n                                            ? u.name\n                                            : u.name\n                                                ? u.name.split(' ').lenth > 0 ? u.name.split(' ')[0]\n                                                    : ''\n                                                : ''\n                                        }\n                                        {!u.name && u.name\n                                            ? u.name.split(' ').lenth > 0 ? u.name.split(' ')[0]\n                                                : ''\n                                            : ''}\n                                        {u._parent && props.store.users[u._parent] ?\n                                            <div\n                                                style={{\n                                                    fontSize: 10,\n                                                    color: \"lightgray\",\n                                                    marginTop: \"-7px\",\n                                                }}>{props.store.users[u._parent].name}</div>\n                                            : <React.Fragment></React.Fragment>}\n                                    </div>\n                                </div>\n                            }\n                        </div>\n                    </HtmlTooltip>\n                </div>\n            </div>\n        )\n    }\n\n    return (\n        <AutoSizer\n            style={{\n                width: \"100%\",\n                height: \"100%\"\n            }}\n        >\n            {({ height, width }) => (\n                <FixedSizeList\n                    height={height}\n                    itemCount={listChats.length}\n                    itemSize={55}\n                    width={expanded ? 295 : 58}\n                    itemData={listChats}\n                    style={{\n                        height: \"100%\",\n                    }}\n                >\n                    {Row}\n                </FixedSizeList>\n            )}\n        </AutoSizer>\n    )\n}\nconst mapStateToProps = (store, props) => ({\n    store: {\n        chat: store.chat,\n        timeline: store.timeline,\n        cards: store.db.cards,\n        users: store.db.users,\n        adminView: store.db.adminView,\n        session: store.session,\n        usersStatus: store.usersStatus\n    }\n})\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","import {\r\n  defaultFont,\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst styles = (theme) => ({\r\n  ...defaultFont,\r\n  menu: {\r\n    position: \"absolute\",\r\n    borderRight: customApp(\"color\"),\r\n    background: customApp('ColumnTitleColor'),\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    overflowY: \"auto\",\r\n    overflowX: \"hidden\",\r\n    display: \"flex\",\r\n    flexDirection: \"column\",\r\n    alignItems: \"center\",\r\n    // boxShadow: \"inset 4px 0px 3px 0px rgb(0 0 0 / 17%)\",\r\n  },\r\n  menuExpanded: {\r\n    position: \"absolute\",\r\n    borderRight: customApp(\"color\"),\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    overflowY: \"auto\",\r\n    overflowX: \"hidden\",\r\n    display: \"flex\",\r\n    flexDirection: \"column\",\r\n    alignItems: \"baseline\",\r\n    paddingLeft: \"15px\",\r\n    paddingRight: \"15px\",\r\n    boxShadow: \"inset 4px 0px 3px 0px rgb(0 0 0 / 17%)\",\r\n  },\r\n  button: {\r\n    padding: \"7px 0px\",\r\n    display: \"flex\",\r\n    justifyContent: \"center\"\r\n  },\r\n  buttonColor: {\r\n    // position: \"relative\",\r\n    // float: \"left\",\r\n    padding: \"12px\",\r\n    display: \"flex\",\r\n    justifyContent: \"center\",\r\n    backgroundColor: customApp(\"color\"),\r\n    alignItems: \"center\",\r\n    width: \"-webkit-fill-available\"\r\n  },\r\n  buttonColorExpanded: {\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    padding: \"12px\",\r\n    display: \"flex\",\r\n    backgroundColor: customApp(\"color\"),\r\n    alignItems: \"center\",\r\n    width: \"100%\"\r\n  },\r\n  separator: {\r\n    position: \"relative\",\r\n    float: \"left\",\r\n    width: \"100%\",\r\n    padding: \"7px\",\r\n    borderTop: `1px solid ${customApp(\"medium\", 0.5)}`,\r\n    marginTop: \"15px\",\r\n    marginBottom: \"0px\",\r\n    height: \"1px\"\r\n  }\r\n});\r\n\r\nexport default styles;\r\n","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport Chats from \"components/Chat/chats\"\nimport CustomButton from \"components/Buttons/custom\"\nimport Icon from \"components/Icon\"\nimport IconButton from \"components/CustomButtons/IconButton\"\nimport TextField from \"components/TextField/\"\n\n//@MATERIAL\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\nimport { makeStyles } from \"@material-ui/core/styles\"\n\n//FUNCTIONS\nimport {\n    translate,\n    customApp,\n    getAppAccess\n} from \"functions/\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/chatMenu2204\"\n\nfunction Component(props) {\n    const { chat, session } = reduxStore.getState()\n    const [chatList, setChatList] = React.useState('chats')\n    const [usersStatus, setUsersStatus] = React.useState(props.usersStatus)\n    const [findName, setFindName] = React.useState(\"\")\n    const [expanded, setExpanded] = React.useState(false)\n    // const [onLine, setOnLine] = React.useState(props.onLine)\n    const useStyles = makeStyles(styles)\n    const classes = useStyles()\n\n    let hashs = window.location.hash.split(\"/\")\n    hashs[0] = hashs[0].replace(\"#\", \"\")\n\n    React.useEffect(() => {\n        setChatList('chats')\n        setExpanded(props.expanded)\n    }, [props.expanded])\n\n    // React.useEffect(() => {\n    //     setOnLine(props.onLine)\n    // }, [props.onLine])\n\n    let AppAccess = getAppAccess()\n\n    const openChat = async (nodeId, db) => {\n        let chatDb = reduxStore.getState().db.cards[nodeId] ? 'cards' : 'users'\n        setFindName(\"\")\n        if (reduxStore.getState().db[chatDb] && reduxStore.getState().db[chatDb][nodeId] && !reduxStore.getState().db[chatDb][nodeId]._loadTimeline) {\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...chat,\n                db: db,\n                nodeId: nodeId,\n                loading: db === 'users' ? false : true,\n            })\n        } else {\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...chat,\n                db: db,\n                nodeId: nodeId,\n                loading: false,\n            })\n        }\n        props.subMenuExpanded(false)\n        setChatList('chats')\n    }\n\n    return (\n        <React.Fragment>\n\n            <div className={expanded ? classes.menuExpanded : classes.menu} style={{ paddingTop: 5 }}>\n                {\n                    (\n                        expanded &&\n                        (\n                            chatList === \"internalGroups\"\n                            || chatList === \"externalGroups\"\n                        )\n                    )\n                    &&\n                    <div className={expanded ? classes.buttonColorExpanded : classes.buttonColor} style={{ marginTop: \"-15px\" }}>\n                        <IconButton\n                            text={expanded ? translate(\"$__newGroup\", \"*\") : null}\n                            title={!expanded ? translate(\"$__newGroup\", \"*\") : null}\n                            icon=\"add_box\"\n                            iconColor={\"#FFFFFF\"}\n                            textColor={\"#FFFFFF\"}\n                            onClick={() => {\n                                props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                    ...reduxStore.getState().sideModule,\n                                    id: \"new\",\n                                    activeModule: \"cardEdit\",\n                                    db: \"cards\",\n                                    data: {\n                                        type: \"chatGroup\",\n                                        status: \"inProgress\",\n                                    }\n                                })\n                            }}\n                        />\n                    </div>\n                }\n                <div className={classes.button} style={{\n                    display: \"flex\",\n                    height: \"46px\",\n                    marginBottom: \"7px\",\n                    width: \"100%\"\n                }}>\n                    {expanded ?\n                        <div className={classes.textField} style={{ width: \"100%\" }}>\n                            <TextField\n                                className={classes.noLabelLight}\n                                label={translate(\"$__search\", \"*\")}\n                                variant={\"standard\"}\n                                autoFocus\n                                value={findName}\n                                InputProps={{\n                                    endAdornment: (\n                                        <InputAdornment position=\"start\">\n                                            <Icon color={customApp(\"colorText\")}>search</Icon>\n                                        </InputAdornment>\n                                    ),\n                                    onChange: e => {\n                                        setFindName(e.target.value)\n                                    },\n                                }}\n                            />\n                        </div>\n                        :\n                        <IconButton\n                            title={!expanded ? translate(\"$__search\", \"*\") : null}\n                            icon=\"search\"\n                            iconColor={findName !== \"\" ? customApp(\"colorText\") : customApp(\"colorText\")}\n                            textColor={findName !== \"\" ? customApp(\"colorText\") : customApp(\"colorText\")}\n                            onClick={() => {\n                                props.subMenuExpanded(true)\n                            }}\n                        />\n                    }\n                </div>\n                <div\n                    style={{\n                        position: \"absolute\",\n                        top: !expanded ? 40 : 50,\n                        bottom: 7,\n                        overflowY: \"auto\",\n                        overflowX: \"hidden\",\n                        left: expanded ? 7 : 0,\n                        paddingLeft: expanded ? 5 : 0,\n                        right: 0,\n                        paddingTop: 7\n                    }}\n                >\n                    <Chats\n                        expanded={expanded}\n                        openChat={(nodeId) => openChat(nodeId, \"cards\")}\n                        find={findName}\n                        onLine={props.onLine}\n                    />\n                </div>\n\n            </div>\n        </React.Fragment >\n    )\n}\n\nconst mapStateToProps = () => ({})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\n\n//FUNCTIONS\nimport { translate } from \"functions/\"\n\nfunction Component(props) {\n    const { session } = reduxStore.getState()\n    const [typing, setTyping] = React.useState({})\n    React.useEffect(() => {\n        setTyping(props.typing)\n    }, [props.typing])\n\n    return (\n        typing &&\n            (\n                (\n                    props.nodeId &&\n                    props.nodeId !== session._id &&\n                    typing['me'] &&\n                    typing['me'][props.nodeId]\n                )\n            ) ?\n            <div style={{ marginLeft: 15, fontSite: 12, color: 'lightgray', fontWeight: \"normal\" }}>\n                {translate(`$__typing`)}...\n            </div>\n            : props.nodeId &&\n                typing &&\n                (\n                    (\n                        typing[props.nodeId] &&\n                        Object.keys(typing[props.nodeId]).filter(us => session && session._id && us !== session._id && typing[props.nodeId][us]).length > 0\n                    )\n                ) ?\n                <div style={{ marginLeft: 15, fontSite: 12, color: 'lightgray', fontWeight: \"normal\", display: \"flex\", alignItems: \"center\" }}>\n                    {Object.keys(typing[props.nodeId]).filter(us => us !== session._id && typing[props.nodeId][us])\n                        .map((a, i) => {\n                            let name = ``\n                            if (reduxStore.getState().db.cards[props.nodeId]._users[a].name) {\n                                name = reduxStore.getState().db.cards[props.nodeId]._users[a].name\n                            } else if (reduxStore.getState().db.cards[props.nodeId]._users[a].name) {\n                                let splitName = reduxStore.getState().db.cards[props.nodeId]._users[a].name.split(' ')\n                                name = `${splitName[0]}${splitName.length > 1 ? ` ${splitName[splitName.length - 1]}` : ``}`\n                            }\n                            return (<Tooltip\n                                title={name}\n                                key={a}\n                            >\n                                <Avatar style={{\n                                    width: 22,\n                                    height: 22,\n                                    border: 'none'\n                                }} alt={name} src={reduxStore.getState().db.cards[props.nodeId]._users[a].image || null} >\n                                    {name.substr(0, 1)}\n                                </Avatar>\n                            </Tooltip>)\n                        })\n                    }\n                    <span style={{ marginLeft: 7 }}>{translate(`$__typing`)}...</span>\n                </div>\n                : <React.Fragment></React.Fragment>\n    )\n}\nconst mapStateToProps = store => ({\n    // typing: store.chat.typing\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(Component)","import {\r\n  defaultFont,\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst styles = (theme) => ({\r\n  ...defaultFont,\r\n  menu: {\r\n    position: 'relative',\r\n    borderRight: customApp('color'),\r\n  },\r\n  menuExpanded: {\r\n    position: 'relative',\r\n    borderRight: customApp('color'),\r\n  },\r\n  button: {\r\n    position: 'relative', float: 'left', width: '100%', padding: '7px'\r\n  },\r\n  avatarGroup: {\r\n    \"& .MuiAvatar-root\": {\r\n      width: \"22px !important\",\r\n      height: \"22px !important\"\r\n    }\r\n  },\r\n  buttonColor: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: 'calc(100% + 20px)',\r\n    padding: '20px 12px',\r\n    marginLeft: '-12px',\r\n    display: \"flex\",\r\n    justifyContent: \"center\",\r\n    backgroundColor: customApp('color')\r\n  },\r\n  buttonColorExpanded: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: 'calc(100% + 20px)',\r\n    padding: '20px',\r\n    marginLeft: '-12px',\r\n    display: \"flex\",\r\n    backgroundColor: customApp('color')\r\n  },\r\n  separator: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    padding: '7px',\r\n    borderTop: `1px solid ${customApp('medium', 0.5)}`,\r\n    marginTop: '15px',\r\n    marginBottom: '0px',\r\n    height: '1px'\r\n  }\r\n});\r\n\r\nexport default styles;\r\n","//CORE\r\nimport React from \"react\"\r\n\r\n//REDUX\r\nimport { connect } from \"react-redux\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\n\r\n//COMPONENTS\r\nimport CustomButton from \"components/Buttons/custom\"\r\n\r\n//FUNCTIONS\r\nimport { translate, customApp } from \"functions/\"\r\n\r\nfunction ButtonViewOnline(props) {\r\n    const { session } = reduxStore.getState()\r\n    const [usersStatus, setUsersStatus] = React.useState(props.usersStatus)\r\n    const [onLine, setOnLine] = React.useState(false)\r\n\r\n    React.useEffect(() => {\r\n        setUsersStatus(props.usersStatus)\r\n        return () => {\r\n\r\n        }\r\n    }, [props.usersStatus])\r\n\r\n    return (\r\n        <React.Fragment>\r\n            <CustomButton\r\n                id={`chat_menu`}\r\n                title={`${translate(`$__showOnlyOnline`, \"*\")} ${Object.keys(usersStatus.users).filter(u => usersStatus.users[u] && u !== session._id).length > 0 ? ` (${Object.keys(usersStatus.users).filter(u => usersStatus.users[u] && u !== session._id).length})` : ``}`}\r\n                text={`${translate(`$__showOnlyOnline`, \"*\")} ${Object.keys(usersStatus.users).filter(u => usersStatus.users[u] && u !== session._id).length > 0 ? ` (${Object.keys(usersStatus.users).filter(u => usersStatus.users[u] && u !== session._id).length})` : ``}`}\r\n                color={customApp(\"colorText\")}\r\n                icon={onLine ? \"toggle_on\" : \"toggle_off\"}\r\n                onClick={() => {\r\n                    setOnLine(a => !a)\r\n                    if (props.onClick)\r\n                        props.onClick(!onLine)\r\n                }}\r\n                size={\"25px\"}\r\n                textSize={\"11px\"}\r\n                transparent\r\n            />\r\n        </React.Fragment>\r\n    )\r\n}\r\nconst mapStateToProps = (store) => {\r\n    return ({\r\n        usersStatus: store.usersStatus && store.usersStatus ? store.usersStatus : {},\r\n    })\r\n}\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(ButtonViewOnline)","//CORE\nimport React from \"react\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\n\n//COMPONENTS\nimport CustomButton from \"components/Buttons/custom\"\nimport Files from \"components/Files/list\"\nimport Menu from \"./menu\"\nimport Timeline from \"components/Timeline\"\nimport Typing from \"./Typing\"\nimport UserBadge from \"components/Badge/user\"\n\n\n//@MATERIAL\nimport { withStyles } from \"@material-ui/core/styles\"\nimport ClickAwayListener from \"@material-ui/core/ClickAwayListener\"\nimport Avatar from \"@material-ui/core/Avatar\"\nimport AvatarGroup from \"@material-ui/lab/AvatarGroup\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\n\n//FUNCTIONS\nimport {\n    customApp,\n    getAppAccess,\n    getDate,\n    translate,\n} from \"functions/\"\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/chat.js\"\nimport ButtonViewOnline from \"./ButtonViewOnline\"\n\nfunction Component(props) {\n    const { classes } = props\n    const [chat, setChat] = React.useState(null)\n    const [expanded, setExpanded] = React.useState(false)\n    const [showFiles, setShowFiles] = React.useState(false)\n    const [onLine, setOnLine] = React.useState(false)\n\n\n    const AppAccess = getAppAccess()\n\n    React.useEffect(() => {\n        let isSubscribed = true\n        if (isSubscribed && JSON.stringify(props.chat) !== JSON.stringify(chat)) {\n            setChat(props.chat)\n        }\n        return () => {\n            isSubscribed = false\n        }\n    }, [props.chat])\n\n    if (!chat)\n        return (<React.Fragment></React.Fragment>)\n\n    const closeChat = (force = false) => {\n        if (force || !(reduxStore.getState() &&\n            (\n                (\n                    reduxStore.getState().lightBox &&\n                    reduxStore.getState().lightBox.open\n                )\n                || (\n                    reduxStore.getState().sideModule &&\n                    reduxStore.getState().sideModule.id\n                )\n            )\n        )) {\n            let toastFy = document.getElementsByClassName('Toastify__toast').length\n            let forward = document.getElementsByClassName('forwardMessage').length\n            console.log(forward)\n            if (toastFy === 0 && forward === 0)\n                props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                    ...chat,\n                    open: false\n                })\n        }\n    }\n\n    if (chat && !chat.open)\n        return (<React.Fragment></React.Fragment>)\n\n    const chatDb = chat && chat.nodeId && reduxStore.getState().db.cards && reduxStore.getState().db.cards[chat.nodeId] ? 'cards' : 'users'\n    let chatData = reduxStore.getState().db[chatDb][chat.nodeId] ? reduxStore.getState().db[chatDb][chat.nodeId] : null\n\n    return (\n        <div\n            style={{\n                position: \"fixed\",\n                top: 0,\n                left: 0,\n                right: 0,\n                bottom: 0,\n                zIndex: 3000,\n                backgroundColor: \"rgba(250,250,250,0.7)\",\n                backdropFilter: \"blur(3px)\",\n            }}\n        >\n            <ClickAwayListener\n                onClickAway={() => {\n                    closeChat()\n                }}\n            >\n                <div\n                    style={{\n                        position: \"fixed\",\n                        ...window.innerWidth > 600 ? {\n                            top: 77,\n                            left: 77,\n                            right: 77,\n                            bottom: 77,\n                        } : {\n                            top: 50,\n                            left: 7,\n                            right: 7,\n                            bottom: 7,\n                        },\n                        ...window.innerWidth > 600 ? {\n                            zIndex: 3,\n                        } : {\n                            zIndex: 6000,\n                        },\n                        boxShadow: \"0px 0px 10px 3px rgba(0,0,0,0.2)\",\n                        borderRadius: \"15px\",\n                        overflow: 'hidden'\n                    }}\n                >\n                    <React.Fragment>\n                        <div style={{\n                            position: \"absolute\",\n                            top: 0,\n                            left: 0,\n                            right: 0,\n                            height: 40,\n                            background: customApp('ColumnTitleColor'),\n                            display: \"flex\",\n                            alignItems: \"center\",\n                        }}>\n                            <div style={{\n                                position: \"absolute\",\n                                left: 13\n                            }}>\n                                <CustomButton\n                                    id={`chat_menu`}\n                                    title={translate(`$__menu`, \"*\")}\n                                    color={customApp(\"colorText\")}\n                                    icon={\"menu\"}\n                                    onClick={() => {\n                                        setExpanded(a => !a)\n                                        if (expanded)\n                                            setOnLine(false)\n                                    }}\n                                    size={\"25px\"}\n                                    transparent\n                                />\n                            </div>\n                            {expanded ?\n                                <div style={{\n                                    position: \"absolute\",\n                                    left: 45,\n                                    color: customApp(\"colorText\")\n                                }}>\n                                    <CustomButton\n                                        id={`addGroup`}\n                                        title={translate(`$__createChatGroup`, \"*\")}\n                                        icon={\"add_circle_outline\"}\n                                        onClick={() => {\n                                            closeChat(true)\n                                            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                ...reduxStore.getState().sideModule,\n                                                id: \"new\",\n                                                activeModule: \"cardEdit\",\n                                                db: \"cards\",\n                                                data: {\n                                                    type: \"chatGroup\",\n                                                    status: \"inProgress\",\n                                                }\n                                            })\n                                        }}\n                                        size={\"25px\"}\n                                        transparent\n                                        color={customApp(\"colorText\")}\n                                    />\n                                </div>\n                                : <React.Fragment></React.Fragment>\n                            }\n                            {expanded ?\n                                <div style={{\n                                    position: \"absolute\",\n                                    left: 80\n                                }}>\n                                    <ButtonViewOnline\n                                        onClick={(e) => {\n                                            setOnLine(e)\n                                        }}\n                                    />\n                                </div>\n                                : <React.Fragment></React.Fragment>\n                            }\n                            <div style={{\n                                position: \"absolute\",\n                                left: !expanded ? 53 : 320,\n                                right: 80,\n                                color: customApp('colorText'),\n                                fontSize: \"12px\",\n                                fontWeight: \"bold\"\n                            }}>\n\n                                {chat && chat.nodeId && chatData ?\n                                    <div style={{\n                                        display: \"flex\",\n                                        alignItems: \"center\"\n                                    }}>\n                                        <UserBadge\n                                            overlap=\"circular\"\n                                            anchorOrigin={{\n                                                vertical: \"bottom\",\n                                                horizontal: \"right\",\n                                            }}\n                                            userId={chat.nodeId}\n                                        >\n                                            <Avatar\n                                                alt={chatData.displayName ? chatData.displayName : chatData.name}\n                                                src={chatData.image ? `${chatData.image}` : null}\n                                                style={{\n                                                    width: \"30px\",\n                                                    height: \"30px\"\n                                                }} />\n                                        </UserBadge>\n                                        <div\n                                            style={{ fontSize: \"14px\" }}\n                                        >\n                                            {chatData.name} <span style={{ fontSize: 10, fontWeight: \"normal\" }}>{reduxStore.getState().usersStatus && reduxStore.getState().usersStatus.users && reduxStore.getState().usersStatus.users[chat.nodeId] && reduxStore.getState().usersStatus.users[chat.nodeId].status === \"away\" && reduxStore.getState().usersStatus.users[chat.nodeId].updatedAt ? `(${translate(\"$__lastSeeTime\")}: ${getDate(reduxStore.getState().usersStatus.users[chat.nodeId].updatedAt)})` : ``}</span>\n                                        </div>\n                                        {\n                                            chat &&\n                                            chat.nodeId &&\n                                            reduxStore.getState().db.cards[chat.nodeId] &&\n                                            reduxStore.getState().db.cards[chat.nodeId].type === 'chatGroup' &&\n                                            reduxStore.getState().db.cards[chat.nodeId]._users &&\n                                            Object.keys(reduxStore.getState().db.cards[chat.nodeId]._users).length > 0 &&\n                                            <div\n                                                classes={classes.avatarGroup}\n                                                style={{\n                                                    marginLeft: 15\n                                                }}>\n                                                <AvatarGroup\n                                                    max={150}\n                                                >\n                                                    {Object.keys(reduxStore.getState().db.cards[chat.nodeId]._users).length > 0\n                                                        && Object.keys(reduxStore.getState().db.cards[chat.nodeId]._users).map((a, i) => {\n                                                            let name = ``\n                                                            if (reduxStore.getState().db.cards[chat.nodeId]._users[a].name) {\n                                                                name = reduxStore.getState().db.cards[chat.nodeId]._users[a].name\n                                                            } else if (reduxStore.getState().db.cards[chat.nodeId]._users[a].name) {\n                                                                let splitName = reduxStore.getState().db.cards[chat.nodeId]._users[a].name.split(' ')\n                                                                name = `${splitName[0]}${splitName.length > 1 ? ` ${splitName[splitName.length - 1]}` : ``}`\n                                                            }\n                                                            if (i < 17) {\n                                                                return (\n                                                                    <Tooltip\n                                                                        title={name}\n                                                                        key={i}\n                                                                    >\n                                                                        <Avatar style={{\n                                                                            width: 22,\n                                                                            height: 22,\n                                                                            border: 'none'\n                                                                        }} alt={name} src={reduxStore.getState().db.cards[chat.nodeId]._users[a].image || null} >\n                                                                            {name.substr(0, 1)}\n                                                                        </Avatar>\n                                                                    </Tooltip>\n                                                                )\n                                                            } else if (i === 17) {\n                                                                let count = Object.keys(reduxStore.getState().db.cards[chat.nodeId]._users).length - 17\n                                                                return (\n                                                                    <Tooltip\n                                                                        title={(\n                                                                            <ul style={{ listingStyle: \"none\", padding: 0 }}>\n                                                                                {Object.keys(reduxStore.getState().db.cards[chat.nodeId]._users).map((aa, aai) => {\n                                                                                    if (aai > 16 &&\n                                                                                        reduxStore.getState().db.cards[chat.nodeId]._users[aa] &&\n                                                                                        reduxStore.getState().db.cards[chat.nodeId]._users[aa].name\n                                                                                    )\n                                                                                        return (<li>{reduxStore.getState().db.cards[chat.nodeId]._users[aa].name}</li>)\n                                                                                })}\n                                                                            </ul>\n                                                                        )}\n                                                                        key={i}\n                                                                    >\n                                                                        <Avatar style={{\n                                                                            width: 22,\n                                                                            height: 22,\n                                                                            border: 'none'\n                                                                        }} alt={`+${count}`} >\n                                                                            <span style={{ fontSize: 10 }}>{`+${count}`}</span>\n                                                                        </Avatar>\n                                                                    </Tooltip>\n                                                                )\n                                                            }\n                                                        }\n                                                        )}\n                                                </AvatarGroup>\n                                            </div>\n                                        }\n                                        <Typing nodeId={chat.nodeId} />\n                                    </div>\n                                    :\n                                    <div>\n                                        {translate(\"$__chats\", 1)}\n                                    </div>\n                                }\n                            </div>\n                            <div style={{\n                                position: \"absolute\",\n                                right: 5,\n                                display: \"flex\"\n                            }}>\n                                {chat && chat.nodeId ?\n                                    <React.Fragment>\n                                        <CustomButton\n                                            id={`chat_files`}\n                                            title={translate(`$__files`, \"*\")}\n                                            color={customApp(\"colorText\")}\n                                            icon={\"folder_special\"}\n                                            onClick={() => {\n                                                setShowFiles(prev => !prev)\n                                            }}\n                                            size={\"25px\"}\n                                            transparent\n                                        />\n                                        {/* <CustomButton\n                                            id={`chat_search`}\n                                            title={translate(`$__search`, \"*\")}\n                                            color={customApp(\"lightgray\")}\n                                            icon={\"search\"}\n                                            onClick={() => {\n                                                // setShowFiles(prev => !prev)\n                                            }}\n                                            size={\"25px\"}\n                                            transparent\n                                        /> */}\n                                        {/* <Search\n                                            db={reduxStore.getState().db.cards[chat.nodeId] ? \"cards\" : \"users\"}\n                                            nodeId={chat.nodeId}\n                                            onAction={(e) => {\n                                                // goToMessage(e._id, true)\n                                            }}\n                                        /> */}\n                                    </React.Fragment>\n                                    : <React.Fragment></React.Fragment>\n                                }\n                                <CustomButton\n                                    id={`chat_settings`}\n                                    title={translate(!reduxStore.getState().chat.notifications ? `$__chatNotificationsOff` : `$__chatNotificationsActive`, 1)}\n                                    color={customApp(\"colorText\")}\n                                    icon={!reduxStore.getState().chat.notifications ? `notifications_off` : `notifications_active`}\n                                    onClick={() => {\n                                        props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                                            ...chat,\n                                            notifications: !reduxStore.getState().chat.notifications,\n                                        })\n                                    }}\n                                    size={\"25px\"}\n                                    transparent\n                                />\n                                {chat &&\n                                    chat.nodeId &&\n                                    reduxStore.getState().db.cards[chat.nodeId] &&\n                                    reduxStore.getState().db.cards[chat.nodeId].type === 'chatGroup' &&\n                                    reduxStore.getState().db.cards[chat.nodeId]._users &&\n                                    reduxStore.getState().db.cards[chat.nodeId]._users[reduxStore.getState().session._id] &&\n                                    (\n                                        parseInt(reduxStore.getState().db.cards[chat.nodeId]._users[reduxStore.getState().session._id].access) > 4\n                                        ||\n                                        (\n                                            AppAccess &&\n                                            (\n                                                AppAccess.user &&\n                                                AppAccess.plan &&\n                                                AppAccess.userAdmin &&\n                                                AppAccess.planAdmin\n                                            )\n                                        )\n                                    ) &&\n                                    <CustomButton\n                                        id={`chat_settings`}\n                                        title={translate(`$__preffers`, \"*\")}\n                                        color={customApp(\"colorText\")}\n                                        icon={\"settings\"}\n                                        onClick={() => {\n                                            props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                                                ...reduxStore.getState().sideModule,\n                                                id: chat.nodeId,\n                                                activeModule: 'cardEdit',\n                                                db: 'cards',\n                                                data: {\n                                                    ...reduxStore.getState().db.cards[chat.nodeId] ? reduxStore.getState().db.cards[chat.nodeId] : {}\n                                                }\n                                            })\n                                            closeChat(true)\n                                        }}\n                                        size={\"25px\"}\n                                        transparent\n                                    />\n                                }\n                                <CustomButton\n                                    id={`chat_closeButton`}\n                                    title={translate(`$__close`, \"*\")}\n                                    color={customApp(\"colorText\")}\n                                    icon={\"close\"}\n                                    onClick={() => {\n                                        closeChat(true)\n                                        setOnLine(false)\n                                    }}\n                                    size={\"25px\"}\n                                    transparent\n                                />\n                            </div>\n                        </div>\n                        <div\n                            style={\n                                {\n                                    position: \"absolute\",\n                                    top: 40,\n                                    left: 0,\n                                    bottom: 0,\n                                    backgroundColor: \"rgba(246,246,246,1)\",\n                                    borderRight: `solid 4px ${customApp(\"color\")}`,\n                                    padding: \"7px\",\n                                    ...!expanded ? {\n                                        width: \"60px\",\n                                    } : {\n                                        width: \"311px\",\n                                    }\n                                }\n                            }\n                        >\n                            <Menu\n                                closeButton={() => {\n                                    props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                                        ...chat,\n                                        open: false\n                                    })\n                                    setOnLine(false)\n                                }}\n                                chat\n                                // unReadCountGroup={count && count.groups ? count.groups : 0}\n                                // unReadCountUser={count && count.users ? count.users : 0}\n                                // count={count}\n                                subMenuExpanded={(a) => {\n                                    setExpanded(a)\n                                    setOnLine(false)\n                                }}\n                                expanded={expanded}\n                                onLine={onLine}\n                            />\n                        </div>\n\n                        <div style={{\n                            position: \"absolute\",\n                            left: expanded ? 312 : 55,\n                            top: 40,\n                            right: showFiles && chat && chat.nodeId ? 333 : 0,\n                            bottom: 0,\n                            backgroundColor: \"white\"\n                        }}\n                        >\n                            {\n                                chat\n                                    && chat.nodeId ?\n                                    <Timeline\n                                        types={[\"comment\"]}\n                                        nodeId={chat.nodeId}\n                                        db={reduxStore.getState().db.cards[chat.nodeId] ? 'cards' : 'users'}\n                                        confirmRead={true}\n                                        loading={chat.loading ? true : false}\n                                        hideCards\n                                        chat={true}\n                                    />\n                                    : <React.Fragment></React.Fragment>\n                            }\n                        </div>\n                        {showFiles && chat && chat.nodeId ?\n                            <div\n                                style={{\n                                    position: 'absolute',\n                                    top: 40,\n                                    right: 0,\n                                    bottom: 0,\n                                    width: '333px',\n                                    backgroundColor: '#f1f3f4',\n                                    zIndex: 100,\n                                    boxShadow: \"-4px 0px 7px 3px rgba(0,0,0,0.1)\"\n                                }}\n                            >\n                                <Files nodeId={chat.nodeId} dark={false} />\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                    </React.Fragment>\n                </div>\n            </ClickAwayListener >\n        </div >\n    )\n}\nconst mapStateToProps = (store) => ({\n    chat: store.chat\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))","//FUNCTIONS\r\nimport { customApp } from \"functions\";\r\n\r\nconst sidebarStyle = theme => ({\r\n  root: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '0px',\r\n    width: '100%',\r\n    height: '100vh',\r\n    zIndex: 100\r\n  },\r\n  rootHide: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '0px',\r\n    width: '100%',\r\n    height: '50px',\r\n    display: 'flex',\r\n    alignItems: \"center\",\r\n    zIndex: 100\r\n  },\r\n  topLogo: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '0px',\r\n    width: '100%',\r\n    height: '50px',\r\n    display: 'flex',\r\n    alignItems: \"center\",\r\n    zIndex: 100,\r\n    justifyContent: \"space-between\"\r\n  },\r\n  bar: {\r\n    backgroundColor: customApp('menu'),\r\n    position: 'absolute',\r\n    top: 0,\r\n    left: 0,\r\n    right: 0,\r\n    bottom: 0,\r\n    zIndex: 100\r\n  },\r\n  item: {\r\n    height: '66px',\r\n    alignItems: 'center',\r\n    width: '100%',\r\n    display: 'flex',\r\n  },\r\n  itemButtom: {\r\n    padding: '7px',\r\n    color: customApp('color', 0.8),\r\n    '&:hover': {\r\n      color: customApp('color', 1),\r\n      backgroundColor: 'rgba(255,255,255,0.1)',\r\n      borderRadius: '7px',\r\n    },\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    alignItems: 'center',\r\n    cursor: 'pointer',\r\n  },\r\n  itemButtomActive: {\r\n    width: '100%',\r\n    padding: '7px',\r\n    color: customApp('color', 1),\r\n    backgroundColor: 'rgba(255,255,255,0.2)',\r\n    borderRadius: '7px',\r\n    display: 'flex',\r\n    alignItems: 'center',\r\n    // flexDirection: 'column',\r\n    // textAlign: 'center',\r\n    cursor: 'pointer',\r\n  },\r\n  themeExample: {\r\n    [theme.breakpoints.up(\"md\")]: {\r\n      left: \"auto !important\",\r\n      right: \"0 !important\"\r\n    },\r\n    [theme.breakpoints.down(\"sm\")]: {\r\n      left: \"0  !important\",\r\n      right: \"auto !important\"\r\n    }\r\n  },\r\n  module: {\r\n    position: 'fixed',\r\n    top: '0px',\r\n    left: '147px',\r\n    width: '70px',\r\n    height: '100vh',\r\n    backgroundColor: 'rgba(246,246,246,1)',\r\n    // boxShadow: '3px 0px 10px 0px rgb(0 0 0 / 22%)',\r\n    borderRight: `solid 4px ${customApp('color')}`,\r\n    padding: '7px',\r\n    //zIndex: '110',\r\n  },\r\n  moduleExpanded: {\r\n    position: 'fixed',\r\n    top: '0',\r\n    left: '147px',\r\n    width: '311px',\r\n    height: '100vh',\r\n    backgroundColor: 'rgba(246,246,246,1)',\r\n    zIndex: '100 !important',\r\n    // boxShadow: '3px 0px 10px 0px rgb(0 0 0 / 22%)',\r\n    borderRight: `solid 4px ${customApp('color')}`,\r\n    padding: '7px',\r\n    //zIndex: 110,\r\n    overflowX: 'auto'\r\n  },\r\n  moduleTitle: {\r\n    width: '100%',\r\n    height: '30px',\r\n    fontSize: '18px',\r\n    color: customApp('color'),\r\n    fontWeight: 'bold',\r\n    paddingLeft: '7px',\r\n    marginTop: '15px'\r\n  },\r\n  sidebarWrapperWithPerfectScrollbar: {\r\n    // overflow: \"hidden !important\"\r\n  },\r\n  separator: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    padding: '7px',\r\n    borderTop: `1px solid ${customApp('medium', 0.5)}`,\r\n    marginTop: '15px',\r\n    marginBottom: '0px',\r\n    height: '1px'\r\n  },\r\n  mainButton: {\r\n    // marginTop: '10px',\r\n    width: '100%',\r\n    justifyContent: 'space-between',\r\n    display: 'flex',\r\n    // padding: '10px 0',\r\n    alignItems: 'center',\r\n  },\r\n  logoImg: {\r\n    width: 111,\r\n    marginLeft: \"15px\",\r\n    justifyContent: 'center'\r\n  },\r\n  user: {\r\n    zIndex: '150 !important'\r\n  }\r\n});\r\n\r\nexport default sidebarStyle;\r\n","//CORE\nimport React from \"react\";\n\n//REDUX\nimport { connect } from \"react-redux\";\nimport { bindActionCreators } from \"redux\";\nimport * as reduxActions from \"store/actions\";\nimport reduxStore from \"store/\";\nimport history from \"store/history\"\n\n//COMPONENTS\nimport Icon from \"components/Icon\"\nimport CustomButton from \"components/Buttons/custom\";\n\n//@MATERIAL\nimport Badge from '@material-ui/core/Badge';\nimport { withStyles } from \"@material-ui/core/styles\";\n\n//IMAGES\nimport logoMachen from \"assets/img/logoMachen.svg\";\nimport Bright from \"assets/icons/BrigthAndConnected\";\n\n//STYLES\nimport styles from \"assets/jss/material-dashboard-pro-react/components/MobileNav.js\";\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\";\nimport { countUnRead } from \"functions/chat\";\n\nrequire('dotenv').config()\n\nfunction Component(props) {\n    const { chat, notifications } = reduxStore.getState()\n    const { classes } = props\n    const [mounted, setMounted] = React.useState(false)\n    const [viewModule, setViewModule] = React.useState(null);\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    React.useEffect(() => {\n        if (!mounted) {\n            setMounted(true)\n        }\n    }, [notifications])\n\n    const openModule = async (route, vm, nodeId, dbProps = 'users') => {\n        if (route && (window.location.pathname !== route || vm === viewModule)) {\n            history.push(route)\n        }\n\n\n        if (vm === 'chat') {\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...chat,\n                open: true,\n                db: dbProps,\n                nodeId: nodeId,\n            })\n        } else {\n            setViewModule(vm)\n            props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                ...chat,\n                open: false,\n            })\n        }\n        if (props.menuExpand)\n            props.menuExpand()\n    }\n\n    const count = countUnRead()\n\n    if (!props.expanded)\n        return (\n            <div className={classes.rootHide}>\n                <div\n                    className={classes.mainButton}\n                    id=\"sideBar_logoMini\"\n                >\n                    <img src={logoMachen} alt=\"logo\"\n                        className={classes.logoImg}\n                        style={{\n                            width: \"111px\",\n                            marginLeft: \"15px\"\n                        }}\n                        onClick={() => {\n                            props.menuExpand()\n                        }}\n                    />\n                    <CustomButton\n                        title={translate(`$__showMenu`, 1)}\n                        color={customApp('menu')}\n                        icon={'menu'}\n                        onClick={props.menuExpand ? () => {\n                            props.menuExpand()\n                        } : null}\n                        transparent\n                    />\n                </div>\n            </div>\n        )\n\n    return (\n        <div className={classes.root}>\n            <div className={classes.bar}>\n                <div className={classes.topLogo}\n                    id=\"sideBar_logoMini\"\n                >\n                    <img src={logoMachen} alt=\"logo\"\n                        className={classes.logoImg}\n                        style={{\n                            width: \"111px\",\n                            marginLeft: \"15px\"\n                        }}\n                    />\n                    <CustomButton\n                        title={translate(`$__hideMenu`, 1)}\n                        color={customApp('color')}\n                        icon={'menu'}\n                        onClick={props.menuExpand ? () => {\n                            props.menuExpand()\n                        } : null}\n                        transparent\n                    />\n                </div>\n                <div\n                    style={{\n                        position: 'absolute',\n                        top: '120px',\n                        bottom: '0px',\n                        overflowX: 'auto',\n                        width: '100%'\n                    }}\n                >\n                    <div className={classes.item} id=\"sideBar_button_dashboard\">\n                        <div\n                            className={window.location.pathname === '/d' ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule('/d', 'dashboard')\n                            }\n                            }\n                        >\n                            <Icon\n                                icon=\"dashboard\"\n                                badgeColor={'primary'}\n                                color={'parent'}\n                                badgeVisible\n                                title=\"$__dashboard\"\n                                size={'27px'}\n                                style={{\n                                    marginBottom: '7px',\n                                    marginRight: '15px'\n                                }}\n                            />\n                            {translate(`$__dashboard`, '*')}\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_chat\">\n                        <div className={chat.open ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                if (props.menuExpand)\n                                    props.menuExpand()\n                                props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n                                    ...chat,\n                                    open: !chat.open,\n                                })\n                            }\n                            }\n                        >\n                            <Badge\n                                overlap=\"rectangular\"\n                                badgeContent={count && count.total ? count.total : 0} color=\"secondary\">\n                                <Icon\n                                    icon={'chat'}\n                                    color={'parent'}\n                                    title=\"$__chat\"\n                                    size={'27px'}\n                                    style={{\n                                        marginBottom: '7px',\n                                        marginRight: '15px'\n                                    }}\n                                />\n                            </Badge>\n                            {translate(`$__chat`, '*')}\n                        </div>\n                    </div>\n                    <div className={classes.separator}></div>\n                    <div className={classes.item} id=\"sideBar_button_StrategyAndPlans\">\n                        <div className={window.location.pathname === '/sp' ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule('/sp', 'StrategyAndPlans')\n                            }\n                            }\n                        >\n                            <Icon\n                                icon=\"view_comfy\"\n                                badgeColor={'primary'}\n                                color={'parent'}\n                                badgeVisible\n                                title={translate('$__StrategyAndPlans')}\n                                size={'27px'}\n                                style={{\n                                    marginBottom: '7px',\n                                    marginRight: '15px'\n                                }}\n                            />\n                            {translate(`$__StrategyAndPlans`, '*')}\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_myTasks\">\n                        <div className={window.location.pathname === '/t' ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule('/t', 'myTasks')\n                            }\n                            }\n                        >\n                            <Icon\n                                icon=\"task\"\n                                badgeColor={'primary'}\n                                color={'parent'}\n                                badgeVisible\n                                title={translate('$__mytasks')}\n                                size={'27px'}\n                                style={{\n                                    marginBottom: '7px',\n                                    marginRight: '15px'\n                                }}\n                            />\n                            {translate(`$__mytasks`, '*')}\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_library\">\n                        <div className={window.location.pathname === '/library' ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule('/library', 'library')\n                            }\n                            }\n                        >\n                            <Icon\n                                icon=\"folder\"\n                                badgeColor={'primary'}\n                                color={'parent'}\n                                badgeVisible\n                                title={translate('$__library')}\n                                size={'27px'}\n                                style={{\n                                    marginBottom: '7px',\n                                    marginRight: '15px'\n                                }}\n                            />\n                            {translate(`$__library`, '*')}\n                        </div>\n                    </div>\n                    <div className={classes.item} id=\"sideBar_button_brightandconnected\">\n                        <div className={window.location.pathname === '/bright-and-connected' ? classes.itemButtomActive : classes.itemButtom}\n                            onClick={() => {\n                                openModule('/bright-and-connected', 'bright-and-connected')\n                            }\n                            }\n                        >\n                            <Icon\n                                icon={Bright}\n                                badgeColor={'primary'}\n                                color={'parent'}\n                                badgeVisible\n                                title=\"BRIGHT & CONNECTED\"\n                                size={'27px'}\n                                style={{\n                                    marginBottom: '7px',\n                                    marginRight: '15px'\n                                }}\n                            />\n                            BRIGHT & CONNECTED\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n    )\n}\n\n\nconst mapStateToProps = (store, ownProps) => ({\n    store, ownProps\n});\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(withStyles(styles)(Component))\n","import React from \"react\"\n\n//COMPONENTS\nimport HeaderWithIcon from \"components/Header/card\"\n\n//@MATERIAL\nimport Dialog from \"@material-ui/core/Dialog\";\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\nimport { getAppAccess, translate } from 'functions/'\n\n\nfunction CardActions(props) {\n    console.log(\"AQUI PRECISA SER CRIADO O PAINEL DE MODELOS DE FLUXOS\")\n    return (\n        <Dialog\n            fullWidth={true}\n            // onClose={() => setMigrator(false)}\n            aria-labelledby=\"simple-dialog-title\"\n            open={props.card.action ? true : false}\n        >\n            <div style={{ position: \"relative\", marginLeft: \"10px\", marginTop: '5px', width: \"calc(100% - 10px)\" }}>\n                <HeaderWithIcon\n                    title={translate(`$__${props.card.action}`, 1)}\n                    icon=\"label\"\n                    onCancel={() => {\n                        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                            ...reduxStore.getState().db,\n                            history: `${window.location.pathname}${window.location.hash}`\n                        })\n\n                    }}\n                />\n            </div>\n            {/*\n                <div style={{ color: \"#CCCCCC\", padding: \"15px\" }}>\n                    {\n                        MigratorData._childrens\n                        && !MigratorData._skipGoals\n                        && MigratorData._goals.length > 0\n                        && MigratorData._goals.filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type).length > 0\n                        &&\n                        <React.Fragment>\n                            <span style={{ color: 'gray' }}>#NEED_TRANSLATE:: Você possui metas vinculadas aos objetivos/ou diretrizes que deseja migrar. Você deseja transformar essas metas em ações?\n                                <p style={{ color: 'red' }}>Essa ação só pode ser desfeita manualmente</p>\n                            </span>\n                            {MigratorData._goals\n                                .filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type)\n                                .sort((a, b) => {\n                                    if (reduxStore.getState().db.orderByTitle\n                                        && reduxStore.getState().db.orderByTitlePosition === 'ASC'\n                                        && a.name.toLowerCase().trim() < b.name.toLowerCase().trim()\n                                    ) {\n                                        return -1\n                                    } else if (reduxStore.getState().db.orderByTitle\n                                        && reduxStore.getState().db.orderByTitlePosition === 'DESC'\n                                        && a.name.toLowerCase().trim() > b.name.toLowerCase().trim()\n                                    ) {\n                                        return -1\n                                    } else if (reduxStore.getState().db.orderByTitle) {\n                                        return 0\n                                    } else if (!reduxStore.getState().db.orderByTitle && String(a.order) && String(b.order) && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low)) {\n                                        return -1\n                                    } else {\n                                        return 1\n                                    }\n                                }\n                                ).map((a, i) =>\n                                    <div style={{ width: 'calc(100%)', display: \"flex\", alignItems: \"center\", justifyContent: \"center\" }} key={a._id}>\n                                        <Card db=\"cards\" data={a} db='cards' noShadow />\n                                        <Button\n                                            onClick={() => {\n                                                updateCard(props, {\n                                                    _id: a._id,\n                                                    type: 'task'\n                                                })\n                                            }}\n                                        >\n                                            <Icon\n                                                icon=\"change_circle\"\n                                                color={customApp('menu')}\n                                                title={translate('$__transformInTask')}\n                                            />\n                                        </Button>\n                                    </div>\n                                )\n                            }\n                            <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\", padding: \"15px\" }}>\n                                <CustomButton\n                                    shadow\n                                    title={translate(\"$__skipAll\")}\n                                    text={translate(\"$__skipAll\")}\n                                    color=\"lightgrey\"\n                                    icon={\"skip_next\"}\n                                    size={\"25px\"}\n                                    onClick={() => {\n                                        setMigratorData({\n                                            ...MigratorData,\n                                            _skipGoals: true\n                                        })\n                                    }}\n                                />\n                                <div style={{ marginLeft: \"15px\" }}>\n                                    <CustomButton\n                                        shadow\n                                        title={translate(\"$__changeAllInTasks\")}\n                                        text={translate(\"$__changeAllInTasks\")}\n                                        icon={\"change_circle\"}\n                                        size={\"25px\"}\n                                        onClick={() => {\n                                            iniMigration('goals')\n                                            setMigratorData({\n                                                ...MigratorData,\n                                                _skipGoals: true\n                                            })\n                                        }}\n                                    />\n                                </div>\n                            </div>\n                        </React.Fragment>\n                    }\n                    {\n                        MigratorData._childrens\n                        && !MigratorData._skipObjectives\n                        && MigratorData._objectives.length > 0\n                        && MigratorData._objectives\n                            .filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type).length > 0\n                        &&\n                        <React.Fragment>\n                            <span style={{ color: 'gray' }}>#NEED_TRANSLATE:: Você possui OBJETIVOS vinculadas aos à diretriz que deseja migrar. Você deseja transformar em metas?\n                                <p style={{ color: 'red' }}>Essa ação só pode ser desfeita manualmente</p>\n                            </span>\n                            {MigratorData._objectives\n                                .filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type)\n                                .sort((a, b) => {\n                                    if (reduxStore.getState().db.orderByTitle\n                                        && reduxStore.getState().db.orderByTitlePosition === 'ASC'\n                                        && a.name.toLowerCase().trim() < b.name.toLowerCase().trim()\n                                    ) {\n                                        return -1\n                                    } else if (reduxStore.getState().db.orderByTitle\n                                        && reduxStore.getState().db.orderByTitlePosition === 'DESC'\n                                        && a.name.toLowerCase().trim() > b.name.toLowerCase().trim()\n                                    ) {\n                                        return -1\n                                    } else if (reduxStore.getState().db.orderByTitle) {\n                                        return 0\n                                    } else if (!reduxStore.getState().db.orderByTitle && String(a.order) && String(b.order) && String(a.order.low) && String(b.order.low) && parseInt(a.order.low) < parseInt(b.order.low)) {\n                                        return -1\n                                    } else {\n                                        return 1\n                                    }\n                                }\n                                ).map((a, i) =>\n                                    <div style={{ width: 'calc(100%)', display: \"flex\", alignItems: \"center\", justifyContent: \"center\" }} key={a._id}>\n                                        <Card db=\"cards\" data={a} noShadow />\n                                        <Button\n                                            onClick={() => {\n                                                updateCard(props, {\n                                                    _id: a._id,\n                                                    type: 'goal'\n                                                })\n                                            }}\n                                        >\n                                            <Icon\n                                                icon=\"change_circle\"\n                                                color={customApp('menu')}\n                                                title={translate('$__transformInGoal')}\n                                            />\n                                        </Button>\n                                    </div>\n                                )\n                            }\n                            <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\", padding: \"15px\" }}>\n                                <CustomButton\n                                    shadow\n                                    title={translate(\"$__skipAll\")}\n                                    text={translate(\"$__skipAll\")}\n                                    color=\"lightgrey\"\n                                    icon={\"skip_next\"}\n                                    size={\"25px\"}\n                                    onClick={() => {\n                                        setMigratorData({\n                                            ...MigratorData,\n                                            _skipObjectives: true\n                                        })\n                                    }}\n                                />\n                                <div style={{ marginLeft: \"15px\" }}>\n                                    <CustomButton\n                                        shadow\n                                        title={translate(\"$__changeAllInGoal\")}\n                                        text={translate(\"$__changeAllInGoal\")}\n                                        icon={\"change_circle\"}\n                                        size={\"25px\"}\n                                        onClick={() => {\n                                            iniMigration('objectives')\n                                            setMigratorData({\n                                                ...MigratorData,\n                                                _skipObjectives: true\n                                            })\n                                        }}\n                                    />\n                                </div>\n                            </div>\n                            <div style={{ marginLeft: \"15px\" }}>\n                                <CustomButton\n                                    shadow\n                                    title={translate(\"$__cancel\")}\n                                    text={translate(\"$__cancel\")}\n                                    icon={\"cancel\"}\n                                    size={\"25px\"}\n                                    onClick={() => {\n                                        setMigrator(false)\n                                    }}\n                                />\n                            </div>\n                        </React.Fragment>\n                    }\n\n                    {(\n                        (\n                            MigratorData\n                            && MigratorData._childrens\n                            && Object.keys(MigratorData._childrens).length > 0\n                            && MigratorData._goals.filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type).length === 0\n                            && MigratorData._objectives.filter(a => reduxStore.getState().db.cards[a._id] && reduxStore.getState().db.cards[a._id].type === a.type).length === 0\n                        )\n                        || (\n                            (\n                                MigratorData._skipGoals\n                                && MigratorData._goals.length > 0\n                            )\n                            &&\n                            (\n                                MigratorData._skipObjectives\n                                && MigratorData._objectives.length > 0\n                            )\n                        )\n                    )\n                        &&\n                        <React.Fragment>\n                            <span style={{ color: 'red' }}>#NEED_TRANSLATE:: Clique em salvar para finalizar as migrações.</span>\n                            <div style={{ display: \"flex\", alignItems: \"center\", justifyContent: \"flex-end\", padding: \"15px\" }}>\n                                <CustomButton\n                                    shadow\n                                    title={translate(\"$__cancel\")}\n                                    text={translate(\"$__cancel\")}\n                                    color=\"lightgrey\"\n                                    icon={\"close\"}\n                                    size={\"25px\"}\n                                    onClick={() => {\n                                        setMigrator(false)\n                                        setMigratorData({})\n                                    }}\n                                />\n                                <div style={{ marginLeft: \"15px\" }}>\n                                    <CustomButton\n                                        shadow\n                                        title={translate(\"$__save\")}\n                                        text={translate(\"$__save\")}\n                                        icon={\"done_all\"}\n                                        size={\"25px\"}\n                                        onClick={() => {\n                                            finishMigration()\n                                        }}\n                                    />\n                                </div>\n                            </div>\n                        </React.Fragment>\n                    }\n                </div> */}\n        </Dialog>\n    )\n}\n\nconst mapStateToProps = (store) => ({\n    card: store.card\n})\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps, mapDispatchToProps)(CardActions)\n","// \r\nimport React from \"react\"\r\n\r\n//COMPONENTS\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport HeaderWithIcon from \"components/Header/card\"\r\nimport Icon from \"components/Icon\"\r\nimport KanbanBoard from \"components/AgileKanban\"\r\n\r\n//@MATERIAL\r\nimport ClickAwayListener from \"@material-ui/core/ClickAwayListener\"\r\n\r\n//REDUX\r\nimport * as reduxActions from \"store/actions\"\r\nimport reduxStore from \"store/\"\r\nimport { bindActionCreators } from \"redux\"\r\nimport { connect } from \"react-redux\"\r\n\r\n//FUNCTIONS\r\nimport ErrorBoundary from \"components/ErrorBoundary\"\r\nimport { translate, customApp } from \"functions\"\r\nimport session from \"store/controls\"\r\n\r\n\r\nconst ModalComponent = (props) => {\r\n    const { db, session } = reduxStore.getState()\r\n    // React.useEffect(() => {\r\n\r\n    // }, [props.board])\r\n\r\n    if (!props.board)\r\n        return (<React.Fragment></React.Fragment>)\r\n\r\n    let hashs = window.location.hash.split(\"/\")\r\n    hashs[0] = hashs[0].replace(\"#\", \"\")\r\n\r\n\r\n\r\n    // return (<div>teste</div>)\r\n\r\n    const data = db.cards[props.board]\r\n    const step = data._parent ? db.cards[data._parent] : null\r\n    const parent = step && step._parent !== hashs[0] && db.cards[step._parent] && db.cards[step._parent]._users && db.cards[step._parent]._users[session._id] ? db.cards[step._parent] : null\r\n\r\n    return (\r\n        <div style={{\r\n            position: \"absolute\",\r\n            top: 0,\r\n            left: 0,\r\n            right: 0,\r\n            bottom: 0,\r\n            backdropFilter: \"blur(3px)\",\r\n        }}>\r\n            <ClickAwayListener\r\n                onClickAway={() => {\r\n                    // setDuplicate(false)\r\n\r\n                }}\r\n            >\r\n                <div\r\n                    style={{\r\n                        position: 'absolute',\r\n                        top: '0px',\r\n                        left: '0px',\r\n                        right: '0px',\r\n                        bottom: '0px',\r\n                        display: 'flex',\r\n                        justifyContent: \"center\",\r\n                        alignItems: \"center\"\r\n                    }}\r\n                    onClick={(e) => {\r\n                        e.preventDefault()\r\n                        e.stopPropagation()\r\n                    }}\r\n                >\r\n\r\n                    <div style={{\r\n                        position: \"relative\",\r\n                        width: 'calc(100% - 100px)',\r\n                        backgroundColor: '#FFFFFF',\r\n                        margin: 'auto',\r\n                        boxShadow: \"0px 0px 10px 3px rgba(0,0,0,0.2)\",\r\n                    }}>\r\n                        <div style={{\r\n                            position: \"relative\",\r\n                            width: '100%',\r\n                            backgroundColor: '#FFFFFF',\r\n                            padding: '9px',\r\n                            height: \"40px\",\r\n                            margin: 'auto',\r\n                            background: customApp('ColumnTitleColor'),\r\n                        }}>\r\n                            <div\r\n                                style={{\r\n                                    fontSize: \"14px\",\r\n                                    color: customApp(\"color\"),\r\n                                    display: \"flex\",\r\n                                    justifyContent: \"flex-start\",\r\n                                    alignItems: \"center\"\r\n                                }}\r\n                            >\r\n                                {parent && parent._id &&\r\n                                    <div style={{\r\n                                        marginRight: 15,\r\n                                        display: \"flex\",\r\n                                        justifyContent: \"flex-start\",\r\n                                        alignItems: \"center\"\r\n                                    }}>\r\n                                        <HeaderWithIcon\r\n                                            title={`${parent?.name || translate(\"$__undefinedName\", 1)} `}\r\n                                            searchText={props?.searchText || null}\r\n                                            icon={parent?.icon || (parent.type && db && db.dataType && db.dataType.filter(a => a.name === parent.type)[0] && db.dataType.filter(a => a.name === parent.type)[0].icon) || \"$__topic\"}\r\n                                            iconTitle={`$__${parent.type}`}\r\n                                            color={customApp('textColor')}\r\n                                            backClick={(e) => {\r\n                                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                                    ...reduxStore.getState().control,\r\n                                                    board: parent._id,\r\n                                                })\r\n                                            }}\r\n                                        />\r\n                                        <div style={{\r\n                                            marginTop: -5\r\n                                        }}>\r\n                                            <Icon icon=\"navigate_next\" color={customApp('textColor')} />\r\n                                        </div>\r\n                                    </div>\r\n                                }\r\n                                <div>\r\n                                    <HeaderWithIcon\r\n                                        title={`${data?.name || translate(\"$__undefinedName\", 1)} `}\r\n                                        searchText={props?.searchText || null}\r\n                                        icon={data?.icon || (data.type && db && db.dataType && db.dataType.filter(a => a.name === data.type)[0] && db.dataType.filter(a => a.name === data.type)[0].icon) || \"$__topic\"}\r\n                                        iconTitle={`$__${data.type}`}\r\n                                        color={customApp('textColor')}\r\n                                    />\r\n                                </div>\r\n                            </div>\r\n                            <div style={{\r\n                                position: \"absolute\",\r\n                                right: 5,\r\n                                top: 5\r\n                            }}>\r\n                                <CustomButton\r\n                                    id={`close_kanban`}\r\n                                    title={translate(`$__close`, \"*\")}\r\n                                    color={customApp(\"color\")}\r\n                                    icon={\"close\"}\r\n                                    onClick={() => {\r\n                                        props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                            ...reduxStore.getState().control,\r\n                                            board: null,\r\n                                        })\r\n                                    }}\r\n                                    size={\"25px\"}\r\n                                    transparent\r\n                                />\r\n                            </div>\r\n                        </div>\r\n                        <div\r\n                            style={{\r\n                                position: \"relative\",\r\n                                padding: '9px',\r\n                            }}\r\n                        >\r\n                            <ErrorBoundary>\r\n                                <KanbanBoard\r\n                                    nodeId={props.board}\r\n                                    columProps={{\r\n                                        style: {\r\n                                            height: \"calc(100vh - 277px)\",\r\n                                        }\r\n                                    }}\r\n                                />\r\n                            </ErrorBoundary>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ClickAwayListener>\r\n        </div>\r\n    )\r\n}\r\n\r\nconst mapStateToProps = (store) => ({\r\n    board: store.controls.board\r\n})\r\n\r\nconst mapDispatchToProps = dispatch =>\r\n    bindActionCreators(reduxActions, dispatch)\r\n\r\nexport default connect(mapStateToProps, mapDispatchToProps)(ModalComponent)","import React from \"react\";\r\n\r\n//REDUX\r\nimport reduxStore from \"store/\";\r\n\r\n//FUNCTIONS\r\nimport api from \"api/\";\r\nrequire('dotenv').config()\r\n\r\nconst nodeUpdate = async (props, data) => {\r\n    let { db } = reduxStore.getState()\r\n    let nodeType = 'cards'\r\n    if (db.cards[data._id]) {\r\n        nodeType = 'cards'\r\n    } else if (db.users[data._id]) {\r\n        nodeType = 'users'\r\n    }\r\n    if (reduxStore.getState().db\r\n        && reduxStore.getState().db[nodeType]\r\n        && reduxStore.getState().db[nodeType][data._id]\r\n    ) {\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...reduxStore.getState().db,\r\n            [nodeType]: {\r\n                ...reduxStore.getState().db[nodeType],\r\n                [data._id]: {\r\n                    ...reduxStore.getState().db[nodeType][data._id],\r\n                    ...data\r\n                }\r\n            }\r\n        });\r\n    }\r\n}\r\n\r\nexport {\r\n    nodeUpdate,\r\n}","import {\r\n  drawerWidth,\r\n  drawerMiniWidth,\r\n  transition,\r\n  containerFluid\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst appStyle = theme => ({\r\n  backdrop: {\r\n    zIndex: theme.zIndex.drawer + 1,\r\n    backgroundColor: \"rgba(0,0,0,0.66) !important\"\r\n  },\r\n  wrapper: {\r\n    position: \"absolute\",\r\n    top: \"70px\",\r\n    left: \"0\",\r\n    right: \"0\",\r\n    bottom: \"0\",\r\n    height: \"calc(100vh - 60px)\",\r\n  },\r\n  mainPanel: {\r\n    overflow: \"auto\",\r\n    position: \"absolute\",\r\n    top: \"0\",\r\n    left: \"0\",\r\n    right: \"0\",\r\n    bottom: \"0\"\r\n  },\r\n  content: {\r\n    marginTop: \"0px\",\r\n    padding: \"15px\",\r\n  },\r\n  container: { ...containerFluid },\r\n  map: {\r\n    marginTop: \"0px\"\r\n  },\r\n  mainPanelSidebarMini: {\r\n    [theme.breakpoints.up(\"md\")]: {\r\n      width: `calc(100% - 0px)`\r\n    }\r\n  },\r\n});\r\n\r\nexport default appStyle;\r\n","import {\r\n  whiteColor,\r\n  blackColor,\r\n  hexToRgb\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\nconst pagesStyle = theme => ({\r\n  wrapper: {\r\n    height: \"auto\",\r\n    minHeight: \"100vh\",\r\n    position: \"relative\",\r\n    top: \"0\"\r\n  },\r\n  fullPage: {\r\n    padding: \"120px 0\",\r\n    position: \"relative\",\r\n    minHeight: \"100vh\",\r\n    display: \"flex!important\",\r\n    margin: \"0\",\r\n    border: \"0\",\r\n    color: whiteColor,\r\n    alignItems: \"center\",\r\n    backgroundSize: \"cover\",\r\n    backgroundPosition: \"center center\",\r\n    height: \"100%\",\r\n    // [theme.breakpoints.down(\"sm\")]: {\r\n    //   minHeight: \"fit-content!important\"\r\n    // },\r\n    \"& footer\": {\r\n      position: \"absolute\",\r\n      bottom: \"0\",\r\n      width: \"100%\",\r\n      border: \"none !important\"\r\n    },\r\n    \"&:before\": {\r\n      backgroundColor: \"rgba(\" + hexToRgb(blackColor) + \", 0.22)\"\r\n    },\r\n    \"&:before,&:after\": {\r\n      display: \"block\",\r\n      content: '\"\"',\r\n      position: \"absolute\",\r\n      width: \"100%\",\r\n      height: \"100%\",\r\n      top: \"0\",\r\n      left: \"0\",\r\n      zIndex: \"2\"\r\n    }\r\n  }\r\n});\r\n\r\nexport default pagesStyle;\r\n","// ID_CREATED*************************\n\nimport React from \"react\"\nimport MD5 from \"crypto-js/md5\"\nimport cx from \"classnames\"\nimport moment from \"moment-timezone\"\nimport { Switch, Route, Redirect } from \"react-router-dom\"\nimport { ToastContainer } from \"react-toastify\"\nimport { ContextMenu, MenuItem, ContextMenuTrigger } from \"react-contextmenu\"\n// import { TourProvider, useTour } from \"@reactour/tour\"\n// import Tour from \"reactour\"\nimport \"react-toastify/dist/ReactToastify.css\"\nimport styled from \"styled-components\"\nimport PolicyAndTerms from \"components/PlataformContracts/PolicyAndTerms\"\nimport LicensingAgreement from \"components/PlataformContracts/LicensingAgreement\"\n\nimport ErrorBoundary from \"components/ErrorBoundary\"\n\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\"\nimport Backdrop from \"@material-ui/core/Backdrop\"\nimport Hidden from \"@material-ui/core/Hidden\"\n\n// COMPONENTS\nimport AuthNavbar from \"components/Navbars/AuthNavbar\"\nimport Footer from \"components/Footer/Footer\"\nimport Icon from \"components/Icon\"\nimport LightBox from \"components/LightBox\"\nimport LoaderPage from \"components/LoaderPage\"\nimport Message from \"components/Timeline/message\"\nimport MiroBoard from \"components/MiroBoard\"\nimport SideModule from \"components/SideModule/\"\nimport Sidebar from \"components/Sidebar/\"\nimport TopHeader from \"components/TopHeader\"\nimport Chat from \"components/Chat\"\nimport MobileNav from \"components/MobileNav\"\nimport CardActions from \"components/CardActions\"\nimport KanbanModal from \"components/AgileKanban/modal\"\n\n//ROUTES\nimport routes from \"routes\"\n\n//IMAGES\nimport background from \"assets/img/fundoLogin.jpg\"\n\n//FUNCTIONS\nimport apims from \"apims/\"\n\nimport {\n  cardAccessDelete,\n  cardAccessRemove,\n  cardAccessUpdate,\n  changePlanId,\n  columnCards,\n  dbUpdateCard,\n  dbUpdateCardSWOT,\n  dbUpdateCardTimer,\n  dbUpdateCard_V2,\n  deleteCard,\n  deleteColumn,\n  myDayUpd,\n  reorderCard,\n  reorderColumns,\n  socketUnLinkChildrens,\n  updateColumnCards,\n} from \"functions/cards\"\nimport {\n  chatReaded,\n  interact,\n  loadTimeline,\n  timelineComment,\n} from \"functions/chat\"\nimport {\n  dbUpdateUser\n} from \"functions/users\"\nimport {\n  dbUpdateFeed\n} from \"functions/feeds\"\nimport {\n  appAlert,\n  languageUPD,\n} from \"functions/\"\n\nimport {\n  nodeUpdate\n} from \"functions/socket\"\n\nimport {\n  tagUpdate,\n  localTagDelete,\n  localTagUnlink\n} from \"functions/tags\"\nimport {\n  loadCardsV2,\n  pageLoadCards,\n} from \"functions/loadData\"\n\n//REDUX\nimport { connect } from \"react-redux\"\nimport { bindActionCreators } from \"redux\"\nimport * as reduxActions from \"store/actions\"\nimport reduxStore from \"store/\"\nimport history from \"store/history\"\n\n// SOCKET\nimport socketIOClient from \"socket.io-client\"\n\n//STYLESS\nimport stylesAdmin from \"assets/jss/material-dashboard-pro-react/layouts/adminStyle\"\nimport stylesLogin from \"assets/jss/material-dashboard-pro-react/layouts/authStyle\"\nimport \"perfect-scrollbar/css/perfect-scrollbar.css\"\n\n//AUDIO\nimport NotificationAudio from \"assets/sound/notification.mp3\"\nimport { translate, customApp } from \"functions\"\n\nconst audio = new Audio(NotificationAudio)\nrequire('dotenv').config()\n\nconst API_WS = String(process.env.REACT_APP_PROD) === 'true' ? process.env.REACT_APP_WS : process.env.REACT_APP_devWS\n\nfunction SaasHome(props) {\n  const { ...rest } = props\n  // states and functions\n  const { session, chat } = reduxStore.getState()\n  const [whiteLabel, setWhiteLabel] = React.useState({})\n  const [auth, setAuth] = React.useState(false)\n  const [backdropEnabled, setBackdropEnabled] = React.useState(false)\n  const [loading, setLoading] = React.useState(true)\n  const [maintenance, setmaintenance] = React.useState(false)\n  const [offlineDetected, setOfflineDetected] = React.useState(false)\n  const [expanded, setExpanded] = React.useState(true)\n  const [subMenuExpanded, setSubMenuExpanded] = React.useState(false)\n  const [appRoutes, setAppRoutes] = React.useState(null)\n\n  const useStyles = makeStyles(auth ? stylesAdmin : stylesLogin)\n  const pageLoads = React.useRef({})\n  const states = React.useRef({})\n\n  const timeZone = 'America/Sao_Paulo'\n  // styles\n  const classes = useStyles()\n  const wrapper = React.createRef()\n  const mainPanelClasses =\n    classes.mainPanel +\n    \" \" +\n    cx({\n      [classes.mainPanelSidebarMini]: true,\n      [classes.mainPanelWithPerfectScrollbar]:\n        navigator.platform.indexOf(\"Win\") > -1\n    })\n\n  const mainPanel = React.createRef()\n  const connection = React.createRef()\n\n  React.useEffect(() => {\n    connection.current = {\n      offline: false\n    }\n    const verifyLabel = async (hostname) => {\n      // console.log(\"WHITELABEL:::\", hostname)\n      const wl = await apims.post('/WhiteLabel', { url: hostname })\n      if (wl) {\n        if (wl?.data) {\n          setWhiteLabel(wl.data)\n          props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n            ...session,\n            custom: {\n              ...session.custom,\n              ...wl.data,\n            }\n          })\n        }\n        verifySession()\n      }\n    }\n    const token = localStorage.getItem(\"TOKEN\") || null\n\n    let hostname = window.location.hostname\n    hostname = hostname.replace(\".machen.ai\", \"\")\n    // hostname = 'vectis'\n\n\n\n\n    if (\n      hostname\n      && hostname.indexOf('software') === -1\n      && hostname.indexOf('hom2022') === -1\n      && hostname.indexOf('localhost') === -1\n    ) {\n      verifyLabel(hostname)\n    } else {\n      verifySession()\n    }\n\n    setAppRoutes(getRoutes(routes))\n  }, [])\n\n\n\n  React.useEffect(() => {\n    let Nhashs = window.location.hash.split(\"/\")\n    Nhashs[0] = Nhashs[0].replace(\"#\", \"\")\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n      ...reduxStore.getState().db,\n      history: `${window.location.pathname}${window.location.hash}`\n    })\n    pageDataRequest(Nhashs)\n  })\n\n  React.useEffect(() => {\n    let Nhashs = window.location.hash.split(\"/\")\n    Nhashs[0] = Nhashs[0].replace(\"#\", \"\")\n    if (auth) {\n      pageDataRequest(Nhashs)\n      initCompleted()\n      init(true)\n      setAppRoutes(getRoutes(routes))\n    }\n  }, [auth])\n\n  const init = async (force) => {\n    connection.current = {\n      offline: false\n    }\n    window.addEventListener(\"dragover\", function (e) {\n      e.preventDefault()\n    }, false)\n    window.addEventListener(\"drop\", function (e) {\n      e.preventDefault()\n    }, false)\n\n    var exitTime\n    var contTime = 0\n    var interval_id = setInterval(() => {\n      contTime = contTime + 1\n    }, 1000)\n\n    var interval_status = setTimeout(() => {\n\n    }, 50000);\n\n    let sessionInterval = setInterval(() => {\n      verifySession(true)\n    }, 360000)\n\n    window.addEventListener(\"blur\", () => {\n      clearInterval(interval_id)\n      clearInterval(sessionInterval)\n      interval_id = 0\n      exitTime = moment().tz(timeZone).unix('X')\n      interval_status = setTimeout(() => {\n        setStatus(\"away\")\n      }, 60000)\n\n    })\n    window.addEventListener(\"focus\", async (e) => {\n      if (!connection?.current?.offline) {\n        verifySession(true)\n        clearInterval(sessionInterval)\n        sessionInterval = setInterval(() => {\n          verifySession(true)\n        }, 360000)\n        clearTimeout(interval_status)\n        if (!interval_id)\n          interval_id = setInterval(() => {\n            contTime = contTime + 1\n          }, 1000)\n        setStatus(\"online\")\n        if (exitTime && moment().tz(timeZone).unix('X') - exitTime > 30)\n          verifyMessages()\n      }\n    })\n  }\n\n  const verifyMessages = (lastDate = null) => {\n    loadTimeline(\n      {\n        ...props,\n        fnIdentification: \"Layouts/Index/loadData()-Users\"\n      },\n      {\n        ids: [reduxStore.getState().session._id],\n        db: \"users\",\n        type: \"comment\",\n        newUpdates: true,\n        lastDate\n      }\n    )\n  }\n\n  const setStatus = async (status) => {\n    if (\n      (status === 'online'\n        && reduxStore.getState().usersStatus.users\n        && reduxStore.getState().usersStatus.users[session._id]\n        && reduxStore.getState().usersStatus.users[session._id].status !== 'online'\n      )\n      ||\n      (status === 'away'\n        && reduxStore.getState().usersStatus.users\n        && reduxStore.getState().usersStatus.users[session._id]\n        && reduxStore.getState().usersStatus.users[session._id].status !== 'away'\n      )\n    ) {\n      const { socket } = reduxStore.getState().functions\n      socket.emit(\"socketStatus\", {\n        socketStatus: status\n      })\n    }\n  }\n\n  const verifySessionNew = async () => {\n\n  }\n\n  const verifySession = async (onlyToken, n = 0) => {\n    if (connection.current && !connection.current.offline) {\n      if (!onlyToken) {\n        try {\n          const token = await apims.post('/verifysession')\n          let data = token && token.data && token.data.user && token.data.user.language ? { locale: token.data.user.language } : { all: true }\n          if (window.location.hash === \"#tab/languages\")\n            data = { all: true }\n          const loadLanguages = await apims.post('/M_Languages_V3', data)\n\n          if (loadLanguages) {\n            let languages = await new Promise((resolve, reject) => {\n              let result = {}\n              loadLanguages.data.map((l, li) => {\n                result = {\n                  ...result,\n                  [l.alias.name.toLowerCase()]: {\n                    alias: l.alias.name.toLowerCase(),\n                    locales: l.locales\n                  }\n                }\n                if (li + 1 === loadLanguages.data.length)\n                  resolve(result)\n              })\n            })\n\n            if (token && token.data && token.data.token) {\n              localStorage.setItem('TOKEN', token.data.token)\n              props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n                ...token.data.user,\n                ...token?.data?.user?.GlobalData?.custom ? {\n                  custom: {\n                    ...session.custom,\n                    ...JSON.parse(token?.data?.user?.GlobalData?.custom),\n                    custom: token?.data?.user?.GlobalData?.custom,\n                    ...whiteLabel,\n                  }\n                } : {\n\n                }\n              })\n              props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                ...reduxStore.getState().db,\n                users: {\n                  ...token.data.users ? token.data.users : {}\n                }\n              })\n              if (languages && token) {\n                props.reduxFunction(\"ASYNC\", \"SET_LANGUAGE\", {\n                  ...languages\n                })\n                if (!auth || (\n                  auth\n                  && JSON.stringify(auth) !== JSON.stringify(token.data.user)\n                )) {\n                  if (JSON.stringify(auth) != JSON.stringify(token.data.user))\n                    setAuth({\n                      ...token.data.user,\n                    })\n                }\n                if (!(\"Notification\" in window)) {\n                  console.log('Esse browser não suporta notificações desktop')\n                } else {\n                  if (Notification.permission !== 'denied') {\n                    await Notification.requestPermission()\n                  }\n                }\n\n                if (window.location.pathname === '/' || routes.filter(prop => prop.auth && prop.path === window.location.pathname).length === 0)\n                  history.push('/d#tab/resume')\n                initSocket()\n                loadData()\n                return true\n              } else {\n                props.reduxFunction(\"ASYNC\", \"SET_LANGUAGE\", {\n                  ...languages\n                })\n                setAuth(false)\n              }\n            } else {\n              props.reduxFunction(\"ASYNC\", \"SET_LANGUAGE\", {\n                ...languages\n              })\n              if (loading) setLoading(false)\n            }\n          }\n        } catch (err) {\n          console.log(err)\n          if (n === 5) {\n            setOfflineDetected(true)\n            if (auth) setAuth(false)\n            if (loading) setLoading(false)\n            setTimeout(() => {\n              window.open(\"/login\", \"_self\")\n            }, 60000)\n          } else {\n            verifySession(onlyToken, n + 1)\n          }\n        }\n      } else {\n        try {\n          const token = await apims.post('/VerifySession', { ignoreUsers: true })\n\n          let actualTokenUser = reduxStore.getState().session\n          if (token && token.data && token.data.token) {\n            localStorage.setItem('TOKEN', token.data.token)\n            props.reduxFunction(\"ASYNC\", \"SET_SESSION\", {\n              ...token.data.user,\n              ...token?.data?.user?.GlobalData?.custom ? {\n                custom: {\n                  ...session.custom,\n                  ...JSON.parse(token?.data?.user?.GlobalData?.custom),\n                  custom: token?.data?.user?.GlobalData?.custom,\n                  ...whiteLabel,\n                }\n              } : {\n\n              }\n            })\n            const { socket } = reduxStore.getState().functions\n\n            socket.emit(\"socketStatus\", {\n              socketStatus: \"online\"\n            })\n            if (token.data && actualTokenUser && actualTokenUser._id && token.data.user && actualTokenUser._id !== token.data.user._id) {\n              window.location.reload()\n              return\n            }\n          } else {\n            localStorage.setItem('TOKEN', null)\n            props.reduxFunction(\"ASYNC\", \"CLEAR_SESSION\")\n            if (window.location.pathname !== '/login') {\n              setTimeout(() => {\n                window.open(\"/login\", \"_self\")\n              }, 300)\n            }\n          }\n        } catch (err) {\n          if (n > 5) {\n            localStorage.setItem('TOKEN', null)\n            props.reduxFunction(\"ASYNC\", \"CLEAR_SESSION\")\n            if (window.location.pathname !== '/login') {\n              setTimeout(() => {\n                window.open(\"/login\", \"_self\")\n              }, 300)\n            }\n          } else {\n            setTimeout(() => {\n              verifySession(onlyToken, n + 1)\n            }, 3000)\n          }\n        }\n      }\n    } else {\n      console.log(\"OFFLINE\")\n    }\n  }\n\n  const loadData = async () => {\n    loadUsers()\n    try {\n      let reqTagsA = await apims.get(`/Tags_List`)\n      if (reqTagsA && reqTagsA.data) {\n        reqTagsA.data.map(x => {\n          x._count = parseInt(x._count)\n          x._countOthers = parseInt(x._countOthers)\n        })\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n          ...reduxStore.getState().db,\n          tag: reqTagsA.data ? reqTagsA.data : []\n        })\n      }\n    } catch (e) {\n      console.group('Layout-ReqTags::ERR::')\n      console.log(e)\n      console.groupEnd()\n    }\n\n\n    //USERGROUPS\n    try {\n      let reqGroups = await apims.get(`/M_User_Group_List`)\n      if (reqGroups && reqGroups.data) {\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n          ...reduxStore.getState().db,\n          userGroup: reqGroups.data ? reqGroups.data : []\n        })\n      }\n    } catch (e) {\n      console.group('Layout-ReqGrpups::ERR::')\n      console.log(e)\n      console.groupEnd()\n    }\n  }\n\n  const loadUsers = async (id) => {\n    try {\n      let reqUsers = await apims.post(`/M_User_List_V3`, { id: id })\n      if (reqUsers && reqUsers.data) {\n        let users = {}\n        reqUsers.data.map(async (a, i) => {\n          users = {\n            ...users,\n            [a.data._id]: {\n              ...reduxStore.getState().db.users && reduxStore.getState().db.users[a.data._id] ? reduxStore.getState().db.users[a.data._id] : {},\n              ...a.data,\n              ...a.access ? { _access: JSON.parse(a.access) } : {},\n              ...a._safety ? { _safety: a._safety } : {},\n              ...a._token ? { _token: { _id: a._token } } : {},\n              ...a.groups && a.groups.filter(t => t.value).length > 0 ? { groups: a.groups } : {},\n              ...a.tags && a.tags.filter(t => t.value).length > 0 ? { tags: a.tags } : {},\n              ...a._parent && a._parent !== reduxStore.getState().session.account ? { _parent: a._parent } : {},\n            }\n          }\n        })\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n          ...reduxStore.getState().db,\n          users: {\n            ...reduxStore.getState().db.users,\n            ...users,\n          },\n        })\n        return true\n      }\n    } catch (e) {\n      console.group('Layout-ReqUsers::ERR::')\n      console.log(e)\n      console.groupEnd()\n    }\n  }\n\n\n  const initCompleted = async () => {\n    // let msgs = await loadMessages({ ini: true })\n    // if (msgs)\n    //   props.reduxFunction(\"ASYNC\", \"SET_CHATS\", msgs)\n\n    await loadCardsV2(props, { cardLoad: 'chat' })\n    await loadTimeline(\n      {\n        ...props,\n        fnIdentification: \"Layouts/Index/loadData()-Users\"\n      },\n      {\n        ids: [reduxStore.getState().session._id],\n        db: \"users\",\n        type: \"comment\",\n        ini: true,\n        limit: 1\n      }\n    )\n\n    await loadTimeline(\n      {\n        ...props,\n        fnIdentification: \"Layouts/Index/loadData()-Users\"\n      },\n      {\n        ids: [reduxStore.getState().session._id],\n        db: \"users\",\n        type: \"comment\",\n        ini: true,\n      }\n    )\n  }\n  const pageDataRequest = async (h, r = false) => {\n    if (auth && window.location.pathname !== '/' && window.location.pathname !== '/login' && props && props.reduxFunction) {\n      if (pageLoads && pageLoads.current && !pageLoads.current.initialLoader) {\n        pageLoads.current = {\n          initialLoader: true\n        }\n        await loadCardsV2({ ...props }, {\n          cardLoad: 'plans'\n        })\n        await loadCardsV2(props, {\n          cardLoad: 'myDay',\n        })\n        await loadCardsV2({ ...props }, {\n          cardLoad: 'chat',\n          ignoreLoader: true\n        })\n        await loadCardsV2({ ...props }, {\n          cardLoad: 'steps',\n          ignoreLoader: true\n        })\n        await loadCardsV2({ ...props }, {\n          cardLoad: 'approval',\n          ignoreLoader: true\n        })\n      }\n      const request = await pageLoadCards(props)\n      if (request) {\n        setLoading(false)\n\n        return true\n      }\n    } else {\n      return true\n    }\n  }\n\n  const handleDrawerToggle = () => {\n    // setMobileOpen(!mobileOpen)\n  }\n\n  const openChat = async (nodeId, dbProps) => {\n    props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n      ...chat,\n      open: true,\n      db: dbProps,\n      nodeId: nodeId,\n      loading: false,\n    })\n  }\n\n  const initSocket = async () => {\n    let newSocket = await socketIOClient(API_WS, {\n      transports: ['websocket', 'polling'],\n      query: { token: localStorage.getItem('TOKEN') }\n    })\n    if (newSocket) {\n      socketFunctions(newSocket)\n      props.reduxFunction(\"ASYNC\", \"SET_FUNCTIONS\", {\n        socket: newSocket\n      })\n\n    }\n    return true\n  }\n\n  const authCallBack = async (d) => {\n    if (d.fn === 'login') {\n      localStorage.setItem('TOKEN', d.token)\n      setTimeout(() => {\n        window.open(\"/d#tab/resume\", \"_self\")\n      }, 1000)\n    } else if (d.fn === 'alert') {\n      appAlert({\n        ...d\n      })\n    }\n  }\n  const getAuthRoutes = routes => {\n    return routes.map((prop, key) => {\n      if (prop.views) {\n        return getAuthRoutes(prop.views)\n      }\n      let CompRender\n      CompRender = prop.component\n      if (!prop.auth && CompRender) {\n        return (\n          <Route\n            path={prop.path}\n            component={() => <CompRender callback={(d) => { authCallBack(d) }} />}\n            key={key}\n          />\n        )\n      }\n    })\n  }\n\n\n  const getRoutes = (routes) => {\n    const session = auth\n    return routes.map((prop, key) => {\n      if (prop.auth && (\n        !prop.AppAccess\n        || (\n          prop\n          && prop.AppAccess\n          && session\n          && session._access\n        )\n      )\n      ) {\n        let CompRender\n        CompRender = prop.component\n\n        let access = !prop.access && !prop.AppAccess ? true : false\n\n        if (prop.access) {\n          prop.access.map(x => {\n            if (session && session[x])\n              access = true\n          })\n        }\n        if (prop.AppAccess) {\n          prop.AppAccess.map(x => {\n            if (session && session._access && session._access[x])\n              access = true\n          })\n        }\n        if (access)\n          return (\n            prop.views && prop.views.length > 0 && getRoutes(prop.views),\n            <Route\n              path={prop.path}\n              component={() => <CompRender />}\n              key={key}\n              expanded={expanded}\n              subMenu={props.subMenu ? true : false}\n            />\n          )\n      }\n    })\n  }\n\n  /**LOAD DATA */\n\n  const logout = async (sk) => {\n    localStorage.setItem('TOKEN', null)\n    props.reduxFunction(\"ASYNC\", \"CLEAR_SESSION\")\n    setTimeout(() => {\n      window.open(\"/login\", \"_self\")\n    }, 300)\n  }\n\n  // const appRoutes = getRoutes(routes)\n\n  const socketFunctions = (socket) => {\n    //VERSION\n    socket.on('global', data => {\n      if (data.fn === 'version') {\n        appAlert({\n          message: translate(`$__appNewVersionAvaiable`, 1),\n          hideiconvariant: true,\n          variant: 'info',\n          persist: true,\n          horizontal: 'right',\n          confirm: () => {\n            window.location.reload()\n          },\n          // cancelHide: true\n        })\n      }\n      if (data.fn === 'logout') {\n        logout()\n      }\n      if (data.fn === 'reload') {\n        window.location.reload()\n      }\n    })\n\n    //MATRIX\n    socket.on('SWOT.UPD', data => {\n      dbUpdateCardSWOT({\n        ...props,\n        store: reduxStore.getState(),\n        _sessionId: session._id,\n      }, data)\n    })\n\n    //CARDS\n    socket.on('copy.LOAD', data => {\n      console.log(\"copy.LOAD\", data)\n      //childrens\n      loadCardsV2({ ...props, ignoreLoader: true }, { cardLoad: 'childrens', idRel: data._id })\n    })\n    socket.on('card.ADD', data => {\n      // console.log('card.ADD::622', data)\n      if (data._id)\n        loadCardsV2({ ...props, ignoreLoader: true }, { cardLoad: 'card', idRel: data._id })\n    })\n    socket.on('card.UPD', data => {\n      // console.log('card.UPD::627', data)\n      dbUpdateCard(props, data)\n    })\n\n    socket.on('card.MYDAY', data => {\n      myDayUpd(props, data)\n    })\n\n    socket.on('card.TIMER', data => {\n      // console.log(data)\n      dbUpdateCardTimer(props, data)\n    })\n\n\n    socket.on('card.UPDATE', data => {\n      // console.log('card.UPDATE::632', data)\n      dbUpdateCard_V2(props, data)\n    })\n\n\n    socket.on('card.ACCESS_UPD', async data => {\n      cardAccessUpdate(props, data)\n    })\n\n    socket.on('card.ACCESS_DELETE', data => {\n      cardAccessDelete(props, data)\n    })\n\n    socket.on('card.ACCESS_REMOVE', data => {\n      cardAccessRemove(props, data)\n    })\n\n    socket.on('card.REORDER', data => {\n      // console.log('card.REORDER::646', data)\n      reorderCard(props, data)\n    })\n    socket.on('card.DELETE', data => {\n      // console.log('card.DELETE::650', data)\n      deleteCard(props, data, true)\n    })\n    socket.on('card.unlinkChildrens', data => {\n      // console.log('card.unlinkChildrens::654', data)\n      socketUnLinkChildrens(props, data)\n    })\n\n    socket.on('unlinkChildrens', data => {\n      socketUnLinkChildrens(props, data)\n    })\n\n    socket.on('card.changePlanId', data => {\n      // console.log('card.changePlanId::659', data)\n      let planId = window.location.hash.split(\"/\")\n      planId[0] = planId[0].replace(\"#\", \"\")\n\n      let loads = reduxStore.getState().sessionLoads.cards.load\n      let reqMd5 = MD5(`${JSON.stringify({\n        idRel: planId[0],\n        cardLoad: 'plan',\n      })}`).toString()\n\n\n      if (\n        planId[0] === data.planId\n        || (\n          Object.keys(loads).length > 0 && loads[reqMd5]\n        )\n      ) {\n        loadCardsV2({ ...props, ignoreLoader: true }, { cardLoad: 'plan', idRel: data.cardId, force: true })\n      } else {\n        changePlanId(props, data)\n      }\n    })\n\n    //GENERIC ACTIONS BY NODE\n    socket.on('node.UPDATE', data => {\n      // console.log('node.UPDATE::684', data)\n      nodeUpdate(props, data)\n    })\n\n\n    //COLUMNS\n    socket.on(`column.UPD`, data => {\n      // console.log('node.UPD::690', data)\n      updateColumnCards(props, data)\n    })\n    socket.on(`column.DELETE`, data => {\n      // console.log('column.DELETE::694', data)\n      deleteColumn(props, data)\n    })\n    socket.on(`column.REORDER`, data => {\n      // console.log('column.REORDER::698', data)\n      reorderColumns(props, data)\n    })\n    socket.on(`column.CARDS`, data => {\n      // console.log('column.CARDS::702', data)\n      columnCards(props, data)\n    })\n\n    //TIMELINE\n    let timelineTyping = {}\n\n    socket.on(`timeline.TYPING`, data => {\n      // console.log('timeline.TYPING::710', data)\n      if (timelineTyping[data.typingUser])\n        clearTimeout(timelineTyping[data.typingUser])\n\n\n      // if (\n      //   reduxStore.getState().chat\n      //   && reduxStore.getState().chat.typing\n      //   && (\n      //     !reduxStore.getState().chat.typing[data.group ? data.group : \"me\"]\n      //     || (\n      //       reduxStore.getState().chat.typing[data.group ? data.group : \"me\"]\n      //       &&\n      //       !reduxStore.getState().chat.typing[data.group ? data.group : \"me\"][data.typingUser]\n      //     )\n      //   )\n      // )\n      // props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n      //   ...reduxStore.getState().chat,\n      //   // typing: {\n      //   //   ...reduxStore.getState().chat.typing,\n      //   //   [data.group ? data.group : \"me\"]: {\n      //   //     ...reduxStore.getState().chat.typing[data.group ? data.group : \"me\"],\n      //   //     [data.typingUser]: true\n      //   //   }\n      //   // }\n      // })\n\n      timelineTyping = {\n        ...timelineTyping,\n        [data.typingUser]: setTimeout(() => {\n          // props.reduxFunction(\"ASYNC\", \"SET_CHAT\", {\n          //   ...reduxStore.getState().chat,\n          //   // typing: {\n          //   //   ...reduxStore.getState().chat.typing,\n          //   //   [data.group ? data.group : \"me\"]: {\n          //   //     ...reduxStore.getState().chat.typing[data.group ? data.group : \"me\"],\n          //   //     [data.typingUser]: false\n          //   //   }\n          //   // }\n          // })\n        }, 3000)\n      }\n    })\n\n    socket.on(`timeline.COMMENT`, async data => {\n      if (\n        (\n          data.db === 'users'\n          && data.idRel === reduxStore.getState().session._id\n          && data.comment\n          && data.comment.user\n          && data.comment.user._id\n          && !reduxStore.getState().db.users[data.comment.user._id]\n        )\n      ) loadUsers(data.comment.user._id)\n\n      if (\n        (\n          data.db === 'users'\n          || (\n            data.db !== 'users'\n            && reduxStore.getState().db.cards[data.idRel]\n            && reduxStore.getState().db.cards[data.idRel].type === 'chatGroup'\n          )\n        )\n      ) {\n        let lastDate = null\n        if (data.filesCount && data.files && data.files.length === data.filesCount)\n          lastDate = parseInt(data.comment.created_at) - 30\n\n        if (data.comment.user._id !== reduxStore.getState().session._id)\n          verifyMessages(lastDate)\n      }\n\n      timelineComment(props, data)\n\n\n\n      if (\n        reduxStore.getState().chat.notifications\n        && (\n          data.idRel === reduxStore.getState().session._id\n          ||\n          reduxStore.getState().db.users[data.idRel]\n          ||\n          (\n            reduxStore.getState().db.cards[data.idRel]\n            && reduxStore.getState().db.cards[data.idRel].type === 'chatGroup'\n          )\n        )\n        && reduxStore.getState().db.users[data.comment.user._id]\n      ) {\n        if (data?.comment?.user?._id !== reduxStore.getState().session._id) {\n          audio.play()\n        }\n        data.comment.nodeId = data.nodeId\n        let comment = {\n          ...data.comment,\n          nodeId: data.comment._parent,\n          idRel: data.nodeId\n        }\n        if (data._parent === reduxStore.getState().session._id) {\n          const notification = new Notification(`${data.comment.user.name} ${translate(`$__sendedANewMessage`, 1)}`, {\n            body: data.comment.message ? data.comment.message : translate(`$__${data.comment.type}`, 1)\n          })\n\n          notification.onclick = (e) => {\n            e.preventDefault()\n            window.focus()\n            notification.close()\n          }\n          appAlert({\n            message: translate(`$__newMessage`, 1),\n            content: (\n              <div\n                style={{ display: 'flex', cursor: 'pointer', backgroundColor: \"#none\" }}\n                onClick={(e) => {\n                  openChat(comment.user._id, 'users')\n                  e.stopPropagation()\n                }\n                }\n              >\n                <Message\n                  storie={comment}\n                  noReactions\n                  inverted\n                />\n              </div>\n            ),\n            hideiconvariant: true,\n            variant: 'info',\n            persist: false,\n            horizontal: 'right',\n            confirm: null\n          })\n        }\n      }\n    })\n    socket.on(`timeline.DEL`, data => {\n      // console.log('timeline.DEL::822', data)\n      const { timeline, session } = reduxStore.getState()\n      let idRel = reduxStore.getState().timeline[data.idRel] &&\n        reduxStore.getState().timeline[data.idRel][data.id] ?\n        data.idRel :\n        session._id\n\n      if (\n        reduxStore.getState().timeline\n        && reduxStore.getState().timeline[idRel]\n        && reduxStore.getState().timeline[idRel][data.id]\n      )\n        props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", {\n          ...reduxStore.getState().timeline,\n          [idRel]: {\n            ...reduxStore.getState().timeline[idRel],\n            [data.id]: {\n              ...reduxStore.getState().timeline[idRel][data.id],\n              deleted: true,\n              ...data.deletedReason ? { deletedReason: data.deletedReason } : {}\n            }\n          }\n        })\n    })\n\n    //USERS\n    socket.on(`user.UPD`, data => {\n      dbUpdateUser(props, data)\n    })\n\n    socket.on('user.CONNECT', data => {\n      props.reduxFunction(\"ASYNC\", \"SET_USERS_STATUS\", {\n        users: {\n          ...reduxStore.getState().usersStatus.users,\n          [data.user]: {\n            status: data.status,\n            updatedAt: data.updatedAt\n          }\n        },\n      })\n    })\n    socket.on('user.DISCONNECT', data => {\n      props.reduxFunction(\"ASYNC\", \"SET_USERS_STATUS\", {\n        users: {\n          ...reduxStore.getState().usersStatus.users,\n          [data.user]: null\n        },\n      })\n    })\n    socket.on('users.STATUS', data => {\n      props.reduxFunction(\"ASYNC\", \"SET_USERS_STATUS\", {\n        ...reduxStore.getState().usersStatus,\n        users: {\n          ...data.users\n        }\n      })\n    })\n\n    socket.on(`user.ACCESS`, data => {\n      // console.log('user.ACCESS::892', data)\n      dbUpdateUser(props, data)\n    })\n    socket.on(\"userGroup.UPD\", data => {\n      // console.log('userGroup.UPD::896', data)\n      tagUpdate(props, data, true)\n    })\n\n    //FEEDS\n    socket.on(`feed.ADD`, data => {\n      // console.log('feed.ADD::902', data)\n      dbUpdateFeed(props, data)\n    })\n\n    //LANGUAGES\n    socket.on('language.UPD', data => {\n      // console.log('LANGUAGE.UPD::908', data)\n      languageUPD(props, data)\n    })\n\n    //TAGS\n    socket.on(\"tag.UPD\", data => {\n      // console.log('tag.UPD::914', data)\n      tagUpdate(props, data, true)\n    })\n    socket.on(\"tag.DEL\", data => {\n      // console.log('tag.DEL::918', data)\n      localTagDelete(props, data, true)\n    })\n\n    socket.on(\"tag.UNLINK\", data => {\n      // console.log('tag.UNLINK::923', data)\n      localTagUnlink(props, data, true)\n    })\n\n\n    //LOGOUT\n    socket.on(\"logout\", data => {\n      // console.log('logout::930', data)\n      if (\n        data.user === reduxStore.getState().session._id\n      ) {\n        logout()\n      }\n    })\n\n    //NOTIFICATIONS\n    socket.on(\"notifications.ADD\", async data => {\n      // console.log('notifications.ADD::940', data)\n      if (reduxStore.getState().session._id === data.userId && data.notify) {\n        props.reduxFunction(\"ASYNC\", \"SET_NOTIFICATIONS\", {\n          ...reduxStore.getState().notifications,\n          [data.notify._id]: data.notify,\n        })\n      }\n    })\n\n\n    //CHAT\n    socket.on(\"chat.STATUS\", data => {\n\n      // console.log('chat.STATUS::953', data)\n      props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        users: {\n          ...reduxStore.getState().db.users,\n          [data.user]: {\n            ...reduxStore.getState().db.users[data.user],\n            chatStatus: data.status\n          }\n        }\n      })\n    })\n    socket.on(\"chat.READED\", data => {\n\n      if (reduxStore.getState().db.cards[data.id] || reduxStore.getState().db.users[data.id] || reduxStore.getState().db.users[data.readedBy]) {\n        chatReaded(props, data)\n      }\n    })\n    socket.on(\"chat.INTERACT\", data => {\n      // console.log('chat.INTERACT', data)\n      interact(props, data)\n      if (reduxStore.getState().db.cards[data.id] || reduxStore.getState().db.users[data.id] || reduxStore.getState().db.users[data.readedBy]) {\n      }\n    })\n    let backdropTimer = setTimeout(() => {\n\n    }, 5000)\n    socket.on(\"disconnect\", () => {\n      connection.current = {\n        offline: true\n      }\n      backdropTimer = setTimeout(() => {\n        setBackdropEnabled(true)\n      }, 5000)\n    })\n    socket.on(\"connect\", () => {\n      setTimeout(() => {\n        socket.emit(\"data\", {\n          module: \"user\",\n          method: \"post\",\n          action: \"logout\"\n        },\n          {\n            notThis: true\n          })\n      }, 2000)\n      if (connection?.current?.offline) {\n        connection.current = {\n          offline: false\n        }\n        verifyMessages()\n      }\n      verifySession(true)\n      clearTimeout(backdropTimer)\n      setBackdropEnabled(false)\n    })\n  }\n\n  if (loading || !appRoutes) {\n    return (\n      <div style={{\n        position: 'fixed',\n        top: '0px',\n        bottom: '0px',\n        left: '0px',\n        right: '0px'\n      }}>\n        <LoaderPage />\n      </div>\n    )\n  }\n\n  if (offlineDetected && window.location.pathname !== '/offline-detect') {\n    history.push('offline-detect')\n  }\n\n  if (maintenance && window.location.pathname !== '/maintenance-mode') {\n    history.push('maintenance-mode')\n  }\n\n  if (!maintenance && !offlineDetected && (window.location.pathname === '/maintenance-mode' || window.location.pathname === '/offline-detect')) {\n    history.push('login')\n  }\n\n  const steps = [\n    {\n      selector: '#wellcome',\n      content: 'Seja bem vindo à MACHEN',\n    },\n    {\n      selector: '#sideBar',\n      content: 'Menu de navegação',\n    },\n    {\n      selector: '#chatNotificationsBt',\n      content: 'Aqui você será notificado sempre que receber alguma mensagem',\n    },\n    {\n      selector: '#notificationsBt',\n      content: 'Aqui você encontra suas notificações de atividades na plataforma',\n    },\n    {\n      selector: '#sideBar_button_StrategyAndPlans',\n      content: `Vamos cadastrar um plano?<n>????</n>`,\n    },\n  ]\n\n\n\n  return (\n    <div style={{\n      position: 'fixed',\n      top: '0px',\n      bottom: '0px',\n      left: auth && expanded ? `calc(198px + ${subMenuExpanded ? `264px` : `0px`})` : '0px',\n      right: '0px'\n    }}\n      onContextMenu={() => {\n        // console.log('GENERAL MENU')\n      }}\n    >\n      {auth ? (\n        <React.Fragment>\n          <div className={classes.wrapper} >\n            <Hidden xsDown>\n              {expanded &&\n                <Sidebar\n                  routes={routes}\n                  handleDrawerToggle={handleDrawerToggle}\n                  menuExpand={() => { setExpanded(prev => !prev) }}\n                  setSubMenuExpanded={(a) => { setSubMenuExpanded(a) }}\n                  subMenuExpanded={subMenuExpanded}\n                  {...rest}\n                />\n              }\n            </Hidden>\n            <Hidden smUp>\n              <MobileNav\n                routes={routes}\n                handleDrawerToggle={handleDrawerToggle}\n                menuExpand={() => { setExpanded(prev => !prev) }}\n                setSubMenuExpanded={(a) => { setSubMenuExpanded(a) }}\n                subMenuExpanded={subMenuExpanded}\n                expanded={expanded}\n                {...rest}\n              />\n            </Hidden>\n            <div className={mainPanelClasses} ref={mainPanel} id=\"mainPannel\">\n              <div className={classes.content}>\n                <div className={classes.container}>\n                  <Switch>\n                    {appRoutes}\n                    <Redirect from=\"/\" to=\"/d#tab/resume\" />\n                  </Switch>\n                </div>\n              </div>\n            </div>\n            <ErrorBoundary>\n              <KanbanModal />\n            </ErrorBoundary>\n            <ErrorBoundary>\n              <SideModule />\n            </ErrorBoundary>\n          </div>\n          <Hidden smDown>\n            <TopHeader menuExpand={() => { setExpanded(prev => !prev) }} expanded={expanded} />\n          </Hidden>\n          <ErrorBoundary>\n            <LightBox />\n          </ErrorBoundary>\n          <MiroBoard />\n          {/* <Notifier /> */}\n          <ErrorBoundary>\n            <LicensingAgreement />\n          </ErrorBoundary>\n          <ErrorBoundary>\n            <Backdrop open={backdropEnabled} className={classes.backdrop}\n              style={{\n                backdropFilter: \"blur(7px) sepia(90%)\",\n              }}\n            >\n              <div style={{\n                position: 'absolute',\n                left: '0px',\n                right: '0px',\n                top: '0px',\n                bottom: '0px',\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center',\n                color: '#FFFFFF',\n                fontSize: '33px',\n                flexDirection: 'column'\n              }}>\n                <div style={{\n                  width: '100%',\n                  display: 'flex',\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                }}>\n                  <Icon color={'ColumnTitleColor'} size=\"77px\">cloud_off</Icon>\n                </div>\n                <div style={{\n                  width: '100%',\n                  display: 'flex',\n                  alignItems: 'center',\n                  justifyContent: 'center',\n                  marginTop: '15px'\n                }}>\n                  {translate('$__noInternetConnection', '*')}\n                </div>\n              </div>\n            </Backdrop>\n          </ErrorBoundary>\n          <div>\n            {/* NOTICE: id must be unique between EVERY <ContextMenuTrigger> and <ContextMenu> pair */}\n            {/* NOTICE: inside the pair, <ContextMenuTrigger> and <ContextMenu> must have the same id */}\n\n            {/* <ContextMenuTrigger id=\"same_unique_identifier\">\n          <div className=\"well\">Right click to see the menu</div>\n          </ContextMenuTrigger>\n          \n          <ContextMenu id=\"same_unique_identifier\">\n          <MenuItem data={{ foo: 'bar' }} onClick={this.handleClick}>\n          ContextMenu Item 1\n          </MenuItem>\n          <MenuItem data={{ foo: 'bar' }} onClick={this.handleClick}>\n            ContextMenu Item 2\n          </MenuItem>\n          <MenuItem divider />\n          <MenuItem data={{ foo: 'bar' }} onClick={this.handleClick}>\n            ContextMenu Item 3\n          </MenuItem>\n        </ContextMenu> */}\n\n          </div>\n          <ErrorBoundary>\n            <Chat expanded={expanded} subMenuExpanded={subMenuExpanded} />\n          </ErrorBoundary>\n          {/* <Tour\n        steps={steps}\n        isOpen={tour}\n        onRequestClose={() => setTour(false)} /> */}\n\n          <ErrorBoundary>\n            <CardActions />\n          </ErrorBoundary>\n          <ErrorBoundary>\n            <PolicyAndTerms />\n          </ErrorBoundary>\n        </React.Fragment>\n        // </TourProvider>\n      ) : (\n        <div>\n          {!maintenance &&\n            <AuthNavbar {...rest} />\n          }\n          <div className={classes.wrapper} ref={wrapper}>\n            <div\n              className={classes.fullPage}\n              style={{\n                backgroundImage: `url(\"${whiteLabel?.loginBackground ? whiteLabel.loginBackground : customApp(\"loginBackground\")}\")`\n              }}\n            >\n              <Switch>\n                {getAuthRoutes(routes)}\n                <Redirect from=\"*\" to={offlineDetected ? '/offline-detect' : maintenance ? '/maintenance-mode' : '/login'} />\n              </Switch>\n              <Footer white />\n\n            </div>\n          </div>\n        </div>\n      )\n      }\n\n      <ErrorBoundary>\n        <StyledContainer pauseOnFocusLoss />\n      </ErrorBoundary>\n    </div >\n  )\n}\n\nconst StyledContainer = styled(ToastContainer)`\n&&&.Toastify__toast-container {\n  min-width:407px !important;\n  z-index:33333;\n}\n.Toastify__toast {\n  z - index:33333;\n  }\n.Toastify__toast-body {\n  z - index:33333;\n  }\n.Toastify__progress-bar { }\n`;\n\nconst mapStateToProps = () => ({})\n\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\nexport default connect(mapStateToProps,\n  mapDispatchToProps\n)(SaasHome)","import React from \"react\";\r\nimport { Router, Route } from \"react-router-dom\";\r\n// import { SnackbarProvider } from 'notistack';\r\n\r\n\r\nimport PropTypes from 'prop-types';\r\n\r\n// REDUX\r\nimport { Provider } from 'react-redux';\r\n\r\nimport Layout from \"layouts/index.js\";\r\n\r\nimport \"assets/scss/material-dashboard-pro-react.scss?v=1.8.0\";\r\n\r\nconst Root = ({ store, history }) => (\r\n    <Provider store={store}>\r\n        <Router history={history}>\r\n            <Route exact patch=\"/:params\" component={Layout} />\r\n        </Router>\r\n    </Provider>\r\n);\r\n\r\nRoot.propTypes = {\r\n    store: PropTypes.object.isRequired\r\n};\r\n\r\n\r\nexport default Root;\r\n","import React from 'react';\nimport { render } from 'react-dom';\nimport history from 'store/history';\nimport store from 'store/index.js';\nimport Root from './root.js';\n\n\nrequire('dotenv').config()\n\nif (window.location.hostname.indexOf('192.168') === -1\n  && window.location.hostname.indexOf('localhost') === -1\n  && window.location.hostname.indexOf('hom2022.machen') === -1\n  && window.location.hostname.indexOf('homologation.machen') === -1\n  && window.location.hostname.indexOf('a1b2c3d4.machen') === -1\n  && window.location.hostname.indexOf('sonne.machen') === -1\n)\n  console.log = () => { }\n\nrender(\n  <Root store={store} history={history} />,\n  document.getElementById('root'),\n);\n","import {\r\n    defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = {\r\n    tags: {\r\n        ...defaultFont,\r\n        position: 'absolute',\r\n        width: '100%',\r\n        right: '0px',\r\n        bottom: '-6px',\r\n        userSelect: \"none\",\r\n        height: '6px',\r\n        marginBottom: '0px',\r\n        display: 'flex',\r\n        justifyContent: 'flex-end',\r\n        overflow: 'hidden',\r\n        \"& .tag\": {\r\n            width: '15px',\r\n            marginRight: '3px',\r\n            cursor: 'pointer',\r\n            height: '6px',\r\n            borderRadius: ' 0px 0px 3px 3px',\r\n        }\r\n    },\r\n\r\n    tagsOver: {\r\n        ...defaultFont,\r\n        position: 'relative',\r\n        width: '100%',\r\n        userSelect: \"none\",\r\n        marginTop: '5px',\r\n        marginBottom: '5px',\r\n        height: 'auto',\r\n        overflow: 'hidden',\r\n        // maxWidth: '77%',\r\n        \"& .tag\": {\r\n            fontSize: '12px',\r\n            padding: '0 5px',\r\n            margin: '3px',\r\n            borderRadius: ' 5px',\r\n            color: customApp('light')\r\n        }\r\n    }\r\n}\r\n\r\nexport default style;","import styles from \"assets/jss/material-dashboard-pro-react/components/Tags.js\";\nimport React from 'react'\n\n//REDUX\nimport reduxStore from \"store/\";\n\n//COMPONENTS\nimport Icon from \"components/Icon\";\nimport ColorPicker from \"components/ColorPicker\";\n\n//@MATERIAL\nimport IconButton from '@material-ui/core/IconButton';\nimport Tooltip from \"@material-ui/core/Tooltip\";\nimport { makeStyles } from \"@material-ui/core/styles\";\n\n//FUNCTIONS\nimport { customApp, translate, textColor } from \"functions/\";\n\nconst useStyles = makeStyles(styles);\n\nfunction CardTags(props) {\n    const classes = useStyles();\n    const [ShowOptions, setShowTags] = React.useState(props.showOptions ? true : false)\n    const [showHiddenButton, setshowHiddenButton] = React.useState(false)\n    const [options, setOptions] = React.useState([])\n\n    React.useEffect(() => {\n        setOptions(reduxStore.getState().db[props.dbNode ? props.dbNode : 'tag'])\n        return () => {\n            setOptions([])\n            setshowHiddenButton(false)\n        }\n    }, [props.options])\n\n    return (\n        <React.Fragment>\n            <div className={(ShowOptions || props.expanded) ? classes.tagsOver : classes.tags}\n                onClick={\n                    (e) => {\n                        if (props.options && props.options.length > 0 && !ShowOptions) {\n                            setShowTags(true)\n                        }\n                        e.stopPropagation()\n                    }\n                }\n                onMouseOver={() => {\n                    setshowHiddenButton(true)\n                }}\n                onMouseLeave={() => {\n                    setTimeout(() => {\n                        setshowHiddenButton(false)\n                    }, 500)\n                }}\n\n            >\n                {options && options.length > 0 && props.options &&\n                    props.options\n                        .filter(tg => tg.value)\n                        .map((tg, i) => {\n                            let t = tg\n                            if (reduxStore.getState().db.tag.filter(a => a.value === tg.value).length > 0) {\n                                t = reduxStore.getState().db.tag.filter(a => a.value === tg.value)[0]\n                                let color = options.filter(a => a.value === t.value).length > 0 && options.filter(a => a.value === t.value)[0].color ? options.filter(a => a.value === t.value)[0].color : customApp('medium')\n                                return (\n                                    <div\n                                        key={i}\n                                        className={'tag'}\n                                        style={{\n                                            position: 'relative',\n                                            float: 'left',\n                                            whiteSpace: 'nowrap',\n                                            backgroundColor: color,\n                                            ...props.rounded ? { borderRadius: \"7px !important\" } : {}\n                                        }}\n                                        onClick={() => {\n                                            if (!props.colorPicker && !props.showOptions)\n                                                setShowTags(false)\n                                        }}\n                                    >\n                                        {(!props.showOptions && ShowOptions && props.colorPicker) ?\n                                            <ColorPicker\n                                                label={t.label}\n                                                color={color}\n                                                _id={t.value}\n                                                onChange={(c) => {\n                                                    let newTag = t\n                                                    newTag.color = c\n                                                    reduxStore.getState().functions.socket.emit('tag.UPD', newTag)\n                                                }\n                                                }\n                                            />\n                                            :\n                                            (ShowOptions || props.expanded) &&\n                                            <div\n                                                className={'tag'}\n                                                style={{\n                                                    backgroundColor: color,\n                                                    color: t.color ? textColor(t.color, true) : '#FFFFFF',\n                                                    display: \"flex\", alignItems: \"center\",\n                                                    ...props.rounded ? { borderRadius: \"7px !important\" } : {}\n                                                }}\n                                            >\n                                                {t.parent && reduxStore.getState().db.tag.filter(tt => tt.value === t.parent).length > 0 ?\n                                                    <div\n                                                        style={{\n                                                            fontSize: 8,\n                                                            marginRight: 3\n                                                        }}\n                                                    >{reduxStore.getState().db.tag.filter(tt => tt.value === t.parent)[0].label} / </div>\n                                                    : <React.Fragment></React.Fragment>}\n                                                {t.label}\n                                            </div>\n                                        }\n                                    </div>\n                                )\n                            }\n                        })}\n                {!props.showOptions && ShowOptions && !props.expanded && showHiddenButton &&\n                    <div style={{ position: 'absolute', top: '0', right: '0' }}>\n                        <Tooltip\n                            title={translate(`$__hideTags`)}\n                        >\n                            <React.Fragment>\n                                <IconButton\n                                    onClick={(e) => {\n                                        if (!props.showOptions)\n                                            setShowTags(false)\n                                    }}\n                                >\n                                    <Icon\n                                        size={\"22px\"}\n                                        color={customApp('medium')}\n                                        icon={'visibility_off'}\n                                    />\n                                </IconButton>\n                            </React.Fragment>\n                        </Tooltip>\n                    </div>\n                }\n            </div>\n        </React.Fragment>\n    )\n}\n\nexport default CardTags","import React from \"react\"\n\n//COMPONENTS\nimport Icon from \"components/Icon/\"\nimport CircularProgress from \"components/Progress/circular\"\nimport Tooltip from \"components/Tooltip/html\"\n\n//@MATERIAL\nimport IconButton from \"@material-ui/core/IconButton\"\nimport Button from \"@material-ui/core/Button\"\nimport Badge from '@material-ui/core/Badge'\nimport { makeStyles } from \"@material-ui/core/styles\"\n\n//FUNCTIONS\nimport {\n    customApp,\n    translate\n} from \"functions/\"\n\nconst useStyles = makeStyles((props) => ({\n    root: {\n        \"& .MuiIconButton-root\": {\n            padding: \"3px\",\n            fontSize: \"none !important\",\n        }\n    },\n    iconButtonStyleTransaparent: {\n        padding: \"3px\",\n        margin: 0,\n        \"&:hover\": {\n            backgroundColor: \"rgba(250,250,250,0.2)\"\n        }\n    },\n    iconButtonStyleWhite: {\n        padding: \"3px !important\",\n        margin: 0,\n        backgroundColor: \"#FFFFFF\",\n        \"&:hover\": {\n            backgroundColor: \"rgba(250,250,250,0.9)\"\n        },\n    },\n    shadow: {\n        boxShadow: \"0 0px 5px rgb(0 0 0 / 20%)\"\n    },\n    iconText: {\n        display: \"flex\",\n        alignItens: \"center\",\n    },\n    iconText_Text: {\n        marginLeft: \"15px\"\n    },\n    badge: {\n        fontSize: '11px',\n        whiteSpace: \"nowrap\"\n    }\n}))\n\nfunction CustomButtom(props, ref) {\n    const classes = useStyles()\n\n    return (\n        <div className={classes.root} style={{ ...props.style ? props.style : {} }}>\n            <Tooltip\n                title={props.title ? props.title : \"INSERT_BUTTON_TITLE\"}\n            >\n                <div style={{ display: \"flex\", alignItems: \"center\", paddingLeft: 7, paddingRight: 7 }}>\n                    {props.text &&\n                        <Button\n                            disabled={props.load ? true : props.disabled ? true : false}\n                            onClick={props.onClick ? (e) => {\n                                e.preventDefault()\n                                e.stopPropagation()\n                                props.onClick()\n                            } : null}\n                            {...props.shadow ? {\n                                className: `${!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}` + ` ` + classes.shadow,\n                            } : {\n                                className: `${!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}`,\n                            }}\n                            {...props.buttonStyle ? { style: props.buttonStyle } : {}}\n                        >\n                            <div className={classes.iconText}>\n                                {props.load ?\n                                    <div>\n                                        <CircularProgress size={25} style={{ margin: \"auto\", display: \"flex\" }} />\n                                        <span style={{ marginLeft: \"15px\", color: \"lightgray\" }}>{props.loadText ? props.loadText : translate(\"$__saving\")}</span>\n                                    </div>\n                                    :\n                                    <div style={{ display: \"flex\", alignItems: \"center\" }}>\n                                        {props.icon ?\n                                            <Badge\n                                                overlap=\"rectangular\"\n                                                badgeContent={props.badgeContent}\n                                                classes={{ badge: classes.badge }}\n                                                color=\"secondary\"\n                                            >\n                                                <Icon\n                                                    usePropagation={props.usePropagation ? true : false}\n                                                    size={props.size ? props.size : \"22px\"}\n                                                    color={props.color ? props.color : customApp(\"menu\")}\n                                                    icon={props.icon ? props.icon : \"help_outline\"} />\n                                            </Badge>\n                                            : <React.Fragment></React.Fragment>\n                                        }\n                                        <span style={{ ...props.textSize ? { fontSize: props.textSize } : {}, marginLeft: \"5px\", color: props.textColor ? props.textColor : props.color ? props.color : customApp(\"menu\") }}>{props.text}</span>\n                                    </div>\n                                }\n\n                            </div>\n                        </Button>\n                    }\n                    {!props.text &&\n                        <IconButton\n                            onClick={props.onClick ? (e) => {\n                                props.onClick()\n                                e.preventDefault()\n                                e.stopPropagation()\n\n                            } : null}\n                            className={!props.transparent ? classes.iconButtonStyleWhite : classes.iconButtonStyleTransaparent}\n                        >\n                            <Badge\n                                badgeContent={props.badgeContent}\n                                color=\"secondary\"\n                                classes={{ badge: classes.badge }}\n                                overlap=\"rectangular\"\n                            >\n                                <Icon\n                                    usePropagation={props.usePropagation ? true : false}\n                                    size={props.size ? props.size : \"22px\"}\n                                    color={props.color ? props.color : customApp(\"menu\")}\n                                    icon={props.icon ? props.icon : \"help_outline\"} />\n                            </Badge>\n                        </IconButton>\n                    }\n                </div>\n            </Tooltip>\n        </div>\n    )\n}\n\nexport default CustomButtom\n","//REDUX\nimport reduxStore from \"store/\"\nimport MD5 from \"crypto-js/md5\"\n\n//FUNCTIONS\nimport api from \"api\"\nimport apims from \"apims\"\nimport { upload } from \"functions/upload.js\"\nimport moment from \"moment-timezone\"\n\nimport { loadCardsV2 } from \"./loadData\"\nimport session from \"store/db\"\n\nimport { removeSeats } from \"./index\"\nimport { v4 as uuid } from \"uuid\"\n\nimport { appAlert, translate } from \"./index\"\n\n\nconst saveCard_V2 = async (props, data) => {\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n    if (hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n    // console.log(data)\n}\n\nconst saveCard = async (props, close = false, data, idRel = null) => {\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n    if (hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n    let newData = { ...data }\n    const oldData = newData._id ? { ...reduxStore.getState().db['cards'][newData._id] } : {}\n    let file = null\n\n    if (newData.order && String(newData.order.low))\n        newData.order = newData.order.low\n\n    if (newData.type === 'chatGroup' && newData._planId) {\n        delete newData._planId\n        delete newData._parent\n        delete newData.idRel\n    }\n\n    Object.keys(newData).map(f => {\n        if (f === 'file') {\n            file = newData[f]\n            delete newData.file\n        }\n        if ((newData[f] && newData[f].low) || (newData[f] && newData[f].low && String(newData[f].low) === '0'))\n            newData[f] = newData[f].low\n        return newData\n    })\n\n    if (!newData._id || (newData._id && newData._id.length !== 36)) {\n        if (idRel) {\n            newData.idRel = idRel\n            newData._parent = idRel\n            if (reduxStore.getState().db.cards[idRel].type === \"plan\") {\n                newData._planId = idRel\n            }\n            if (reduxStore.getState().db.cards[idRel].type !== \"plan\" && reduxStore.getState().db.cards[idRel]._planId) {\n                newData._planId = reduxStore.getState().db.cards[idRel]._planId\n            }\n            // console.log(newData)\n        } else {\n            if (window.location.pathname.indexOf('sp') > -1 && !newData._parent)\n                newData._parent = newData._parent ? newData._parent : hashs[0] ? hashs[0] : null\n            if (newData._parent)\n                newData.idRel = idRel ? idRel : newData._parent\n            if (window.location.pathname.indexOf('sp') > -1 && hashs[0] && hashs[0].length === 36)\n                newData._planId = hashs[0]\n            // console.log(newData)\n        }\n\n        const responseAdd = await addCard(props, {\n            ...newData,\n            oldData: oldData,\n        }, file, close)\n        return responseAdd\n    } else {\n        const responseUPd = await updateCard(props, {\n            ...newData,\n            oldData: oldData,\n        }, file, close)\n\n        //Save ASPECTS\n        if (newData\n            && newData.type\n            && newData.type.indexOf('guideline') > -1\n            && newData.type !== 'guideline'\n            && Object.keys(reduxStore.getState().db.cards).filter(a =>\n                (\n                    reduxStore.getState().db.cards[a]._planId === hashs[0]\n                    || reduxStore.getState().db.cards[a]._parent === hashs[0]\n                )\n                && reduxStore.getState().db.cards[a]._selected === true\n            ).length > 0)\n            await saveMATRIX(newData._id)\n\n        return responseUPd\n    }\n}\n\nconst kpiTimerStart = async (props, cardId) => {\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n\n    const response = await api.post(\"timer/start\", {\n        idRel: cardId,\n        startTime: moment().unix(\"X\")\n    })\n\n    if (response) {\n        return response.data\n    }\n}\n\nconst kpiTimerStop = async (props, cardId) => {\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n    const response = await api.put(\"timer/stop\", {\n        idRel: cardId,\n    })\n\n    if (response) {\n        return response.data\n    }\n}\nconst kpiTimerDelete = async (props, cardId, timerId) => {\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n    const response = await api.delete(`timer/run/${timerId}`, {\n        idRel: cardId,\n    })\n\n    let kpiTimer = reduxStore.getState().db.cards[cardId]._kpiTimer\n    if (kpiTimer[timerId])\n        delete kpiTimer[timerId]\n\n    if (response) {\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [cardId]: {\n                    ...reduxStore.getState().db.cards[cardId],\n                    _kpiTimer: kpiTimer\n                }\n            }\n        })\n        // socket.emit('card.TimerDelete', {\n        //     cardId,\n        //     timerId,\n        // })\n        return true\n    }\n}\n\nconst saveMATRIX = async (props) => {\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n    let id = Object.keys(reduxStore.getState().db.cards).filter(a => {\n        if (\n            (\n                reduxStore.getState().db.cards[a]._planId === hashs[0]\n                || reduxStore.getState().db.cards[a]._parent === hashs[0]\n            )\n            && reduxStore.getState().db.cards[a]._selected === true\n            && reduxStore.getState().db.cards[a].type\n            && reduxStore.getState().db.cards[a].type.indexOf('guideline') > -1) {\n            return true\n        }\n    })[0]\n    let aspects = Object.keys(reduxStore.getState().db.cards).filter(a =>\n        (\n            reduxStore.getState().db.cards[a]._planId === hashs[0]\n            || reduxStore.getState().db.cards[a]._parent === hashs[0]\n        )\n        && reduxStore.getState().db.cards[a]._selected === true\n        && reduxStore.getState().db.cards[a].type\n        && reduxStore.getState().db.cards[a].type.indexOf('guideline') === -1\n    )\n    api.put(\"matrix/aspects\", {\n        _id: id,\n        _parent: hashs[0],\n        aspects: aspects\n    })\n    if (props && props.reduxFunction)\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [id]: {\n                    ...reduxStore.getState().db.cards[id],\n                    _aspects: aspects\n                }\n            }\n        })\n    return true\n}\n\nconst addCard = async (props, newData, file, close = false) => {\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n    const { dataType } = reduxStore.getState().db\n    const { session, db } = reduxStore.getState()\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n\n    const response = new Promise(async (resolve, reject) => {\n        try {\n            let action = 'add'\n            if (newData.type === 'myTask' || newData.type === 'chatGroup') {\n                newData.myTask = true\n            }\n            if (!newData.status)\n                newData.status = \"notStarted\"\n            socket.emit(\"data\", {\n                module: \"cards\",\n                method: \"post\",\n                action\n            }, newData, async (response) => {\n                newData._users = {\n                    [session._id]: {\n                        name: db.users[session._id].name ? db.users[session._id].name : null,\n                        displayName: db.users[session._id].displayName ? db.users[session._id].displayName : null,\n                        image: db.users[session._id].image ? db.users[session._id].image : null,\n                        access: 5,\n                        _id: session._id\n                    }\n                }\n\n                if (newData.type && newData.type.indexOf('guideline') > -1)\n                    await saveMATRIX(response.id)\n\n                if (newData.myTask)\n                    delete newData.myTask\n\n                newData._loaded = true\n                newData._loadTimeline = true\n                if (response.id) {\n                    if (!close)\n                        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n                            ...reduxStore.getState().sideModule,\n                            id: response.id,\n                            data: {\n                                ...reduxStore.getState().sideModule.data,\n                                ...newData,\n                                _id: response.id,\n                            }\n                        })\n\n                    newData._id = response.id\n\n                    if (parseInt(newData.order) >= 0)\n                        newData.order = { low: newData.order }\n\n                    newData = {\n                        ...newData,\n                        ...response.data,\n                    }\n                    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                        ...reduxStore.getState().db,\n                        cards: {\n                            ...reduxStore.getState().db.cards,\n                            [newData._id]: {\n                                ...newData,\n                                //_loaded: true,\n                                created_at: moment().tz('America/Sao_Paulo').unix('x'),\n                                updated_at: {\n                                    low: moment().tz('America/Sao_Paulo').unix('x')\n                                },\n                            },\n                        }\n                    })\n                    timelineAdd(props, newData._id, {\n                        [response.log._id]: {\n                            ...response.log,\n                            _parent: newData._id,\n                        }\n                    })\n                    if (file) {\n                        updateCard(props, {\n                            ...newData,\n                        }, file, close)\n                    } else if ((hashs[0] === 'tab' && hashs[1] === 'myDay')) {\n                        setMyDay(props, { _id: response.id, userId: session._id, option: true }, {\n                            new: true,\n                            user: session._id,\n                            cardId: newData._id,\n                            cardData: {\n                                ...newData,\n                            },\n                        })\n                        timelineAdd(props, newData._id, {\n                            [response.log._id]: {\n                                ...response.log,\n                                _parent: newData._id,\n                            }\n                        })\n                    }\n                }\n                resolve({\n                    ...newData,\n                    //_loaded: true,\n                    created_at: moment().tz('America/Sao_Paulo').unix('x'),\n                    updated_at: {\n                        low: moment().tz('America/Sao_Paulo').unix('x')\n                    },\n                })\n            })\n        } catch (e) {\n            console.log(e)\n        }\n    })\n\n    const result = await response\n    return result\n}\n\nconst massUpdate = async (props, data) => {\n    if (data.ids.length > 0) {\n        let socket\n        if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n            socket = reduxStore.getState().functions.socket\n        } else {\n            socket = reduxStore.getState().functions.socket\n        }\n        socket.emit(\"data\", {\n            module: \"cards\",\n            method: \"put\",\n            action: \"massUpdate\"\n        }, data, async (response) => {\n            let cards = reduxStore.getState().db.cards\n            data.ids.map(async id => {\n                cards[id] = {\n                    ...cards[id],\n                    ...data.data,\n                }\n                if (response.log)\n                    await timelineAdd(props, id, {\n                        [uuid()]: {\n                            ...response.log,\n                            _parent: [id],\n                        }\n                    })\n            })\n\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                ...reduxStore.getState().db,\n                cards: {\n                    ...reduxStore.getState().cards,\n                    ...cards,\n                }\n            })\n        })\n    }\n}\nconst updateCard = async (props, nData, file) => {\n    let newData = {\n        ...nData,\n    }\n    let imageResult\n\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n\n    if (file) {\n        imageResult = await upload(newData._id, file)\n        newData.image = imageResult\n    }\n    if (!file || (file && imageResult)) {\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [newData._id]: {\n                    ...reduxStore.getState().db.cards[newData._id],\n                    ...newData,\n                    _users: {\n                        ...reduxStore.getState().db.cards[newData._id]._users,\n                    }\n                }\n            }\n        })\n        socket.emit(\"data\", {\n            module: \"cards\",\n            method: \"put\",\n            action: \"update220527\"\n        }, newData, async (response) => {\n            if (newData.order && parseInt(newData.order) >= 0)\n                newData.order = { low: newData.order }\n\n            if (response && response.log && response.log._id)\n                timelineAdd(props, newData._id, {\n                    [response.log._id]: {\n                        ...response.log,\n                        _parent: [newData._id],\n                    }\n                })\n            const { db } = reduxStore.getState()\n            if (\n                newData.type\n                && newData._id\n                && newData.type.indexOf('guideline') > -1\n                && newData.type !== 'guideline'\n                && Object.keys(db.cards).filter(card =>\n                    db.cards[card]._parent === newData._id\n                    && db.dataType.filter(a => a.name === db.cards[card].type && a.module === 'swot').length > 0\n                )\n            ) {\n                await saveMATRIX(newData._id)\n            }\n        })\n    }\n    return true\n}\n\nconst timelineAdd = (props, nodeId, data) => {\n    let newTimeline = reduxStore.getState().timeline[nodeId] ? reduxStore.getState().timeline[nodeId] : {}\n    newTimeline = {\n        ...newTimeline,\n        ...data\n    }\n    props.reduxFunction(\"ASYNC\", \"SET_TIMELINE\", {\n        ...reduxStore.getState().timeline,\n        [nodeId]: newTimeline\n    })\n}\n\nconst restoreCard = async (props, data) => {\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n    socket.emit(\"data\", {\n        module: \"cards\",\n        method: \"put\",\n        action: \"restore\"\n    }, {\n        _id: data._id,\n    }, async (response) => {\n        dbCardsDelete(props, {\n            cardId: data._id,\n        }, false)\n    })\n}\n\nconst deleteCard = async (props, data, onlyRedux, childrensDelete = false) => {\n    let { db } = reduxStore.getState()\n    if (!onlyRedux) {\n        let socket\n        if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n            socket = reduxStore.getState().functions.socket\n        } else {\n            socket = reduxStore.getState().functions.socket\n        }\n        socket.emit(\"data\", {\n            module: \"cards\",\n            method: \"put\",\n            action: \"delete\"\n        }, {\n            _id: data._id,\n            deleted: true,\n            childrensDelete,\n            client: db.cards[data._id] && db.cards[data._id].client ? db.cards[data._id].client : db.cards[data._id] && db.cards[data._id]._planId && db.cards[db.cards[data._id]._planId] && db.cards[db.cards[data._id]._planId].client ? db.cards[db.cards[data._id]._planId].client : null\n        }, async (response) => {\n            dbCardsDelete(props, {\n                cardId: data._id,\n                childrens: childrensDelete\n            }, true)\n        })\n    } else {\n        dbCardsDelete(props, {\n            cardId: data._id,\n            childrens: data.childrensDelete\n        }, true)\n    }\n}\n\nconst dbCardsDelete = (props, data, deleted = false) => {\n    let cards = { ...reduxStore.getState().db.cards }\n    cards[data.cardId] = {\n        ...cards[data.cardId],\n        deleted: deleted,\n        ...cards[data.cardId] && cards[data.cardId]._selected ? { _selected: false } : {}\n    }\n    if (data.childrens) {\n        let childrens = getChildrens(data.cardId)\n        Object.keys(childrens).map(c => {\n            cards[c] = {\n                ...cards[c],\n                deleted: deleted,\n            }\n        })\n    }\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: {\n            ...reduxStore.getState().db.cards,\n            ...cards\n        }\n    })\n}\nconst dbUpdateCardSWOT = (props, data) => {\n    if (reduxStore.getState().db.cards[data._id] && !reduxStore.getState().db.cards[data._id]._selected && data && data._selected) {\n        delete data._selected\n    }\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: {\n            ...reduxStore.getState().db.cards,\n            [data._id]: {\n                ...reduxStore.getState().db.cards[data._id],\n                _aspects: data.aspects,\n            }\n        }\n    })\n    props.reduxFunction(\"ASYNC\", \"preLoader\", {\n        ...reduxStore.getState().preLoader,\n        autoSave: true,\n    })\n}\nexport const dbUpdateCard = async (props, data) => {\n    let forceUpdate = {}\n    let card = await new Promise(async (resolve, reject) => {\n        if (data && data.cardData && data.cardData._parent && !reduxStore.getState().db.cards[data.cardData._parent]) {\n            const lp = await loadCardsV2(props, {\n                idRel: data.cardData._parent,\n                cardLoad: \"fullCatenation\",\n                ignoreLoader: true\n            })\n            if (lp && lp[data.cardData._parent])\n                forceUpdate = {\n                    _requireApproval: lp[data.cardData._parent].requireApproval ? true : null\n                }\n        } else if (data?.cardData?._parent && reduxStore.getState().db.cards[data.cardData._parent]) {\n            let cardParent = reduxStore.getState().db.cards[data.cardData._parent]\n            forceUpdate = {\n                _requireApproval: !cardParent.requireApproval ? null : true\n            }\n        }\n        if (!reduxStore.getState().db.cards[data.cardId]) {\n            const loadNewCard = await loadCardsV2(props, {\n                idRel: data.cardId,\n                cardLoad: \"fullCatenation\",\n                ignoreLoader: true\n            })\n            if (loadNewCard && loadNewCard.cards && loadNewCard.cards[data.cardId]) {\n                resolve(loadNewCard.cards[data.cardId])\n            }\n        } else {\n            resolve(reduxStore.getState().db.cards[data.cardId])\n        }\n\n    })\n    if (card) {\n        let newTags = reduxStore.getState().db.tag\n        if (reduxStore.getState().db.cards && card) {\n            if (data.cardData && data.cardData._tags && data.cardData._tags.length > 0) {\n                data.cardData._tags.map(tag => {\n                    if (card\n                        && card._tags\n                        && card._tags.filter(fil => fil.value === tag.value).length === 0\n                    )\n                        newTags.filter(fil => fil.value === tag.value).map(a => {\n                            a.count = a.count + 1\n                        })\n                })\n            }\n            if (card._tags) {\n                card._tags.map(tag => {\n                    if (data.cardData._tags && data.cardData._tags.filter(fil => fil.value === tag.value).length === 0)\n                        newTags.filter(fil => fil.value === tag.value).map(a => {\n                            a.count = a.count - 1\n                        })\n                })\n            }\n        }\n\n        if (\n            !data.new\n            ||\n            (\n                data.new\n                && data.user !== session._id\n            )) {\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                ...reduxStore.getState().db,\n                cards: {\n                    ...reduxStore.getState().db.cards,\n                    [data.cardId]: {\n                        ...card ? card : {},\n                        ...data.cardData,\n                        _notifications: reduxStore.getState().db.cards && card && card._notifications ? card._notifications : {\n                            comment: 0,\n                            log: 0,\n                            timer: 0,\n                            kpi: 0\n                        },\n                        createdBy: data.user ? data.user : null,\n                        ...forceUpdate,\n                    }\n                },\n                tag: newTags\n            })\n        }\n    }\n}\n\nconst dbUpdateCardTimer = (props, data) => {\n    let card = reduxStore.getState().db.cards[data.cardId] || null\n    if (card) {\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [data.cardId]: {\n                    ...card,\n                    _kpiTimer: data._kpiTimer\n                }\n            },\n        })\n    }\n}\n\nconst dbUpdateCard_V2 = async (props, data) => {\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: {\n            ...reduxStore.getState().db.cards,\n            [data._id]: {\n                ...reduxStore.getState().db.cards[data._id] ? reduxStore.getState().db.cards[data._id] : {},\n                ...data\n            }\n        },\n    })\n}\n\nconst selectSWOT = async (props, idCard) => {\n    const { db } = reduxStore.getState()\n    const { cards } = db\n    let selectedCard = cards[idCard]\n\n    let hashs = window.location.hash.split('/')\n    hashs[0] = hashs[0].replace('#', '')\n    if (hashs[0].length !== 36) {\n        hashs[0] = null\n    }\n\n    let activeCards = {}\n\n    Object.keys(db.cards).filter(a =>\n        db.cards[a]\n        && !db.cards[a].deleted\n        && (\n            db.cards[a]._planId === hashs[0]\n            || db.cards[a]._parent === hashs[0]\n        )\n    ).map(a => {\n        activeCards = {\n            ...activeCards,\n            [a]: db.cards[a]\n        }\n    })\n\n    Object.keys(activeCards).map(card => {\n        if (activeCards[card]\n            && activeCards[card].type\n            && activeCards[card].type.indexOf('guideline') === -1\n            && activeCards[card].type.indexOf('objective') === -1\n            && activeCards[card].type.indexOf('goal') === -1\n        ) {\n            activeCards[card] = {\n                ...activeCards[card],\n                _selected: false\n            }\n        }\n    })\n    if (selectedCard && selectedCard._aspects && selectedCard._aspects.length > 0) {\n        selectedCard._aspects.map(as => {\n            if (activeCards[as])\n                activeCards[as] = {\n                    ...activeCards[as],\n                    _selected: true\n                }\n        })\n    }\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: {\n            ...cards,\n            ...activeCards\n        }\n    })\n}\n\nconst updateColumnCards = (props, data) => {\n    if (reduxStore.getState().db.cards[data._cardColumn]) {\n        let columnData = {\n            ...reduxStore.getState().db.cards[data._cardColumn].boards[data._board].columns[data._columnId],\n            ...data._columnData,\n        }\n        let columnOrder = [...reduxStore.getState().db.cards[data._cardColumn].boards[data._board].columnOrder]\n        if (data._columnsOrder)\n            columnOrder = data._columnsOrder\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [data._cardColumn]: {\n                    ...reduxStore.getState().db.cards[data._cardColumn],\n                    boards: {\n                        ...reduxStore.getState().db.cards[data._cardColumn].boards,\n                        [data._board]: {\n                            ...reduxStore.getState().db.cards[data._cardColumn].boards[data._board],\n                            columnOrder,\n                            columns: {\n                                ...reduxStore.getState().db.cards[data._cardColumn].boards[data._board].columns,\n                                [data._columnId]: columnData\n                            }\n                        }\n                    }\n                }\n            }\n        })\n    }\n    selectSWOT(props)\n}\n\nconst deleteColumn = (props, data) => {\n    if (reduxStore.getState().db.cards[data._parent]) {\n        let columnOrder = [...reduxStore.getState().db.cards[data._parent].boards[data._board].columnOrder]\n        let columns = { ...reduxStore.getState().db.cards[data._parent].boards[data._board].columns }\n\n        delete columns[data._deleted]\n        columnOrder.splice(columnOrder.indexOf(data._deleted), 1)\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [data._parent]: {\n                    ...reduxStore.getState().db.cards[data._parent],\n                    boards: {\n                        ...reduxStore.getState().db.cards[data._parent].boards,\n                        [data._board]: {\n                            ...reduxStore.getState().db.cards[data._parent].boards[data._board],\n                            columnOrder,\n                            columns\n                        }\n                    }\n                }\n            }\n        })\n    }\n}\n\nconst reorderCard = (props, data) => {\n    let cards = reduxStore.getState().db.cards\n    let cardsToReorder = data.cards\n    if (cardsToReorder && cardsToReorder.length > 0) {\n        cardsToReorder.map((a, i) => {\n            cards = {\n                ...cards,\n                [a]: {\n                    ...cards[a],\n                    order: `${i + 1}`\n                }\n            }\n        })\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                ...cards\n            }\n        })\n    }\n    return\n}\n\nconst reorderColumns = (props, data) => {\n    if (reduxStore.getState().db.cards[data._parent]) {\n        let columnOrder = data._order\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [data._parent]: {\n                    ...reduxStore.getState().db.cards[data._parent],\n                    boards: {\n                        ...reduxStore.getState().db.cards[data._parent].boards,\n                        [data._board]: {\n                            ...reduxStore.getState().db.cards[data._parent].boards[data._board],\n                            columnOrder,\n                        }\n                    }\n                }\n            }\n        })\n    }\n    return\n}\n\nconst columnCards = (props, data) => {\n    const { db } = reduxStore.getState()\n    const newState = {\n        [data.cardId]: {\n            ...db.cards[data.cardId],\n            boards: {\n                ...db.cards[data.cardId].boards,\n                [data.boardId]: {\n                    ...db.cards[data.cardId].boards[data.boardId],\n                    columns: data.columns\n                }\n            }\n        }\n    }\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...db,\n        cards: {\n            ...db.cards,\n            ...newState\n        }\n    })\n    return\n}\n\nconst localAddCard = async (props, data, newCard) => {\n\n    let user = {\n        ...reduxStore.getState().db.cards[data._id] && reduxStore.getState().db.cards[data._id]._users && reduxStore.getState().db.cards[data._id]._users[data.userId] ? reduxStore.getState().db.cards[data._id]._users[data.userId] : {},\n        ...newCard && newCard.data && newCard.data._users && newCard.data._users[data.userId] ? newCard.data._users[data.userId] : {},\n        myDay: !data.checklist && data.option ? createDate : null\n    }\n\n    let createDate = moment().tz('America/Sao_Paulo').unix('x')\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: {\n            ...reduxStore.getState().db.cards,\n            [data._id]: {\n                ...newCard && newCard.data ? newCard.data : {},\n                ...reduxStore.getState().db.cards[data._id],\n                _users: {\n                    ...reduxStore.getState().db.cards[data._id] && reduxStore.getState().db.cards[data._id]._users ? reduxStore.getState().db.cards[data._id]._users : {},\n                    ...newCard && newCard.data && newCard.data._users ? newCard.data._users : {},\n                    [data.userId]: user\n                },\n            }\n        }\n    })\n}\n\nconst myDayUpd = async (props, data) => {\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: {\n            ...reduxStore.getState().db.cards,\n            [data._id]: {\n                ...reduxStore.getState().db.cards[data._id],\n                _users: {\n                    ...reduxStore.getState().db.cards[data._id] && reduxStore.getState().db.cards[data._id]._users ? reduxStore.getState().db.cards[data._id]._users : {},\n                    [data.userId]: {\n                        ...reduxStore.getState().db.cards[data._id] && reduxStore.getState().db.cards[data._id]._users && reduxStore.getState().db.cards[data._id]._users[data.userId] ? reduxStore.getState().db.cards[data._id]._users[data.userId] : {},\n                        myDay: data.option ? data.createDate : null,\n                    }\n                }\n            }\n        }\n    })\n}\n\nconst setMyDay = async (props, data, newCard) => {\n\n    let createDate = moment().unix('x')\n    localAddCard(props, data, newCard)\n\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n\n\n    socket.emit(\"data\", {\n        module: \"cards\",\n        method: \"post\",\n        action: \"setMyDay\"\n    }, {\n        ...data,\n        createDate: createDate\n    })\n\n    if (reduxStore.getState().sideModule.id && reduxStore.getState().sideModule.id === data._id)\n        props.reduxFunction(\"ASYNC\", \"SET_MODULE\", {\n            ...reduxStore.getState().sideModule,\n            data: {\n                ...reduxStore.getState().sideModule.data ? reduxStore.getState().sideModule.data : {},\n                _users: {\n                    ...reduxStore.getState().db.cards[data._id] && reduxStore.getState().db.cards[data._id]._users ? reduxStore.getState().db.cards[data._id]._users : {},\n                    [data.userId]: {\n                        ...reduxStore.getState().db.cards[data._id] && reduxStore.getState().db.cards[data._id]._users && reduxStore.getState().db.cards[data._id]._users[data.userId] ? reduxStore.getState().db.cards[data._id]._users[data.userId] : {},\n                        myDay: data.option ? createDate : null\n                    }\n                }\n            }\n        })\n}\n\nconst cardCopyTo = async (props, data) => {\n\n}\n\nconst cardMoveTo = async (props, data) => {\n    try {\n        const response = await api.put('/cards/moveTo', {\n            ...data\n        })\n\n        if (response) {\n            changePlanId(props, data)\n            return true\n        }\n    } catch (e) {\n        appAlert({\n            message: `${translate(\"$__tryAgainOrContactSupport\", 1)}. ERROR: cMoveTo->API~887`,\n            variant: 'error',\n            persist: false,\n            horizontal: \"right\",\n        })\n    }\n}\n\nconst changePlanId = async (props, data) => {\n    let cards = reduxStore.getState().db.cards\n    let changeId = await new Promise(async (resolve, reject) => {\n        let rcc = await reqChildrenCards(data.cardId)\n        if (rcc && rcc.length > 0) {\n            rcc.map((c, ci) => {\n                if (cards[c]) {\n                    cards[c] = {\n                        ...cards[c],\n                        _planId: data.planId\n                    }\n                }\n                if (ci + 1 === rcc.length)\n                    resolve(true)\n            })\n        } else {\n            resolve(true)\n        }\n\n    })\n\n    if (changeId) {\n        if (cards[data.cardId])\n            cards[data.cardId] = {\n                ...cards[data.cardId],\n                _parent: data.newRel,\n                _planId: data.planId\n            }\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                ...cards\n            }\n        })\n    }\n}\n\nconst cardAccessUpdate = async (props, data) => {\n    // ;.log(data)\n    if (!reduxStore.getState().db.cards[data.cardId]) {\n        const loadNewCard = await loadCardsV2(props, {\n            idRel: data.cardId,\n            cardLoad: \"fullCatenation\",\n            ignoreLoader: true\n        })\n        if (loadNewCard) {\n            let users = reduxStore.getState().db.cards[data.cardId] && reduxStore.getState().db.cards[data.cardId]._users ? reduxStore.getState().db.cards[data.cardId]._users : {}\n            if (data.isResponsible)\n                Object.keys(users).map(u => {\n                    if (u !== data.userId && users[u].isResponsible)\n                        delete users[u].isResponsible\n                })\n\n            let newCard = reduxStore.getState().db.cards[data.cardId] ? reduxStore.getState().db.cards[data.cardId] : {}\n            if (loadNewCard && loadNewCard.cards && loadNewCard.cards[data.cardId])\n                newCard = loadNewCard.cards[data.cardId]\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                ...reduxStore.getState().db,\n                cards: {\n                    ...reduxStore.getState().db.cards,\n                    [data.cardId]: {\n                        ...newCard,\n                        _users: {\n                            ...users,\n                            [data.userId]: {\n                                ...data.userData ? data.userData : {},\n                                ...reduxStore.getState().db.users && reduxStore.getState().db.users[data.userId] ? reduxStore.getState().db.users[data.userId] : {},\n                                ...newCard && newCard._users && newCard._users[data.userId] ? newCard._users[data.userId] : {},\n                                ...data.isResponsible ? { isResponsible: true } : {},\n                                ...String(data.approvalResponsible) ? { approvalResponsible: data.approvalResponsible } : { approvalResponsible: data.approvalResponsible },\n                                ...data.access ? { access: data.access } : {},\n                            }\n                        }\n                    }\n                }\n            })\n        }\n    } else {\n        let users = reduxStore.getState().db.cards[data.cardId] && reduxStore.getState().db.cards[data.cardId]._users ? reduxStore.getState().db.cards[data.cardId]._users : {}\n        if (data.isResponsible)\n            Object.keys(users).map(u => {\n                if (u !== data.userId && users[u].isResponsible)\n                    delete users[u].isResponsible\n            })\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [data.cardId]: {\n                    ...reduxStore.getState().db.cards[data.cardId] ? reduxStore.getState().db.cards[data.cardId] : {},\n                    _users: {\n                        ...users,\n                        [data.userId]: {\n                            ...reduxStore.getState().db.cards[data.cardId] && reduxStore.getState().db.cards[data.cardId]._users && reduxStore.getState().db.cards[data.cardId]._users[data.userId] ? reduxStore.getState().db.cards[data.cardId]._users[data.userId] : {},\n                            ...users[data.userId] ? users[data.userId] : {},\n                            ...data.userData ? data.userData : {},\n                            ...data.isResponsible ? { isResponsible: true } : {},\n                            ...String(data.approvalResponsible) ? { approvalResponsible: data.approvalResponsible } : { approvalResponsible: data.approvalResponsible },\n                            ...data.access ? { access: data.access } : {},\n                        }\n                    }\n                }\n            }\n        })\n    }\n}\n\nconst cardAccessDelete = (props, data) => {\n    if (!reduxStore.getState().db.cards[data.cardId]) {\n        return true\n    } else {\n        let newCard = { ...reduxStore.getState().db.cards[data.cardId] }\n        if (newCard._users[data.userId])\n            delete newCard._users[data.userId]\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [data.cardId]: {\n                    ...newCard,\n                }\n            }\n        })\n    }\n}\nconst cardAccessRemove = (props, data) => {\n    if (!reduxStore.getState().db.cards[data.cardId]) {\n        return true\n    } else {\n        let newCard = { ...reduxStore.getState().db.cards[data.cardId] }\n        if (data.userIds && data.userIds.length > 0)\n            data.userIds.map(userId => {\n                if (newCard._users[userId])\n                    delete newCard._users[userId]\n            })\n\n\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n            ...reduxStore.getState().db,\n            cards: {\n                ...reduxStore.getState().db.cards,\n                [data.cardId]: {\n                    ...newCard,\n                }\n            }\n        })\n    }\n}\n\nconst unlinkChildrens = async (props, data) => {\n    try {\n        api.put(\"cards/unlinkChildrens\", {\n            cardId: data.cardId,\n            planId: data._planId\n        })\n        // socketUnLinkChildrens(props, {\n        //     cardId: data.cardId,\n        //     planId: data._planId\n        // })\n    } catch (e) {\n        console.log(e)\n    }\n    return true\n}\nconst socketUnLinkChildrens = async (props, data) => {\n    let cards = reduxStore.getState().db.cards\n    Object.keys(cards).filter(card =>\n        cards[card]._parent === data.cardId\n        && cards[card].type !== \"step\"\n        && (\n            !cards[card].checklist\n            ||\n            (\n                cards[card].checklist\n                && cards[card].showCard\n            )\n        )).map(card => {\n            cards[card]._parent = data.planId\n        }\n        )\n    if (data.cards && data.cards.length > 0)\n        data.cards.map(cardId => {\n            if (cards[cardId])\n                cards[cardId] = {\n                    ...cards[cardId],\n                    _parent: data.planId\n                }\n        })\n\n    if (cards && cards[data.cardId])\n        cards[data.cardId] = {\n            ...cards[data.cardId],\n            _parent: data.planId\n        }\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: cards\n    })\n}\n\nconst getCardColor = (data, children) => {\n    let color = data && data.color ? data.color : null\n    let parent = data.color && children ? true : false\n    if (data._parent && reduxStore.getState().db.cards[data._parent]) {\n        let parentColor = getCardColor(reduxStore.getState().db.cards[data._parent], true)\n        if (parentColor.color)\n            return parentColor\n    }\n    return {\n        parent,\n        color,\n        parentId: data.color ? data._id : null\n    }\n}\nconst getCardParents = (parent) => {\n    let parents = []\n    if (parent && reduxStore.getState().db.cards[parent]) {\n        let req = getCardParents(parent)\n        req.map(x => {\n            if (parents.indexOf(x) === -1)\n                parents.push(x)\n        })\n        if (parents.indexOf(parent) === -1)\n            parents.push(parent)\n    }\n    return parents\n}\nconst connectInMount = (parentId) => {\n    const { db, session } = reduxStore.getState()\n    let parent = reduxStore.getState().db.cards[parentId]\n    if (reduxStore.getState().db.cards[parentId]) {\n        let result = {}\n        if (\n            !reduxStore.getState().db.cards[parentId].private\n            ||\n            (\n                reduxStore.getState().db.cards[parentId].private\n                && reduxStore.getState().db.cards[parentId]._users\n                && reduxStore.getState().db.cards[parentId]._users[session._id]\n            )\n        )\n            result = {\n                [parentId]: {\n                    _id: parent._id,\n                    type: parent.type,\n                    name: parent.name,\n                    icon: parent.type && db && db.dataType ? db.dataType.filter(a => a.name === parent.type)[0].icon : \"topic\",\n                },\n            }\n        if (parent._parent) {\n            result = { ...connectInMount(parent._parent), ...result }\n        }\n        return result\n    } else {\n        return {}\n    }\n}\n\nconst linkCard = async (props, data) => {\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n    socket.emit(\"data\", {\n        module: \"cards\",\n        method: \"put\",\n        action: \"link\"\n    }, data, async (response) => {\n    })\n}\n\nconst sortList = (a, b) => {\n    if (reduxStore.getState().db.orderByTitle\n        && reduxStore.getState().db.orderByTitlePosition === 'ASC') {\n        if (removeSeats(a.name.toLowerCase().trim()) < removeSeats(b.name.toLowerCase().trim()))\n            return -1\n        if (removeSeats(a.name.toLowerCase().trim()) > removeSeats(b.name.toLowerCase().trim()))\n            return 1\n        return 0\n    }\n    if (reduxStore.getState().db.orderByTitle\n        && reduxStore.getState().db.orderByTitlePosition === 'DESC') {\n        if (removeSeats(a.name.toLowerCase().trim()) < removeSeats(b.name.toLowerCase().trim()))\n            return 1\n        if (removeSeats(a.name.toLowerCase().trim()) > removeSeats(b.name.toLowerCase().trim()))\n            return -1\n        return 0\n    }\n    if (reduxStore.getState().db.orderByTitle) {\n        return 0\n    } else if (\n        !reduxStore.getState().db.orderByTitle\n        && a.order\n        && b.order\n        && a.order.low\n        && b.order.low\n        && String(a.order)\n        && String(b.order)\n        && String(a.order.low)\n        && String(b.order.low)\n        && parseInt(a.order.low) < parseInt(b.order.low)\n    ) {\n        return -1\n    } else if (\n        !reduxStore.getState().db.orderByTitle\n        && a.order\n        && b.order\n        && String(a.order)\n        && String(b.order)\n        && a.order.low\n        && b.order.low\n        && String(a.order.low)\n        && String(b.order.low)\n        && parseInt(a.order.low) > parseInt(b.order.low)\n    ) {\n        return 1\n    } else {\n        return 0\n    }\n}\n\nconst getUserAccess = (id) => {\n    const { db, session } = reduxStore.getState()\n    let data = { ...db.cards[id] }\n    if (db.cards[id]) {\n        let cardAccess = 0\n        if (data\n            && data._users\n            && Object.keys(data._users).length > 0\n            && data._users[Object.keys(data._users).find(a => a.indexOf(session._id) > -1)]\n            && data._users[Object.keys(data._users).find(a => a.indexOf(session._id) > -1)].access) {\n            cardAccess = parseInt(data._users[Object.keys(data._users).find(a => a.indexOf(session._id) > -1)].access)\n        }\n\n        if (data && data._parent && db.cards[data._parent]\n            && db.cards[data._parent]._users\n            && Object.keys(db.cards[data._parent]._users).length > 0\n            && db.cards[data._parent]._users[Object.keys(db.cards[data._parent]._users).find(a => a.indexOf(session._id) > -1)]\n            && db.cards[data._parent]._users[Object.keys(db.cards[data._parent]._users).find(a => a.indexOf(session._id) > -1)].access\n            && parseInt(db.cards[data._parent]._users[Object.keys(db.cards[data._parent]._users).find(a => a.indexOf(session._id) > -1)].access) > parseInt(cardAccess)\n        ) {\n            cardAccess = parseInt(db.cards[data._parent]._users[Object.keys(db.cards[data._parent]._users).find(a => a.indexOf(session._id) > -1)].access)\n        }\n\n        if (\n            db.cards[id]._planId\n            && db.cards[db.cards[id]._planId]\n            && db.cards[db.cards[id]._planId]._users\n            && Object.keys(db.cards[db.cards[id]._planId]._users).length > 0\n            && db.cards[db.cards[id]._planId]._users[Object.keys(db.cards[db.cards[id]._planId]._users).find(a => a.indexOf(session._id) > -1)]\n            && parseInt(db.cards[db.cards[id]._planId]._users[Object.keys(db.cards[db.cards[id]._planId]._users).find(a => a.indexOf(session._id) > -1)].access) > parseInt(cardAccess)\n        ) {\n            cardAccess = parseInt(db.cards[db.cards[id]._planId]._users[Object.keys(db.cards[db.cards[id]._planId]._users).find(a => a.indexOf(session._id) > -1)].access)\n        }\n        return cardAccess\n    }\n    return 0\n}\n\nconst getUserList = (cardId, options = {}) => {\n\n    // console.log(options, cardId)\n\n    const { db, session } = reduxStore.getState()\n    let data = {\n        ...cardId ? db.cards[cardId] : {}\n    }\n\n\n    let userList = {}\n    if (!options?.noInternal)\n        Object.keys(db.users).filter(u => db.users[u].type === \"user\" && db.users[u]._parent === session._account && !db.users[u].deleted).map(u => {\n            userList = {\n                ...userList,\n                [u]: {\n                    ...db.users[u],\n                    _id: u,\n                    type: \"user\",\n                }\n            }\n        })\n\n    if (data?.client && db.users[data.client])\n        Object.keys(db.users).filter(u =>\n            db.users[u]._parent === data.client\n            && !db.users[u].deleted\n        ).map(u => {\n            userList = {\n                ...userList,\n                [u]: {\n                    ...db.users[u],\n                    _id: u,\n                    type: \"external\",\n                    ...db.users[u]._parent ? { _parent: db.users[u]._parent } : {},\n                }\n            }\n        })\n    if (data?._users)\n        Object.keys(data._users).map(u => {\n            if (u !== session._id) {\n                let type = \"user\"\n                if (\n                    !db.users[u]\n                    ||\n                    (\n                        db.users[u]\n                        && db.users[u]._parent\n                        && db.users[db.users[u]._parent]\n                        && db.users[u]._parent !== session.account\n                    )\n                ) type = \"external\"\n\n                if (\n                    !db.users[u]\n                    ||\n                    (\n                        db.users[u]\n                        && db.users[u]._parent\n                        && !db.users[db.users[u]._parent]\n                    )\n                ) type = \"consultant\"\n\n                userList = {\n                    ...userList,\n                    [u]: {\n                        ...data._users[u],\n                        _id: u,\n                        type: type,\n                        ...data._users[u]._parent ? { _parent: data._users[u]._parent } : {}\n                    }\n                }\n            }\n        })\n\n    if (options && !options.onlyCard) {\n        if (\n            !options.noPlan\n            && data._planId\n            && db.cards[data._planId]?._users[session._id]\n        ) {\n            Object.keys(db.cards[data._planId]._users).map(u => {\n\n            })\n            userList = {\n                ...userList,\n                ...getUserList(data._planId, { noPlan: true, noInternal: true }),\n            }\n        }\n        if (\n            data._parent\n            && db.cards[data._parent]?._users[session._id]\n        ) {\n            userList = {\n                ...userList,\n                ...getUserList(data._parent, { noPlan: true, noInternal: true }),\n            }\n        }\n    }\n    if (options?.isArray) {\n        let result = []\n        Object.keys(userList).map(a => {\n            if (result.filter(us => us._id === a).length === 0)\n                result.push(userList[a])\n        })\n        return result\n    }\n    return userList\n}\n\nconst verifyTemplate = (id, firstId = null) => {\n    if (id === firstId)\n        return false\n    if (!id)\n        return false\n\n    let isTemplate = false\n\n    let card = reduxStore.getState().db.cards[id] ? reduxStore.getState().db.cards[id] : null\n\n    if (!card)\n        return false\n    if (card && card.isTemplate) {\n        isTemplate = true\n    } else if (card && card._planId && card._planId !== card._id && reduxStore.getState().db.cards[card._planId]) {\n        isTemplate = verifyTemplate(card._planId, firstId ? firstId : id)\n    } else if (card && card._parent && reduxStore.getState().db.cards[card._parent]) {\n        isTemplate = verifyTemplate(card._parent, firstId ? firstId : id)\n    }\n    return isTemplate\n}\n\nconst copyCards = async (props, from, to) => {\n    const response = new Promise(async (resolve, reject) => {\n        const apiConn = await api.post('/cards/copy', {\n            from,\n            to\n        })\n        if (apiConn)\n            resolve(true)\n    })\n\n    const result = await response\n    return result\n}\n\nconst getChildrens = (id) => {\n    const { cards } = reduxStore.getState().db\n    let result = {\n        [id]: true\n    }\n    Object.keys(cards).filter(c => cards[c]._parent === id).map(async (c, ci) => {\n        let child = getChildrens(c)\n        if (child) {\n            result = {\n                ...result,\n                ...child,\n            }\n        }\n    })\n    return result\n\n\n}\n\nconst updateCardStatus = async (props, d) => {\n    let data = props.data && props.data._id ? reduxStore.getState().db.cards[props.data._id] : {}\n\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n\n    let dataUpdate = d\n    let localUpdate = dataUpdate\n    if (dataUpdate.status === \"completed\") {\n        localUpdate = {\n            ...localUpdate,\n            completed_at: {\n                low: moment().unix(\"X\")\n            }\n        }\n    } else {\n        dataUpdate = {\n            ...localUpdate,\n            completed_at: null\n        }\n    }\n\n    try {\n        socket.emit(\"data\", {\n            module: \"cards\",\n            method: \"put\",\n            action: \"status\"\n        }, {\n            _id: data._id,\n            ...dataUpdate\n        }, async () => {\n            props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n                ...reduxStore.getState().db,\n                cards: {\n                    ...reduxStore.getState().db.cards,\n                    [data._id]: {\n                        ...reduxStore.getState().db.cards[data._id],\n                        ...localUpdate,\n                    },\n                }\n            })\n\n        })\n    } catch (e) {\n        console.log(e)\n    }\n}\n\n//2022Ago\nexport const updateCardData = async (props, d) => {\n    let data = props.data && props.data._id ? reduxStore.getState().db.cards[props.data._id] : {}\n\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n\n    let dataUpdate = d\n    let localUpdate = dataUpdate\n    if (dataUpdate.status === \"completed\") {\n        localUpdate = {\n            ...localUpdate,\n            completed_at: {\n                low: moment().unix(\"X\")\n            }\n        }\n    } else if (dataUpdate.status) {\n        localUpdate = {\n            ...localUpdate,\n            completed_at: {\n                low: null\n            }\n        }\n    }\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: {\n            ...reduxStore.getState().db.cards,\n            [data._id]: {\n                ...reduxStore.getState().db.cards[data._id],\n                ...localUpdate,\n            },\n        }\n    })\n    try {\n        socket.emit(\"data\", {\n            module: \"cards\",\n            method: \"put\",\n            action: \"update220527\"\n        }, {\n            _id: data._id,\n            ...dataUpdate\n        })\n    } catch (e) {\n        console.log(e)\n    }\n}\n\n//2023Fev @@@REVIEW_CODE\nexport const saveCardData = async (props, d) => {\n    let data = props.data && props.data._id ? reduxStore.getState().db.cards[props.data._id] : {}\n\n    let socket\n    if (props && props.store && reduxStore.getState().functions && reduxStore.getState().functions.socket) {\n        socket = reduxStore.getState().functions.socket\n    } else {\n        socket = reduxStore.getState().functions.socket\n    }\n\n    let dataUpdate = d\n    let localUpdate = dataUpdate\n    if (dataUpdate.status === \"completed\") {\n        localUpdate = {\n            ...localUpdate,\n            completed_at: {\n                low: moment().unix(\"X\")\n            }\n        }\n    } else if (dataUpdate.status) {\n        localUpdate = {\n            ...localUpdate,\n            completed_at: {\n                low: null\n            }\n        }\n    }\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: {\n            ...reduxStore.getState().db.cards,\n            [data._id]: {\n                ...reduxStore.getState().db.cards[data._id],\n                ...localUpdate,\n            },\n        }\n    })\n    try {\n        api.put(\"/cards/update\", dataUpdate)\n    } catch (e) {\n        console.log(e)\n    }\n}\n\nconst reqChildrenCards = async (cardId, status = null, fid) => {\n    let cards = reduxStore.getState().db.cards\n    let childrenCards = []\n    let chields = Object.keys(cards)\n        .filter(a =>\n            cards[a]\n            && cards[a]._parent\n            && (\n                cards[a]._parent === cardId\n                ||\n                cards[a]._parent === fid\n            )\n            && (\n                !status\n                ||\n                (\n                    status === 'completed'\n                    && cards[a].status !== \"completed\"\n                )\n                ||\n                (\n                    status !== 'completed'\n                    && cards[a]._parentCompleted\n                    && cards[a]._parentCompleted.cardId\n                    && (\n                        cards[a]._parentCompleted.cardId === cardId\n                        ||\n                        cards[a]._parentCompleted.cardId === fid\n                    )\n                )\n            )\n        )\n    if (chields.length > 0) {\n        let load = await new Promise((resolve, reject) => {\n            chields.map(async (a, ai) => {\n                let ch = await reqChildrenCards(a, status, cardId)\n                if (childrenCards.indexOf(a) === -1) {\n                    childrenCards.push(a)\n                }\n                if (ch && ch.length > 0) {\n                    ch.map((xx, xxi) => {\n                        if (childrenCards.indexOf(xx) === -1) {\n                            childrenCards.push(xx)\n                        }\n                        if (xxi + 1 === ch.length && ai + 1 === chields.length)\n                            resolve(true)\n                    })\n                } else {\n                    resolve(true)\n                }\n\n            })\n        })\n        if (load) {\n            return childrenCards\n        }\n    } else {\n        return []\n    }\n}\n\nconst cardStatus = async (props, parentId, status) => {\n    let childrens = await reqChildrenCards(parentId, status)\n    let cards = reduxStore.getState().db.cards\n    if (childrens && childrens.length > 0)\n        childrens.map(cc => {\n            cards[cc] = {\n                ...cards[cc],\n                status: status,\n                completed_at: status === 'completed' ? {\n                    low:\n                        moment().unix(\"X\")\n                } : null,\n                ...status === 'completed' ? {\n                    _parentCompleted: {\n                        cardId: parentId,\n                        completed_at: {\n                            low: moment().unix(\"X\")\n                        }\n                    }\n                } : { _parentCompleted: null }\n            }\n        })\n\n    cards[parentId] = {\n        ...cards[parentId],\n        status: status,\n        completed_at: status === 'completed' ? {\n            low:\n                moment().unix(\"X\")\n        } : null,\n    }\n\n    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\n        ...reduxStore.getState().db,\n        cards: cards\n    })\n\n}\n\nconst countNotifications = (nodeId, debug = false, my = false) => {\n    const { session } = reduxStore.getState()\n    let notifications = reduxStore.getState().db.cards[nodeId] && reduxStore.getState().db.cards[nodeId]._notifications ? reduxStore.getState().db.cards[nodeId]._notifications : {}\n\n    Object.keys(notifications).map(t => notifications[t] = parseInt(notifications[t]))\n    let newTotal = 0\n\n    Object.keys(notifications).filter(t => t !== 'total').map(t => {\n        if (\n            reduxStore.getState().db.cards[nodeId]\n            && reduxStore.getState().db.cards[nodeId]._users\n            && reduxStore.getState().db.cards[nodeId]._users[session._id]\n            && reduxStore.getState().timeline[nodeId]\n            && parseInt(notifications[t])\n            < Object.keys(reduxStore.getState().timeline[nodeId]).filter(m =>\n                reduxStore.getState().timeline[nodeId][m]\n                && reduxStore.getState().timeline[nodeId][m].type\n                && reduxStore.getState().timeline[nodeId][m].type === t\n            ).length\n        ) {\n            notifications[t] = reduxStore.getState().timeline &&\n                reduxStore.getState().timeline[nodeId] &&\n                Object.keys(reduxStore.getState().timeline[nodeId]).length > 0 ?\n                Object.keys(reduxStore.getState().timeline[nodeId]).filter(tm => {\n                    if (session &&\n                        session._id &&\n                        parseInt(reduxStore.getState().timeline[nodeId][tm].created_at) > 1650666142 &&\n                        reduxStore.getState().timeline[nodeId][tm].type === t &&\n                        reduxStore.getState().timeline[nodeId][tm].user &&\n                        reduxStore.getState().timeline[nodeId][tm].user._id !== session._id\n                        &&\n                        (\n                            !reduxStore.getState().timeline[nodeId][tm].readedBy\n                            ||\n                            (\n                                reduxStore.getState().timeline[nodeId][tm].readedBy &&\n                                !reduxStore.getState().timeline[nodeId][tm].readedBy[session._id]\n                            )\n                        )\n                    )\n                        return true\n                }\n                ).length : 0\n            newTotal = newTotal + parseInt(notifications[t])\n        } else {\n            notifications[t] = parseInt(notifications[t])\n            newTotal = newTotal + parseInt(notifications[t])\n        }\n    })\n\n    return {\n        ...notifications,\n        total: newTotal\n    }\n}\n\nconst planAccountVerify = (plan) => {\n    const { session, db } = reduxStore.getState()\n    if (\n        plan\n        && plan.length === 36\n        && db.cards[plan]\n        && !db.cards[plan].isTemplate\n        && (\n            db.cards[plan]._users\n            && (\n                !db.cards[plan]._users[session._id]\n                && (\n                    db.cards[plan]._account\n                    && db.cards[plan]._account !== MD5(session.account).toString()\n                )\n            )\n        )\n    )\n        return false\n    return true\n}\n\nconst planMyAccountVerify = (plan) => {\n    const { session, db } = reduxStore.getState()\n    if (\n        plan\n        && plan.length === 36\n        && db.cards[plan]\n        && !db.cards[plan].isTemplate\n        && (\n            db.cards[plan]._account\n            && db.cards[plan]._account !== MD5(session.account).toString()\n        )\n    )\n        return false\n    return true\n}\n\nconst setCompleted = async (props, data) => {\n    const countChildrens = await apims.post(\"/Card_Count\", { id: data._id })\n    if (countChildrens && parseInt(countChildrens.data) > 0 && data.status !== 'completed') {\n        appAlert({\n            message: translate('$__concludeWithChildrensNotConcludedConfirm', 1),\n            autoClose: 50000,\n            buttons: [\n                {\n                    shadow: true,\n                    title: translate(\"$__concludeAll\"),\n                    text: translate(\"$__concludeAll\"),\n                    color: \"green\",\n                    icon: \"close\",\n                    size: \"25px\",\n                    onClick: () => {\n                        updateCardData(\n                            {\n                                ...props,\n                                data: { _id: data._id }\n                            }, { status: data.status === 'completed' ? 'inProgress' : 'completed' })\n                        if (countChildrens && parseInt(countChildrens.data) > 0)\n                            cardStatus(props, data._id, data.status === 'completed' ? 'inProgress' : 'completed')\n                    },\n                    style: { marginLeft: 15 }\n                },\n                {\n                    shadow: true,\n                    title: translate(\"$__cancel\"),\n                    text: translate(\"$__cancel\"),\n                    color: \"red\",\n                    icon: \"close\",\n                    size: \"25px\",\n                    onClick: () => {\n                        // toast.dismiss(key)\n                    },\n                    style: { marginLeft: 15 }\n                }],\n            variant: 'warning',\n            persist: false,\n            horizontal: 'right',\n        })\n    } else {\n        updateCardData(\n            {\n                ...props,\n                data: { _id: data._id }\n            }, { status: data.status === 'completed' ? 'inProgress' : 'completed' })\n        if (countChildrens && parseInt(countChildrens.data) > 0) {\n            cardStatus(props, data._id, data.status === 'completed' ? 'inProgress' : 'completed')\n        }\n    }\n}\n\nexport const privateVerify = (id) => {\n    const { session, db } = reduxStore.getState()\n    const card = db.cards[id] || {}\n    if (card && card.private && card._users[session._id])\n        return true\n    return false\n}\n\nexport const setCompletedStep = async (id) => {\n    const { db, session } = reduxStore.getState()\n    const card = db.cards[id]\n    const step = db.cards[card._hasStep]\n    console.log(card, step)\n}\n\nexport {\n    cardAccessDelete,\n    cardAccessRemove,\n    cardAccessUpdate,\n    cardCopyTo,\n    cardMoveTo,\n    cardStatus,\n    changePlanId,\n    columnCards,\n    connectInMount,\n    copyCards,\n    countNotifications,\n    dbUpdateCardSWOT,\n    dbUpdateCardTimer,\n    dbUpdateCard_V2,\n    deleteCard,\n    deleteColumn,\n    getCardColor,\n    getCardParents,\n    getChildrens,\n    getUserAccess,\n    getUserList,\n    kpiTimerDelete,\n    kpiTimerStart,\n    kpiTimerStop,\n    linkCard,\n    localAddCard,\n    massUpdate,\n    myDayUpd,\n    planAccountVerify,\n    planMyAccountVerify,\n    reorderCard,\n    reorderColumns,\n    restoreCard,\n    saveCard,\n    saveCard_V2,\n    saveMATRIX,\n    selectSWOT,\n    setCompleted,\n    setMyDay,\n    socketUnLinkChildrens,\n    sortList,\n    unlinkChildrens,\n    updateCard,\n    updateCardStatus,\n    updateColumnCards,\n    verifyTemplate,\n}","const initialState = {\r\n    tags: [],\r\n    userGroups: [],\r\n    users: {\r\n        userGroup: [],\r\n        selected: {}\r\n    },\r\n    units: {\r\n        userGroup: [],\r\n        selected: {}\r\n    },\r\n    clients: {\r\n        userGroup: [],\r\n        selected: {}\r\n    },\r\n    groups: {\r\n        userGroup: [],\r\n        selected: {}\r\n    },\r\n    plans: {\r\n        userGroup: [],\r\n        selected: {}\r\n    },\r\n    sideModuleWindow: false,\r\n    clearFilter: false,\r\n    text: '',\r\n    cards: {\r\n        iniDate: null,\r\n        endDate: null,\r\n        dateStatus: [],\r\n        status: {\r\n            all: true,\r\n            notStarted: true,\r\n            awaitAction: true,\r\n            paused: true,\r\n            inProgress: true,\r\n            completed: true,\r\n        },\r\n        priority: {\r\n            all: true,\r\n            'null': true,\r\n            normal: true,\r\n            low: true,\r\n            medium: true,\r\n            high: true,\r\n        },\r\n        priority: {\r\n            all: true,\r\n            'null': true,\r\n            normal: true,\r\n            low: true,\r\n            medium: true,\r\n            high: true,\r\n        },\r\n        risk: {\r\n            all: true,\r\n            'null': true,\r\n            normal: true,\r\n            low: true,\r\n            medium: true,\r\n            high: true,\r\n        },\r\n        complexity: {\r\n            all: true,\r\n            'null': true,\r\n            normal: true,\r\n            low: true,\r\n            medium: true,\r\n            high: true,\r\n        },\r\n        impact: {\r\n            all: true,\r\n            'null': true,\r\n            normal: true,\r\n            low: true,\r\n            medium: true,\r\n            high: true,\r\n        },\r\n        kpiType: [],\r\n        iniKpiValue: null,\r\n        endKpiValue: null,\r\n    },\r\n};\r\n\r\nexport {\r\n    initialState\r\n}","import React from \"react\";\nimport { SketchPicker } from \"react-color\";\n\n//@MATERIAL\nimport ClickAwayListener from '@material-ui/core/ClickAwayListener';\nimport CustomButton from \"components/Buttons/custom\";\nimport Grow from '@material-ui/core/Grow';\nimport Paper from '@material-ui/core/Paper';\nimport Popper from '@material-ui/core/Popper';\nimport Tooltip from \"@material-ui/core/Tooltip\";\nimport { makeStyles } from '@material-ui/core/styles';\n\n//FUNCTIONS\nimport {\n    translate,\n    textColor,\n} from \"functions/\";\n\nimport api from \"api/\";\n\nconst useStyles = makeStyles((props) => ({\n    iconButtonStyleTransaparent: {\n        padding: \"3px\",\n        margin: 0,\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        }\n    },\n    iconButtonStyleWhite: {\n        padding: \"3px\",\n        margin: 0,\n        backgroundColor: '#FFFFFF',\n        '&:hover': {\n            backgroundColor: 'rgba(250,250,250,0.9)'\n        }\n    },\n}));\n\nfunction Comp(props) {\n    const [open, setOpen] = React.useState(false);\n    const [color, setColor] = React.useState(props.color ? props.color : \"rgba(200,200,200,1)\")\n\n    const anchorRef = React.useRef(null)\n\n    const handleClose = (event) => {\n        if (anchorRef.current && anchorRef.current.contains(event.target)) {\n            return;\n        }\n\n        setOpen(false);\n        if (props.onClose)\n            props.onClose()\n    };\n\n    const saveColor = async (color) => {\n        if (props.onChange)\n            props.onChange(color)\n        setOpen(!open)\n\n        if (props._id)\n            await api.put(\"node/update\", {\n                _id: props._id,\n                color: color\n            })\n    }\n\n    return (\n        <div className={\"cardColorPicker\"} style={{\n            ...props.style ? props.style : {},\n        }}\n            onClick={(e) => {\n                e.stopPropagation()\n                e.preventDefault()\n            }}\n            onDrag={(e) => {\n                e.preventDefault()\n                e.stopPropagation()\n            }}\n            onDragStart={(e) => {\n                e.preventDefault()\n                e.stopPropagation()\n            }}\n            onDragEnter={(e) => {\n                e.preventDefault()\n                e.stopPropagation()\n            }}\n            onDragCapture={(e) => {\n                e.preventDefault()\n                e.stopPropagation()\n            }}\n            onDragEnterCapture={(e) => {\n                e.preventDefault()\n                e.stopPropagation()\n            }}\n            onDragOver={(e) => {\n                e.preventDefault()\n                e.stopPropagation()\n            }}\n        >\n            {props.children ?\n                <div\n                    ref={anchorRef}\n                    style={{\n                        margin: 3,\n                        cursor: 'pointer',\n                    }}\n                    onClick={(e) => {\n                        setOpen(op => !op)\n                        // e.preventDefault()\n                        // e.stopPropagation()\n                    }}\n                >\n                    <div\n                        onClick={(e) => {\n                            // e.preventDefault()\n                            // e.stopPropagation()\n                        }}\n                    >\n                        {props.children}\n                    </div>\n                </div>\n                :\n                <div\n                    ref={anchorRef}\n                    style={{\n                        ...props.label ? {\n                            borderRadius: 7,\n                            padding: 7,\n                            color: color ? textColor(color, true) : '#FFFFFF',\n                            fontSize: 12\n                        } : {\n                            width: props.size ? props.size : 21,\n                            height: props.size ? props.size : 21,\n                        },\n                        margin: 3,\n                        backgroundColor: color,\n                        borderRadius: props.size ? props.size : 21,\n                        cursor: 'pointer',\n                    }}\n                    onClick={() => {\n                        setOpen(op => !op)\n                    }}\n                >\n                    {props.label ? props.label : ``}\n                </div>\n            }\n            <Popper\n                open={open}\n                anchorEl={anchorRef.current}\n                role={undefined}\n                transition\n                disablePortal={props.disablePortal ? true : false}\n            >\n                {({ TransitionProps, placement }) => (\n                    <Grow\n                        {...TransitionProps}\n                        style={{\n                            transformOrigin: 'right center',\n                        }}\n                    >\n                        <Paper>\n                            <ClickAwayListener onClickAway={handleClose}>\n                                <div style={{\n                                    position: \"relative\",\n                                    backgroundColor: \"#FFFFFF\",\n                                    boxShadow: \"0px 0px 10px 5px rgba(0,0,0,0.17)\",\n                                    borderRadius: 7,\n                                }} onClick={(e) => {\n                                    e.stopPropagation()\n                                }}>\n                                    <div style={{ position: \"relative\", width: \"100%\", display: \"flex\", marginTop: \"-5px\", justifyContent: \"end\" }}>\n                                        <CustomButton\n                                            title={translate(\"$__cancel\", 1)}\n                                            color={'lightgrey'}\n                                            icon={'close'}\n                                            onClick={() => {\n                                                setColor(props.color ? props.color : 'rgba(200,200,200,1)')\n                                                setOpen(!open)\n                                            }}\n                                            size={'30px'}\n                                        />\n                                        {props.color ?\n                                            <CustomButton\n                                                title={translate(\"$__removeColor\", 1)}\n                                                color={'red'}\n                                                icon={'format_color_reset'}\n                                                onClick={() => { saveColor(null) }}\n                                                size={'30px'}\n                                            />\n                                            : <React.Fragment></React.Fragment>\n                                        }\n                                        <CustomButton\n                                            title={translate(\"$__saveColor\", 1)}\n                                            color={'green'}\n                                            icon={'save'}\n                                            onClick={() => { saveColor(color) }}\n                                            size={'30px'}\n                                        />\n                                    </div>\n                                    <SketchPicker\n                                        color={color}\n                                        onChange={(newColor, event) => {\n                                            setColor(`rgba(${newColor.rgb.r}, ${newColor.rgb.g}, ${newColor.rgb.b}, ${newColor.rgb.a})`)\n                                            event.stopPropagation()\n                                        }}\n                                        disableAlpha\n                                    />\n                                    <div style={{ clear: 'both' }}></div>\n                                </div>\n                            </ClickAwayListener>\n                        </Paper>\n                    </Grow>\n                )}\n            </Popper>\n        </div>\n    )\n}\nexport default Comp;\n","import axios from \"axios\";\r\nimport history from \"store/history\";\r\n\r\n/**\r\n * Create base url for requisition api\r\n */\r\nconst api = axios.create(String(process.env.REACT_APP_PROD) === 'true' ? {\r\n  baseURL: process.env.REACT_APP_WS\r\n} : {\r\n  baseURL: process.env.REACT_APP_devWS\r\n});\r\n\r\naxios.defaults.withCredentials = true;\r\n/**\r\n * intecept verbs http to verify token\r\n */\r\napi.interceptors.request.use(async config => {\r\n  const token = localStorage.getItem('TOKEN');\r\n  if (token) {\r\n    config.headers.Authorization = `Bearer ${token}`;\r\n    config.headers.Accept = \"application/json;charset=UTF-8;application/x-www-form-urlencoded\";\r\n  }\r\n  return config;\r\n});\r\n\r\napi.interceptors.response.use(\r\n  async data => {\r\n    return Promise.resolve(data);\r\n  }\r\n  ,\r\n  error => {\r\n    const response = Promise.reject(error.response);\r\n    if (error && error.response && error.response.status && error.response.status === 401 && window.location.pathname !== '/login' && window.location.pathname !== '/register' && window.location.pathname !== '/activate') {\r\n      // console.log(error.response.status)\r\n      localStorage.setItem('TOKEN', null)\r\n      localStorage.clear();\r\n      window.open('/login', '_self')\r\n    }\r\n    return response\r\n  }\r\n);\r\n\r\n/**\r\n * Export api\r\n */\r\nexport default api;\r\n","//\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"@material-ui/icons/utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(_react.default.Fragment, null, _react.default.createElement(\"path\", {\n  fill: \"none\",\n  d: \"M20.45,5.43,19,4l-1.79,1.8,1.41,1.41ZM13,1.52H11v3h2Zm7,12h3v-2H20ZM9,17.67v4.81h6V17.67a6,6,0,1,0-6,0ZM4,13.48v-2H1v2ZM6.76,5.82,5,4,3.56,5.43l1.8,1.79Z\"\n}),_react.default.createElement(\"path\", {\n  d: \"M20.45,5.43,19,4l-1.79,1.8,1.41,1.41ZM13,1.52H11v3h2Zm7,12h3v-2H20ZM9,17.67v4.81h6V17.67a6,6,0,1,0-6,0ZM4,13.48v-2H1v2ZM6.76,5.82,5,4,3.56,5.43l1.8,1.79Z\"\n})), 'Ideas');\n\nexports.default = _default;","const defaultState = {\r\n    notifications: [],\r\n};\r\n\r\nexport default (state = defaultState, action) => {\r\n    switch (action.type) {\r\n        case 'NEW_ALERT':\r\n            return {\r\n                ...state,\r\n                notifications: [\r\n                    ...state.notifications,\r\n                    {\r\n                        key: action.value.options.key,\r\n                        ...action.value,\r\n                    },\r\n                ],\r\n            };\r\n\r\n        case 'CLOSE_ALERT':\r\n            return {\r\n                ...state,\r\n                notifications: state.notifications.map(notification => (\r\n                    (action.dismissAll || notification.key === action.value)\r\n                        ? { ...notification, dismissed: true }\r\n                        : { ...notification }\r\n                )),\r\n            };\r\n\r\n        case 'REMOVE_ALERT':\r\n            return {\r\n                ...state,\r\n                notifications: state.notifications.filter(\r\n                    notification => notification.key !== action.value,\r\n                ),\r\n            };\r\n\r\n        default:\r\n            return state;\r\n    }\r\n};\r\n","const initialState = {\r\n    copy: [],\r\n    selected: [],\r\n    action: null\r\n}\r\n\r\nconst card = (state = initialState, data) => {\r\n    if (data.action === 'SET_CARD' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else if (data.action === 'CLEAR_CARD') {\r\n        return {\r\n            ...initialState\r\n        }\r\n    }\r\n    else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default card;","const initialState = {\r\n    open: false,\r\n    nodeId: null,\r\n    activeChats: [],\r\n    activeModule: 'users',\r\n    groups: {},\r\n    notifications: true,\r\n}\r\n\r\nconst sideModule = (state = initialState, data) => {\r\n    if (data.action === 'SET_CHAT' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else if (data.action === 'CLOSE_CHAT') {\r\n        return {\r\n            ...initialState\r\n        }\r\n    }\r\n    else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default sideModule;","const initialState = {\r\n    timelines: {},\r\n    unreadeds: {},\r\n    drafts: {}\r\n}\r\n\r\nconst sideModule = (state = initialState, data) => {\r\n    if (data.action === 'SET_CHATS' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else if (data.action === 'CLEAR_CHATS') {\r\n        return {\r\n            ...initialState\r\n        }\r\n    }\r\n    else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default sideModule;","const initialState = {}\r\n\r\nconst socket = (state = initialState, data) => {\r\n    if (data.action === 'SET_FUNCTIONS' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    }\r\n    else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default socket;","const initialState = {};\r\n\r\nconst languages = (state = initialState, data) => {\r\n    if (data.action === 'SET_LANGUAGE' && data.value) {\r\n        return data.value\r\n    }\r\n    else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default languages;","const initialState = {\r\n    open: false,\r\n    miro: false,\r\n    files: [],\r\n    file: 0\r\n}\r\n\r\nconst sideModule = (state = initialState, data) => {\r\n    if (data.action === 'LIGHTBOX' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else if (data.action === 'LIGHTBOX_CLOSE') {\r\n        return {\r\n            ...initialState\r\n        }\r\n    }\r\n    else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default sideModule;","const initialState = {\r\n    total: 0,\r\n    lastNotification: 0,\r\n    firstNotification: 0,\r\n}\r\n\r\nconst session = (state = initialState, data) => {\r\n    if (data.action === 'SET_NOTIFICATIONS' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    }\r\n    else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default session;","/**\r\n * @createDate 2019-07-02 v:1.0\r\n * @author Cristofer Marinho\r\n * @param {fullScreen} @Boolean\r\n * @param {text} // Info text loader @String\r\n * @param {type} // default|progressBar|\r\n *\r\n * Used in:\r\n *    /layouts/d    \r\n */\r\n\r\nconst initialState = {\r\n    fullScreen: true,\r\n    visible: true,\r\n    callBack: null,\r\n    autoSave: false,\r\n    cards: true,\r\n\r\n};\r\n\r\nconst preLoader = (state = initialState, data) => {\r\n    if (data.action === 'preLoader' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else {\r\n        return state\r\n    }\r\n}\r\n\r\nexport default preLoader","import { initialState } from \"./search-initialState\";\r\n\r\nconst session = (state = initialState, data) => {\r\n    if (data.action === 'SEARCH' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    }\r\n    if (data.action === 'SEARCH_CLEAR') {\r\n        return initialState\r\n    }\r\n    return state\r\n}\r\n\r\nexport default session;","import logoMachen from \"assets/img/logoMachen.svg\"\r\nimport login from \"assets/img/fundoLogin.jpg\"\r\n\r\nconst initialState = {\r\n    custom: {\r\n        ColumnTitleColor: `linear-gradient(90deg, rgba(67,18,102,1) 0%, rgba(90,35,130,1) 100%)`,\r\n        customLogo: logoMachen,\r\n        loginBackground: login,\r\n        linearProgress: `linear-gradient(90deg, rgba(90,35,130,0) 0%, rgba(67,18,102,1) 30%, rgba(67,18,102,1) 70%, rgba(90,35,130,0) 100%)`,\r\n        AvatarBackground: \"radial-gradient(rgba(114,47,162,1) 0%, rgba(67,18,102,1) 100%)\",\r\n        AvatarIconColor: \"#FFFFFF\",\r\n        active: 'rgb(192,178,131)',\r\n        color: 'rgb(192,178,131)',\r\n        colorText: 'rgb(192,178,131)',\r\n        dark: 'rgb(8,27,49)',\r\n        darkText: 'rgb(8,27,49)',\r\n        disabled: 'rgb(200,200,200)',\r\n        fieldRadius: '3px',\r\n        fieldVariant: 'standard', //filled, outlined, standard\r\n        light: '#FFFFFF',\r\n        lightText: '#FFFFFF',\r\n        line: 'rgb(192,178,131)',\r\n        locale: 'pt-BR',\r\n        subMenuColor: 'linear-gradient(90deg, rgba(233,233,233,1) 0%, rgba(237,237,237,1) 100%)',\r\n        subMenuTextColor: 'rgb(125,125,125)',\r\n        subMenuTextColorActive: 'rgb(192,178,131)',\r\n        medium: 'rgb(125,125,125)',\r\n        mediumText: 'rgb(150,150,150)',\r\n        menu: 'rgb(67,18,102)',\r\n        menuColor: `linear-gradient(90deg, rgba(67,18,102,1) 0%, rgba(90,35,130,1) 100%)`,\r\n        menuButtonColor: 'rgb(192,178,131)',\r\n        timelineMyMessage: '#ebe3f1'\r\n    },\r\n    cards: {\r\n        load: [],\r\n        adminViewLoader: false,\r\n        adminView: false,\r\n        loaded: false,\r\n        expanded: false,\r\n        hide: {\r\n            image: false,\r\n            description: false,\r\n            dates: false,\r\n            kpi: false,\r\n            kpiChart: false,\r\n            kpiChange: false,\r\n        }\r\n    },\r\n    timeline: {\r\n        load: []\r\n    },\r\n    sideModuleWindow: false,\r\n    dashboard: {\r\n        period: '$__last7Days'\r\n    },\r\n    period: '$__last7Days',\r\n    users: {},\r\n    showDeleted: false,\r\n    showPrivate: false\r\n};\r\n\r\nconst session = (state = initialState, data) => {\r\n    if (data.action === 'SET_SESSION' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else if (data.action === 'CLEAR_SESSION') {\r\n        return {\r\n            ...state,\r\n        }\r\n\r\n    } else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default session;","const initialState = {\r\n    cards: {\r\n        load: {},\r\n    },\r\n    timeline: {\r\n        load: {}\r\n    },\r\n};\r\n\r\nconst sessionLoads = (state = initialState, data) => {\r\n    if (data.action === 'SET_SESSION_LOADS' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else if (data.action === 'CLEAR_SESSION_LOADS') {\r\n        return {\r\n            ...state,\r\n        }\r\n\r\n    } else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default sessionLoads;","const initialState = {\r\n    module: null,\r\n    activeModule: 'cardEdit',\r\n    reqSave: false,\r\n    window: false, //popup || expanded || false\r\n    id: null,\r\n    data: {},\r\n}\r\n\r\nconst sideModule = (state = initialState, data) => {\r\n    if (data.action === 'SET_MODULE' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else if (data.action === 'CLEAR_MODULE') {\r\n        return {\r\n            ...initialState\r\n        }\r\n    }\r\n    else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default sideModule;","const initialState = {}\r\n\r\nconst sideModule = (state = initialState, data) => {\r\n    if (data.action === 'SET_TIMELINE' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default sideModule;","const initialState = {\r\n    cards: {},\r\n    timeline: {}\r\n}\r\n\r\nconst toLoad = (state = initialState, data) => {\r\n    if (data.action === 'TO_LOAD' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default toLoad;","const initialState = {\r\n    users: {},\r\n};\r\n\r\nconst session = (state = initialState, data) => {\r\n    if (data.action === 'SET_USERS_STATUS' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else if (data.action === 'CLEAR_USERS_STATUS') {\r\n        return {\r\n            ...state,\r\n        }\r\n\r\n    } else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default session;","const initialState = {\r\n    typing: {}\r\n}\r\n\r\nconst sideModule = (state = initialState, data) => {\r\n    if (data.action === 'SET_TYPING' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    }\r\n    if (data.action === 'RESET_TYPING') {\r\n        return {\r\n            ...initialState\r\n        }\r\n    }\r\n    return state\r\n};\r\n\r\nexport default sideModule;","import { takeLatest, takeEvery, put, call, all } from 'redux-saga/effects'; //, select, delay\r\n\r\nfunction callBackFn(fn) {\r\n    if (fn.next) {\r\n        fn.next()\r\n    }\r\n    return true\r\n}\r\n\r\nfunction* generate(data) {\r\n    yield put({ type: data.action, value: data.value })\r\n    yield call(callBackFn, data)\r\n}\r\n\r\n\r\nexport default function* saga() {\r\n    yield all([\r\n        takeLatest(\"ASYNC\", generate),\r\n        takeEvery(\"IMMEDIATE\", generate),\r\n    ])\r\n}","import { legacy_createStore as createStore, combineReducers, applyMiddleware } from \"redux\"\r\nimport createSagaMiddleware from \"redux-saga\"\r\nimport { routerMiddleware } from \"react-router-redux\"\r\nimport history from \"store/history\"\r\n\r\n//REDUCERS\r\nimport alert from \"./alert\"\r\nimport card from \"./card\"\r\nimport chat from \"./chat\"\r\nimport chats from \"./chats\"\r\nimport controls from \"./controls\"\r\nimport db from \"./db\"\r\nimport functions from \"./functions\"\r\nimport languages from \"./languages\"\r\nimport lightBox from \"./lightBox\"\r\nimport notifications from \"./notifications\"\r\nimport preLoader from \"./preLoader\"\r\nimport search from \"./search\"\r\nimport session from \"./session\"\r\nimport sessionLoads from \"./sessionLoads\"\r\nimport sideModule from \"./sideModule\"\r\nimport timeline from \"./timeline\"\r\nimport toLoad from \"./toLoad\"\r\nimport usersStatus from \"./usersStatus\"\r\nimport chatTyping from \"./chatTyping\"\r\n\r\n//SAGA\r\nimport rootSaga from \"./sagas\"\r\n\r\nconst sagaMiddleware = createSagaMiddleware()\r\n\r\nconst store = createStore(\r\n  combineReducers({\r\n    alert,\r\n    card,\r\n    chat,\r\n    chatTyping,\r\n    chats,\r\n    controls,\r\n    db,\r\n    functions,\r\n    languages,\r\n    lightBox,\r\n    notifications,\r\n    preLoader,\r\n    search,\r\n    session,\r\n    sessionLoads,\r\n    sideModule,\r\n    timeline,\r\n    toLoad,\r\n    usersStatus,\r\n  }),\r\n  applyMiddleware(sagaMiddleware, routerMiddleware(history))\r\n)\r\n\r\nsagaMiddleware.run(rootSaga)\r\n\r\nexport default store\r\n","import { createBrowserHistory } from \"history\";\r\n\r\nconst history = createBrowserHistory();\r\n\r\nexport default history;\r\n","module.exports = __webpack_public_path__ + \"static/media/logoMachen.c1ab9af8.svg\";","module.exports = \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAGQAAABkCAYAAABw4pVUAAABN2lDQ1BBZG9iZSBSR0IgKDE5OTgpAAAokZWPv0rDUBSHvxtFxaFWCOLgcCdRUGzVwYxJW4ogWKtDkq1JQ5ViEm6uf/oQjm4dXNx9AidHwUHxCXwDxamDQ4QMBYvf9J3fORzOAaNi152GUYbzWKt205Gu58vZF2aYAoBOmKV2q3UAECdxxBjf7wiA10277jTG+38yH6ZKAyNguxtlIYgK0L/SqQYxBMygn2oQD4CpTto1EE9AqZf7G1AKcv8ASsr1fBBfgNlzPR+MOcAMcl8BTB1da4Bakg7UWe9Uy6plWdLuJkEkjweZjs4zuR+HiUoT1dFRF8jvA2AxH2w3HblWtay99X/+PRHX82Vun0cIQCw9F1lBeKEuf1UYO5PrYsdwGQ7vYXpUZLs3cLcBC7dFtlqF8hY8Dn8AwMZP/fNTP8gAAAAJcEhZcwAACxMAAAsTAQCanBgAAATuaVRYdFhNTDpjb20uYWRvYmUueG1wAAAAAAA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/PiA8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA2LjAtYzAwMiAxMTYuMTY0NzY2LCAyMDIxLzAyLzE5LTIzOjEwOjA3ICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmUuY29tL3Bob3Rvc2hvcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgMjEuMiAoV2luZG93cykiIHhtcDpDcmVhdGVEYXRlPSIyMDIxLTA4LTE2VDEwOjAwOjU2LTAzOjAwIiB4bXA6TW9kaWZ5RGF0ZT0iMjAyMS0wOC0xNlQxMDowMjoyNC0wMzowMCIgeG1wOk1ldGFkYXRhRGF0ZT0iMjAyMS0wOC0xNlQxMDowMjoyNC0wMzowMCIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NGNkYzhjZTMtOTEyYS1lODQwLWJjYjQtOWVkMTMxMGFiYjU4IiB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOjRjZGM4Y2UzLTkxMmEtZTg0MC1iY2I0LTllZDEzMTBhYmI1OCIgeG1wTU06T3JpZ2luYWxEb2N1bWVudElEPSJ4bXAuZGlkOjRjZGM4Y2UzLTkxMmEtZTg0MC1iY2I0LTllZDEzMTBhYmI1OCI+IDx4bXBNTTpIaXN0b3J5PiA8cmRmOlNlcT4gPHJkZjpsaSBzdEV2dDphY3Rpb249ImNyZWF0ZWQiIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6NGNkYzhjZTMtOTEyYS1lODQwLWJjYjQtOWVkMTMxMGFiYjU4IiBzdEV2dDp3aGVuPSIyMDIxLTA4LTE2VDEwOjAwOjU2LTAzOjAwIiBzdEV2dDpzb2Z0d2FyZUFnZW50PSJBZG9iZSBQaG90b3Nob3AgMjEuMiAoV2luZG93cykiLz4gPC9yZGY6U2VxPiA8L3htcE1NOkhpc3Rvcnk+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+rzal5gAAFXlJREFUeJztnXlsZMd95z9V9a6+SDY5Q3JIzn1oNIpjO97YcrwxAluyN16ttcF617tAEGSxyALZwEBOLBIgCRDAuf5IYCAIknWAIItgs96VkhiyFcmSV5JzOFnJSizbkuYezXA4nINXs493VVX+eM1ucsjh2d1DyfwC/IPdXfWq6vvqd796wlrLZnHrrWmAI8Cf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\"","import axios from \"axios\"\r\naxios.defaults.headers.post[\"Content-Type\"] = \"application/json; charset=UTF-8\"\r\n\r\n/**\r\n * Create base url for requisition ms\r\n */\r\nconst apims = axios.create(String(process.env.REACT_APP_PROD) === \"true\" ? {\r\n  baseURL: process.env.REACT_APP_MS\r\n} : {\r\n  baseURL: process.env.REACT_APP_devMS\r\n});\r\n\r\naxios.defaults.withCredentials = true;\r\n/**\r\n * intecept verbs http to verify token\r\n */\r\napims.interceptors.request.use(async config => {\r\n  config.headers[\"Content-Type\"] = `${config.headers[\"Content-Type\"] ? `${config.headers[\"Content-Type\"]}` : `application/json`}; charset=UTF-8;`\r\n  // config.headers[\"Access-Control-Allow-Origin\"] = \"*\"\r\n  const token = localStorage.getItem(\"TOKEN\") || \"\"\r\n  if (String(token) !== \"null\" && String(token) !== \"\" && String(token) !== \"undefined\") {\r\n    config.headers.Authorization = `Bearer ${token}`\r\n    config.headers.Accept = \"application/json;charset=UTF-8;application/x-www-form-urlencoded\"\r\n  }\r\n  return config\r\n});\r\n\r\napims.interceptors.response.use(\r\n  async data => {\r\n    return Promise.resolve(data)\r\n  }\r\n  ,\r\n  error => {\r\n    const response = Promise.reject(error.response)\r\n    if (error && error.response && error.response.status && error.response.status === 401 && window.location.pathname !== '/login' && window.location.pathname !== '/register' && window.location.pathname !== '/activate') {\r\n      console.log(error)\r\n    }\r\n    return response\r\n  }\r\n);\r\n\r\n/**\r\n * Export ms\r\n */\r\nexport default apims;\r\n","/*!\r\n\r\n=========================================================\r\n* Material Dashboard PRO React - v1.8.0\r\n=========================================================\r\n\r\n* Product Page: https://www.creative-tim.com/product/material-dashboard-pro-react\r\n* Copyright 2019 Creative Tim (https://www.creative-tim.com)\r\n\r\n* Coded by Creative Tim\r\n\r\n=========================================================\r\n\r\n* The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.\r\n\r\n*/\r\n\r\n// ##############################\r\n// // // Function that converts from hex color to rgb color\r\n// // // Example: input = #9c27b0 => output = 156, 39, 176\r\n// // // Example: input = 9c27b0 => output = 156, 39, 176\r\n// // // Example: input = #999 => output = 153, 153, 153\r\n// // // Example: input = 999 => output = 153, 153, 153\r\n// #############################\r\nconst hexToRgb = input => {\r\n  input = input + \"\";\r\n  input = input.replace(\"#\", \"\");\r\n  let hexRegex = /[0-9A-Fa-f]/g;\r\n  if (!hexRegex.test(input) || (input.length !== 3 && input.length !== 6)) {\r\n    throw new Error(\"input is not a valid hex color.\");\r\n  }\r\n  if (input.length === 3) {\r\n    let first = input[0];\r\n    let second = input[1];\r\n    let last = input[2];\r\n    input = first + first + second + second + last + last;\r\n  }\r\n  input = input.toUpperCase(input);\r\n  let first = input[0] + input[1];\r\n  let second = input[2] + input[3];\r\n  let last = input[4] + input[5];\r\n  return (\r\n    parseInt(first, 16) +\r\n    \", \" +\r\n    parseInt(second, 16) +\r\n    \", \" +\r\n    parseInt(last, 16)\r\n  );\r\n};\r\n\r\n// ##############################\r\n// // // Variables - Styles that are used on more than one component\r\n// #############################\r\n\r\nconst drawerWidth = 260;\r\n\r\nconst drawerMiniWidth = 60;\r\n\r\nconst transition = {\r\n  transition: \"all 0.33s cubic-bezier(0.685, 0.0473, 0.346, 1)\"\r\n};\r\n\r\nconst containerFluid = {\r\n  //paddingRight: \"15px\",\r\n  //paddingLeft: \"15px\",\r\n  marginRight: \"auto\",\r\n  marginLeft: \"auto\",\r\n  \"&:before,&:after\": {\r\n    display: \"table\",\r\n    content: '\" \"'\r\n  },\r\n  \"&:after\": {\r\n    clear: \"both\"\r\n  }\r\n};\r\n\r\nconst container = {\r\n  paddingRight: \"15px\",\r\n  paddingLeft: \"15px\",\r\n  marginRight: \"auto\",\r\n  marginLeft: \"auto\",\r\n  \"@media (min-width: 768px)\": {\r\n    width: \"750px\"\r\n  },\r\n  \"@media (min-width: 992px)\": {\r\n    width: \"970px\"\r\n  },\r\n  \"@media (min-width: 1200px)\": {\r\n    width: \"1170px\"\r\n  },\r\n  \"&:before,&:after\": {\r\n    display: \"table\",\r\n    content: '\" \"'\r\n  },\r\n  \"&:after\": {\r\n    clear: \"both\"\r\n  },\r\n  \"&::-webkit-scrollbar\": {\r\n    width: '4px',\r\n    height: '4px',\r\n  },\r\n  \"&::-webkit-scrollbar-button\": {\r\n    width: '0px',\r\n    height: '0px',\r\n  },\r\n  \"&::-webkit-scrollbar-thumb\": {\r\n    background: '#e1e1e1',\r\n    border: '0px none #ffffff',\r\n    borderRadius: '27px',\r\n  },\r\n  \"&::-webkit-scrollbar-thumb:hover\": {\r\n    background: '#ffffff',\r\n  },\r\n  \"&::-webkit-scrollbar-thumb:active\": {\r\n    background: '#000000',\r\n  },\r\n  \"&::-webkit-scrollbar-track\": {\r\n    background: '#666666',\r\n    border: '0px none #ffffff',\r\n    borderRadius: '20px',\r\n  },\r\n  \"&::-webkit-scrollbar-track:hover\": {\r\n    background: '#666666',\r\n  },\r\n  \"&::-webkit-scrollbar-track:active\": {\r\n    background: '#333333',\r\n  },\r\n  \"&::-webkit-scrollbar-corner\": {\r\n    background: 'transparent',\r\n  }\r\n};\r\n\r\n\r\nconst defaultFont = {\r\n  fontFamily: '\"Soleto\", \"Roboto\", \"Helvetica\", \"Arial\", sans-serif',\r\n  fontWeight: \"300\",\r\n  lineHeight: \"1.5em\"\r\n};\r\n\r\nconst primaryColor = [\"#9c27b0\", \"#ab47bc\", \"#8e24aa\", \"#af2cc5\", \"#7b1fa2\"];\r\nconst warningColor = [\r\n  \"#ff9800\",\r\n  \"#ffa726\",\r\n  \"#fb8c00\",\r\n  \"#ffa21a\",\r\n  \"#f57c00\",\r\n  \"#faf2cc\",\r\n  \"#fcf8e3\"\r\n];\r\nconst dangerColor = [\r\n  \"#f44336\",\r\n  \"#ef5350\",\r\n  \"#e53935\",\r\n  \"#f55a4e\",\r\n  \"#d32f2f\",\r\n  \"#ebcccc\",\r\n  \"#f2dede\"\r\n];\r\nconst successColor = [\r\n  \"#4caf50\",\r\n  \"#66bb6a\",\r\n  \"#43a047\",\r\n  \"#5cb860\",\r\n  \"#388e3c\",\r\n  \"#d0e9c6\",\r\n  \"#dff0d8\"\r\n];\r\nconst infoColor = [\r\n  \"#00acc1\",\r\n  \"#26c6da\",\r\n  \"#00acc1\",\r\n  \"#00d3ee\",\r\n  \"#0097a7\",\r\n  \"#c4e3f3\",\r\n  \"#d9edf7\"\r\n];\r\nconst roseColor = [\"#e91e63\", \"#ec407a\", \"#d81b60\", \"#eb3573\", \"#c2185b\"];\r\nconst grayColor = [\r\n  \"#999\",\r\n  \"#777\",\r\n  \"#3C4858\",\r\n  \"#AAAAAA\",\r\n  \"#D2D2D2\",\r\n  \"#DDD\",\r\n  \"#555555\",\r\n  \"#333\",\r\n  \"#eee\",\r\n  \"#ccc\",\r\n  \"#e4e4e4\",\r\n  \"#E5E5E5\",\r\n  \"#f9f9f9\",\r\n  \"#f5f5f5\",\r\n  \"#495057\",\r\n  \"#e7e7e7\",\r\n  \"#212121\",\r\n  \"#c8c8c8\",\r\n  \"#505050\"\r\n];\r\nconst blackColor = \"#000\";\r\nconst whiteColor = \"#FFF\";\r\nconst twitterColor = \"#55acee\";\r\nconst facebookColor = \"#3b5998\";\r\nconst googleColor = \"#dd4b39\";\r\nconst linkedinColor = \"#0976b4\";\r\nconst pinterestColor = \"#cc2127\";\r\nconst youtubeColor = \"#e52d27\";\r\nconst tumblrColor = \"#35465c\";\r\nconst behanceColor = \"#1769ff\";\r\nconst dribbbleColor = \"#ea4c89\";\r\nconst redditColor = \"#ff4500\";\r\n\r\nconst boxShadow = {\r\n  boxShadow:\r\n    \"0 10px 30px -12px rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \", 0.42), 0 4px 25px 0px rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \", 0.12), 0 8px 10px -5px rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \", 0.2)\"\r\n};\r\n\r\nconst primaryBoxShadow = {\r\n  boxShadow:\r\n    \"0 4px 20px 0 rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \",.14), 0 7px 10px -5px rgba(\" +\r\n    hexToRgb(primaryColor[0]) +\r\n    \",.4)\"\r\n};\r\nconst infoBoxShadow = {\r\n  boxShadow:\r\n    \"0 4px 20px 0 rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \",.14), 0 7px 10px -5px rgba(\" +\r\n    hexToRgb(infoColor[0]) +\r\n    \",.4)\"\r\n};\r\nconst successBoxShadow = {\r\n  boxShadow:\r\n    \"0 4px 20px 0 rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \",.14), 0 7px 10px -5px rgba(\" +\r\n    hexToRgb(successColor[0]) +\r\n    \",.4)\"\r\n};\r\nconst warningBoxShadow = {\r\n  boxShadow:\r\n    \"0 4px 20px 0 rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \",.14), 0 7px 10px -5px rgba(\" +\r\n    hexToRgb(warningColor[0]) +\r\n    \",.4)\"\r\n};\r\nconst dangerBoxShadow = {\r\n  boxShadow:\r\n    \"0 4px 20px 0 rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \",.14), 0 7px 10px -5px rgba(\" +\r\n    hexToRgb(dangerColor[0]) +\r\n    \",.4)\"\r\n};\r\nconst roseBoxShadow = {\r\n  boxShadow:\r\n    \"0 4px 20px 0 rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \",.14), 0 7px 10px -5px rgba(\" +\r\n    hexToRgb(roseColor[0]) +\r\n    \",.4)\"\r\n};\r\n\r\nconst warningCardHeader = {\r\n  background:\r\n    \"linear-gradient(60deg, \" + warningColor[1] + \", \" + warningColor[2] + \")\",\r\n  ...warningBoxShadow\r\n};\r\nconst successCardHeader = {\r\n  background:\r\n    \"linear-gradient(60deg, \" + successColor[1] + \", \" + successColor[2] + \")\",\r\n  ...successBoxShadow\r\n};\r\nconst dangerCardHeader = {\r\n  background:\r\n    \"linear-gradient(60deg, \" + dangerColor[1] + \", \" + dangerColor[2] + \")\",\r\n  ...dangerBoxShadow\r\n};\r\nconst infoCardHeader = {\r\n  background:\r\n    \"linear-gradient(60deg, \" + infoColor[1] + \", \" + infoColor[2] + \")\",\r\n  ...infoBoxShadow\r\n};\r\nconst primaryCardHeader = {\r\n  background:\r\n    \"linear-gradient(60deg, \" + primaryColor[1] + \", \" + primaryColor[2] + \")\",\r\n  ...primaryBoxShadow\r\n};\r\nconst roseCardHeader = {\r\n  background:\r\n    \"linear-gradient(60deg, \" + roseColor[1] + \", \" + roseColor[2] + \")\",\r\n  ...roseBoxShadow\r\n};\r\nconst customCardHeader = {\r\n\r\n};\r\n\r\nconst card = {\r\n  display: \"inline-block\",\r\n  position: \"relative\",\r\n  width: \"100%\",\r\n  margin: \"25px 0\",\r\n  boxShadow: \"0 1px 4px 0 rgba(\" + hexToRgb(blackColor) + \", 0.14)\",\r\n  borderRadius: \"6px\",\r\n  color: \"rgba(\" + hexToRgb(blackColor) + \", 0.87)\",\r\n  background: whiteColor\r\n};\r\n\r\nconst cardActions = {\r\n  margin: \"0 20px 10px\",\r\n  paddingTop: \"10px\",\r\n  borderTop: \"1px solid \" + grayColor[8],\r\n  height: \"auto\",\r\n  ...defaultFont\r\n};\r\n\r\nconst cardHeader = {\r\n  margin: \"-20px 15px 0\",\r\n  borderRadius: \"3px\",\r\n  padding: \"15px\"\r\n};\r\n\r\nconst defaultBoxShadow = {\r\n  border: \"0\",\r\n  borderRadius: \"3px\",\r\n  boxShadow:\r\n    \"0 10px 20px -12px rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \", 0.42), 0 3px 20px 0px rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \", 0.12), 0 8px 10px -5px rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \", 0.2)\",\r\n  padding: \"10px 0\",\r\n  transition: \"all 150ms ease 0s\"\r\n};\r\n\r\nconst tooltip = {\r\n  padding: \"10px 15px\",\r\n  minWidth: \"130px\",\r\n  color: whiteColor,\r\n  lineHeight: \"1.7em\",\r\n  background: \"rgba(\" + hexToRgb(grayColor[6]) + \",0.9)\",\r\n  border: \"none\",\r\n  borderRadius: \"3px\",\r\n  opacity: \"1!important\",\r\n  boxShadow:\r\n    \"0 8px 10px 1px rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \", 0.14), 0 3px 14px 2px rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \", 0.12), 0 5px 5px -3px rgba(\" +\r\n    hexToRgb(blackColor) +\r\n    \", 0.2)\",\r\n  maxWidth: \"200px\",\r\n  textAlign: \"center\",\r\n  fontFamily: '\"Helvetica Neue\",Helvetica,Arial,sans-serif',\r\n  fontSize: \"12px\",\r\n  fontStyle: \"normal\",\r\n  fontWeight: \"400\",\r\n  textShadow: \"none\",\r\n  textTransform: \"none\",\r\n  letterSpacing: \"normal\",\r\n  wordBreak: \"normal\",\r\n  wordSpacing: \"normal\",\r\n  wordWrap: \"normal\",\r\n  whiteSpace: \"normal\",\r\n  lineBreak: \"auto\"\r\n};\r\n\r\nconst title = {\r\n  color: grayColor[2],\r\n  textDecoration: \"none\",\r\n  fontWeight: \"300\",\r\n  marginTop: \"30px\",\r\n  marginBottom: \"25px\",\r\n  minHeight: \"32px\",\r\n  fontFamily: \"'Roboto', 'Helvetica', 'Arial', sans-serif\",\r\n  \"& small\": {\r\n    color: grayColor[1],\r\n    fontSize: \"65%\",\r\n    fontWeight: \"400\",\r\n    lineHeight: \"1\"\r\n  }\r\n};\r\n\r\nconst cardTitle = {\r\n  ...title,\r\n  marginTop: \"0\",\r\n  marginBottom: \"3px\",\r\n  minHeight: \"auto\",\r\n  \"& a\": {\r\n    ...title,\r\n    marginTop: \".625rem\",\r\n    marginBottom: \"0.75rem\",\r\n    minHeight: \"auto\"\r\n  }\r\n};\r\n\r\nconst cardSubtitle = {\r\n  marginTop: \"-.375rem\"\r\n};\r\n\r\nconst cardLink = {\r\n  \"& + $cardLink\": {\r\n    marginLeft: \"1.25rem\"\r\n  }\r\n};\r\n\r\nexport {\r\n  hexToRgb,\r\n  //variables\r\n  drawerWidth,\r\n  drawerMiniWidth,\r\n  transition,\r\n  container,\r\n  containerFluid,\r\n  boxShadow,\r\n  card,\r\n  defaultFont,\r\n  primaryColor,\r\n  warningColor,\r\n  dangerColor,\r\n  successColor,\r\n  infoColor,\r\n  roseColor,\r\n  grayColor,\r\n  blackColor,\r\n  whiteColor,\r\n  twitterColor,\r\n  facebookColor,\r\n  googleColor,\r\n  linkedinColor,\r\n  pinterestColor,\r\n  youtubeColor,\r\n  tumblrColor,\r\n  behanceColor,\r\n  dribbbleColor,\r\n  redditColor,\r\n  primaryBoxShadow,\r\n  infoBoxShadow,\r\n  successBoxShadow,\r\n  warningBoxShadow,\r\n  dangerBoxShadow,\r\n  roseBoxShadow,\r\n  warningCardHeader,\r\n  successCardHeader,\r\n  dangerCardHeader,\r\n  infoCardHeader,\r\n  primaryCardHeader,\r\n  roseCardHeader,\r\n  customCardHeader,\r\n  cardActions,\r\n  cardHeader,\r\n  defaultBoxShadow,\r\n  tooltip,\r\n  title,\r\n  cardTitle,\r\n  cardSubtitle,\r\n  cardLink\r\n};\r\n","//ICONS\r\nimport GuidelineD from \"assets/icons/GuidelineC.js\";\r\nimport GuidelineC from \"assets/icons/GuidelineD.js\";\r\nimport GuidelineR from \"assets/icons/GuidelineE.js\";\r\nimport GuidelineE from \"assets/icons/GuidelineR.js\";\r\nimport MicrosoftWord from \"assets/icons/microsoftWord.svg\";\r\nimport MicrosoftExcel from \"assets/icons/microsoftExcel.svg\";\r\nimport MicrosoftPowerpoint from \"assets/icons/microsoftPowerpoint.svg\";\r\nimport SwotIcon from \"assets/icons/SWOT.js\";\r\nimport MatrixIcon from \"assets/icons/Matrix.js\"\r\nimport PDF from \"assets/icons/pdf.svg\";\r\nimport BrightAndConnectedIcon from \"assets/icons/BrigthAndConnected\";\r\nimport packageJson from '../../package.json';\r\n\r\n\r\nconst initialState = {\r\n    version: packageJson.version,\r\n    swot: [\r\n        { value: 'strength', label: '$__strength', icon: 'arrow_upward' },\r\n        { value: 'weakness', label: '$__weakness', icon: 'arrow_downward' },\r\n        { value: 'opportunity', label: '$__opportunity', icon: 'trending_up' },\r\n        { value: 'threat', label: '$__threat', icon: 'trending_down' }\r\n    ],\r\n    languages: [\r\n        { value: 'pt-BR', label: '$__pt-BR' },\r\n        { value: 'en-US', label: '$__en-US' },\r\n        { value: 'es-ES', label: '$__es-ES' },\r\n    ],\r\n    planType: [\r\n        {\r\n            label: \"$__strategic\",\r\n            value: null,\r\n            swot: true,\r\n            overview: true,\r\n            description: \"$__strategicPlanDescription\"\r\n        },\r\n        {\r\n            label: \"$__tacticAndOrOperational\",\r\n            value: \"operational\",\r\n            overview: false,\r\n            swot: false,\r\n            kanban: true,\r\n            description: \"$__operationalPlanDescription\"\r\n        },\r\n        {\r\n            label: \"$__flowOrProcess\", //fluxos / processos\r\n            value: \"flow\",\r\n            swot: false,\r\n            kanban: false,\r\n            overview: true,\r\n            description: \"$__flowOrProcesPlanDescription\"\r\n        }\r\n    ],\r\n    status: [\r\n        { value: 'notStarted', label: '$__notStarted', icon: 'query_builder', color: '#929497' },\r\n        { value: 'inProgress', label: '$__inProgress', icon: 'play_circle_outline', color: '#011E41' },\r\n        { value: 'awaitAction', label: '$__await', icon: 'hourglass_top', color: 'pink' },\r\n        { value: 'paused', label: '$__paused', icon: 'pause_presentation', color: '#EBA900' },\r\n        {\r\n            value: 'completed', label: '$__completed', icon: 'verified', color: '#5A7F71', props: {\r\n                periodFilter: true\r\n            }\r\n        }\r\n    ],\r\n    currency: [\r\n        { value: 'BRL', label: '$__currencyBRL', symbol: 'R$' },\r\n        { value: 'USD', label: '$__currencyUSD', symbol: '$' },\r\n        { value: 'EUR', label: '$__currencyEUR', symbol: '€' },\r\n        // { value: 'CLP', label: '$__currencyCLP', symbol: '$' },\r\n        // { value: 'AUD', label: '$__currencyAUD', symbol: '$' },\r\n        // { value: 'NZD', label: '$__currencyNZD', symbol: '$' },\r\n        // { value: 'CNY', label: '$__currencyCNY', symbol: '¥' },\r\n        // { value: 'PYG', label: '$__currencyPYG', symbol: 'Gs' },\r\n        // { value: 'RUB', label: '$__currencyRUB', symbol: '₽' }\r\n    ],\r\n    expiresIn: [\r\n        // { value: '48h', label: '$__48hours' },\r\n        // { value: '24h', label: '$__24hours' },\r\n        { value: '12h', label: '$__12hours' },\r\n        { value: null, label: '$__6hours' },\r\n        { value: '3h', label: '$__3hours' },\r\n        { value: '1h', label: '$__1hour' },\r\n    ],\r\n    passwordExpire: [\r\n        { value: '30', label: '$__30days' },\r\n        { value: '60', label: '$__60days' },\r\n        { value: '90', label: '$__90days' },\r\n    ],\r\n    plans: [\r\n        {\r\n            value: 'p0', label: '$__saasPlanName0', settings: {\r\n                space: 5368709120,\r\n                admins: 1,\r\n                price: 0,\r\n                onBoarding: false,\r\n                brightAndConnected: {\r\n                    feed: false,\r\n                    feedDays: false,\r\n                    radarLimit: 25,\r\n                    // radarDays: 10,\r\n                    insight: false,\r\n                },\r\n                plan: {\r\n                    activeLimit: 2,\r\n                    planClient: false,\r\n                    clientAdmin: false,\r\n                    machenPlan: false,\r\n                    templates: false,\r\n                    guidelineLimit: 2,\r\n                    feedLimit: 4,\r\n                    radarLimit: 25,\r\n                    insightLimit: 25,\r\n                },\r\n                task: {\r\n                    activeLimit: 25,\r\n                    filter: false,\r\n                    kpi: false,\r\n                    timeSheet: false,\r\n                    recurrence: false\r\n                },\r\n                files: {\r\n                    uploadLimit: 26214400,\r\n                },\r\n                chat: {\r\n                    groupUsersLimit: 7,\r\n                },\r\n                support: {\r\n                    email: true,\r\n                    priority: 0,\r\n                    chat: false,\r\n                },\r\n                mobile: {\r\n\r\n                },\r\n                addOn: {\r\n                    learneng: false,\r\n                    denkenDiscount: 0,\r\n                },\r\n                onBoarding: {\r\n                    technician: false,\r\n                    custom: false,\r\n                }\r\n            }\r\n        },\r\n        {\r\n            value: 'p1', label: '$__saasPlanName1', settings: {\r\n                space: 26843545600,\r\n                admins: 1,\r\n                price: 149.00,\r\n                onBoarding: 0,\r\n                whiteLabel: false,\r\n                brightAndConnected: {\r\n                    feed: true,\r\n                    feedDays: 15,\r\n                    radarLimit: 0,\r\n                    // radarDays: 90,\r\n                    insight: true,\r\n                },\r\n                plan: {\r\n                    planLimit: 0,\r\n                    planClient: true,\r\n                    clientAdmin: 1,\r\n                    machenPlan: true,\r\n                    templates: true,\r\n                    guidelineLimit: 0,\r\n                    feedLimit: 0,\r\n                    radarLimit: 0,\r\n                    insightLimit: 0,\r\n                },\r\n                task: {\r\n                    activeLimit: 0,\r\n                    filter: true,\r\n                    kpi: true,\r\n                    timeSheet: true,\r\n                    recurrence: true\r\n                },\r\n                files: {\r\n                    uploadLimit: 104857600,\r\n                },\r\n                chat: {\r\n                    groupLimit: 0,\r\n                },\r\n                support: {\r\n                    email: true,\r\n                    priority: 0,\r\n                    chat: true,\r\n                },\r\n                mobile: {\r\n\r\n                },\r\n                addOn: {\r\n                    learneng: true,\r\n                    denkenDiscount: 5,\r\n                },\r\n                onBoarding: {\r\n                    technician: 1000,\r\n                    custom: 4990,\r\n                }\r\n            }\r\n        },\r\n        {\r\n            value: 'p2', label: '$__saasPlanName2', settings: {\r\n                space: 53687091200,\r\n                admins: 9,\r\n                price: 890.00,\r\n                onBoarding: 4990.00,\r\n                brightAndConnected: {\r\n                    feed: true,\r\n                    feedDays: 0,\r\n                    radarLimit: 0,\r\n                    // radarDays: 90,\r\n                    insight: true,\r\n                },\r\n                plan: {\r\n                    planLimit: 0,\r\n                    planClient: true,\r\n                    clientAdmin: 2,\r\n                    machenPlan: true,\r\n                    templates: true,\r\n                    guidelineLimit: 0,\r\n                    feedLimit: 0,\r\n                    radarLimit: 0,\r\n                    insightLimit: 0,\r\n                },\r\n                task: {\r\n                    activeLimit: 0,\r\n                    filter: true,\r\n                    kpi: true,\r\n                    timeSheet: true,\r\n                    recurrence: true\r\n                },\r\n                files: {\r\n                    uploadLimit: 314572800,\r\n                },\r\n                chat: {\r\n                    groupLimit: 0,\r\n                },\r\n                support: {\r\n                    email: true,\r\n                    priority: 0,\r\n                    chat: true,\r\n                },\r\n                mobile: {\r\n\r\n                },\r\n                addOn: {\r\n                    learneng: true,\r\n                    denkenDiscount: 0,\r\n                    whiteLabel: false,\r\n                },\r\n                onBoarding: {\r\n                    technician: 1000,\r\n                    custom: 4990,\r\n                }\r\n            }\r\n        },\r\n        {\r\n            value: 'p3', label: '$__saasPlanName3', settings: {\r\n                space: 107374182400,\r\n                admins: 19,\r\n                price: 1790.00,\r\n                onBoarding: 6990.00,\r\n                brightAndConnected: {\r\n                    feed: true,\r\n                    feedDays: 0,\r\n                    radarLimit: 0,\r\n                    // radarDays: 90,\r\n                    insight: true,\r\n                },\r\n                plan: {\r\n                    planLimit: 0,\r\n                    planClient: true,\r\n                    clientAdmin: 3,\r\n                    machenPlan: true,\r\n                    templates: true,\r\n                    guidelineLimit: 0,\r\n                    feedLimit: 0,\r\n                    radarLimit: 0,\r\n                    insightLimit: 0,\r\n                },\r\n                task: {\r\n                    activeLimit: 0,\r\n                    filter: true,\r\n                    kpi: true,\r\n                    timeSheet: true,\r\n                    recurrence: true\r\n                },\r\n                files: {\r\n                    uploadLimit: 314572800,\r\n                },\r\n                chat: {\r\n                    groupLimit: 0,\r\n                },\r\n                support: {\r\n                    email: true,\r\n                    priority: 0,\r\n                    chat: true,\r\n                },\r\n                mobile: {\r\n\r\n                },\r\n                addOn: {\r\n                    learneng: true,\r\n                    denkenDiscount: 0,\r\n                    whiteLabel: false,\r\n                },\r\n                onBoarding: {\r\n                    technician: 1000,\r\n                    custom: 4990,\r\n                }\r\n\r\n            }\r\n        },\r\n        {\r\n            value: 'p4', label: '$__saasPlanName4', settings: {\r\n                space: 214748364800,\r\n                admins: 49,\r\n                price: 3990.00,\r\n                onBoarding: 10990.00,\r\n                brightAndConnected: {\r\n                    feed: true,\r\n                    feedDays: 0,\r\n                    radarLimit: 0,\r\n                    // radarDays: 90,\r\n                    insight: true,\r\n                },\r\n                plan: {\r\n                    planLimit: 0,\r\n                    planClient: true,\r\n                    clientAdmin: 3,\r\n                    machenPlan: true,\r\n                    templates: true,\r\n                    guidelineLimit: 0,\r\n                    feedLimit: 0,\r\n                    radarLimit: 0,\r\n                    insightLimit: 0,\r\n                },\r\n                task: {\r\n                    activeLimit: 0,\r\n                    filter: true,\r\n                    kpi: true,\r\n                    timeSheet: true,\r\n                    recurrence: true\r\n                },\r\n                files: {\r\n                    uploadLimit: 314572800,\r\n                },\r\n                chat: {\r\n                    groupLimit: 0,\r\n                },\r\n                support: {\r\n                    email: true,\r\n                    priority: 0,\r\n                    chat: true,\r\n                },\r\n                mobile: {\r\n\r\n                },\r\n                addOn: {\r\n                    learneng: true,\r\n                    denkenDiscount: 0,\r\n                    whiteLabel: false,\r\n                },\r\n                onBoarding: {\r\n                    technician: 1000,\r\n                    custom: 4990,\r\n                }\r\n\r\n            }\r\n        },\r\n        {\r\n            value: 'p5', label: '$__saasPlanName5', settings: {\r\n                space: 0,\r\n                admins: 0,\r\n                price: 0,\r\n                onBoarding: 0,\r\n                brightAndConnected: {\r\n                    feed: true,\r\n                    feedDays: 0,\r\n                    radarLimit: 0,\r\n                    // radarDays: 90,\r\n                    insight: true,\r\n                },\r\n                plan: {\r\n                    planLimit: 0,\r\n                    planClient: true,\r\n                    clientAdmin: 3,\r\n                    machenPlan: true,\r\n                    templates: true,\r\n                    guidelineLimit: 0,\r\n                    feedLimit: 0,\r\n                    radarLimit: 0,\r\n                    insightLimit: 0,\r\n                },\r\n                task: {\r\n                    activeLimit: 0,\r\n                    filter: true,\r\n                    kpi: true,\r\n                    timeSheet: true,\r\n                    recurrence: true\r\n                },\r\n                files: {\r\n                    uploadLimit: 314572800,\r\n                },\r\n                chat: {\r\n                    groupLimit: 0,\r\n                },\r\n                support: {\r\n                    email: true,\r\n                    priority: 0,\r\n                    chat: true,\r\n                },\r\n                mobile: {\r\n\r\n                },\r\n                addOn: {\r\n                    learneng: true,\r\n                    denkenDiscount: 0,\r\n                    whiteLabel: false,\r\n                },\r\n                onBoarding: {\r\n                    technician: true,\r\n                    custom: 4990,\r\n                }\r\n\r\n            }\r\n        },\r\n    ],\r\n    type: [\r\n        { value: 'plan', label: '$__plan', icon: 'view_comfy', color: null, calendar: false },\r\n        { value: 'strength', label: '$__strength', icon: 'arrow_upward', color: null, calendar: false },\r\n        { value: 'weakness', label: '$__weakness', icon: 'arrow_downward', color: null, calendar: false },\r\n        { value: 'opportunity', label: '$__opportunity', icon: 'trending_up', color: null, calendar: false },\r\n        { value: 'threat', label: '$__threat', icon: 'trending_down', color: null, calendar: false },\r\n        { value: 'guideline', label: '$__guideline', icon: MatrixIcon, color: null, calendar: true },\r\n        { value: 'guidelineD', label: '$__guidelineD', icon: GuidelineD, color: null, calendar: true },\r\n        { value: 'guidelineR', label: '$__guidelineR', icon: GuidelineR, color: null, calendar: true },\r\n        { value: 'guidelineC', label: '$__guidelineC', icon: GuidelineC, color: null, calendar: true },\r\n        { value: 'guidelineE', label: '$__guidelineE', icon: GuidelineE, color: null, calendar: true },\r\n        { value: 'objective', label: '$__objective', icon: 'gps_fixed', color: null, calendar: true },\r\n        { value: 'goal', label: '$__goal', icon: 'flag', color: null, calendar: true },\r\n        { value: 'iniciative', label: '$__iniciative', icon: 'play_arrow', color: null, calendar: true },\r\n        { value: 'task', label: '$__task', icon: 'fact_check', color: null, calendar: true },\r\n        { value: 'meeting', label: '$__meeting', icon: 'meeting_room', color: null, calendar: true },\r\n        { value: 'myTask', label: '$__myTask', icon: 'person_pin', color: null, calendar: true },\r\n        { value: 'link', label: '$__radar', icon: 'public', color: null, calendar: true },\r\n        { value: 'insight', label: '$__insight', icon: BrightAndConnectedIcon, color: null, calendar: true },\r\n    ],\r\n    dateStatus: [\r\n        { value: 'notStarted', label: '$__notStarted', icon: 'query_builder' },\r\n        { value: 'inProgress', label: '$__inProgress', icon: 'play_circle_outline' },\r\n    ],\r\n    priority: [\r\n        { value: null, label: '$__none', color: '#c6c6c6' },\r\n        { value: 'normal', label: '$__normal', color: '#c6c6c6' },\r\n        { value: 'low', label: '$__low', color: '#faba00' },\r\n        { value: 'medium', label: '$__medium', color: '#ff7c32' },\r\n        { value: 'high', label: '$__high', color: '#ff0000' }\r\n    ],\r\n    automation: [\r\n        { value: 'doNotChange', label: '$__doNotChange' },\r\n        { value: 'replace', label: '$__replaceWith' },\r\n        { value: 'add', label: '$__add' },\r\n        { value: 'remove', label: '$__remove' },\r\n    ],\r\n    fileExtensions: [\r\n        { ext: ['jpg', 'jpeg', 'jpe', 'jfif', 'gif', 'png', 'webp', 'svg', 'eps'], icon: false, title: 'image', viewer: 'img' },\r\n        { ext: ['txt'], icon: 'description', title: 'Text', viewer: 'text' },\r\n        { ext: ['doc', 'docx', 'dot', 'doc', 'dotx'], icon: MicrosoftWord, title: 'Microsoft Word', viewer: 'microsoft' },\r\n        { ext: ['xls', 'xlt', 'ooxml', 'xlsx'], icon: MicrosoftExcel, title: 'Microsoft Excel', viewer: 'microsoft' },\r\n        { ext: ['ppt', 'pptx', 'ppsx', 'sldx'], icon: MicrosoftPowerpoint, title: 'Microsoft PowerPoint', viewer: 'microsoft' },\r\n        { ext: ['pdf'], icon: PDF, title: 'PDF', viewer: 'pdf' },\r\n        { ext: ['aac', 'wav', 'ts', 'smf', 'ogg', 'mp3', '3gp', 'caf', 'm4a'], icon: 'audiotrack', title: 'audioFile', viewer: 'audio' },\r\n        { ext: ['avi', 'mov', 'mp4', '3gpp'], icon: 'movie', title: 'movieFile', viewer: 'movie' }\r\n    ],\r\n    access: [\r\n        {\r\n            name: '$__admin',\r\n            permissions: {\r\n                create: true,\r\n                read: true,\r\n                run: true,\r\n                update: true,\r\n                delete: true,\r\n                moderate: true,\r\n                levels: 0 //0=infinito\r\n            }\r\n        },\r\n        {\r\n            name: '$__manager',\r\n            permissions: {\r\n                create: true,\r\n                read: true,\r\n                run: true,\r\n                update: true,\r\n                delete: true,\r\n                moderate: true,\r\n                levels: 0 //0=infinito\r\n            }\r\n        },\r\n        {\r\n            name: '$__user',\r\n            permissions: {\r\n                create: true,\r\n                read: true,\r\n                run: true,\r\n                update: false,\r\n                delete: false,\r\n                moderate: false,\r\n                levels: 0 //0=infinito\r\n            }\r\n        },\r\n        {\r\n            name: '$__guest',\r\n            permissions: {\r\n                create: false,\r\n                read: true,\r\n                run: true,\r\n                update: false,\r\n                delete: false,\r\n                moderate: false,\r\n                levels: 1 //0=infinito\r\n            }\r\n        }\r\n    ],\r\n    tag: [],\r\n    userGroup: [],\r\n    dataType: [\r\n        {\r\n            name: 'user',\r\n            icon: 'contact_page',\r\n            module: 'user',\r\n            reqId: false,\r\n            view: {\r\n                'c': {\r\n                    pages: ['users'],\r\n                    access: ['userAdmin', 'userModerate', 'master']\r\n                },\r\n            },\r\n            hash: null,\r\n            db: 'users',\r\n            iniModule: 'userEdit',\r\n            modules: ['resumeUser', 'userEdit', 'access', 'twoFactor', 'cards', 'mobile', 'settings', 'delete'],\r\n            requireFields: ['name', 'email'],\r\n            hideFields: ['independentAccount'],\r\n            disabledFields: [],\r\n            data: {\r\n                type: \"user\"\r\n            },\r\n            sharedIn: {\r\n                attach: [],\r\n                copy: [],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'user',\r\n            icon: 'contact_page',\r\n            module: 'user',\r\n            reqId: false,\r\n            view: {\r\n                'c': {\r\n                    pages: ['units'],\r\n                    access: ['userAdmin', 'userModerate', 'master']\r\n                },\r\n            },\r\n            hash: true,\r\n            db: 'users',\r\n            iniModule: 'userEdit',\r\n            modules: ['resumeUser', 'userEdit', 'access', 'twoFactor', 'cards', 'mobile', 'settings', 'delete'],\r\n            requireFields: ['name', 'email'],\r\n            hideFields: ['independentAccount'],\r\n            disabledFields: [],\r\n            data: {\r\n                type: \"user\"\r\n            },\r\n            sharedIn: {\r\n                attach: [],\r\n                copy: [],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'group',\r\n            icon: 'groups',\r\n            module: 'user',\r\n            reqId: false,\r\n            view: {\r\n                'c': {\r\n                    pages: ['units'],\r\n                    access: ['userAdmin', 'userModerate'],\r\n                    noId: true\r\n                },\r\n            },\r\n            hash: null,\r\n            db: 'cards',\r\n            iniModule: 'userEdit',\r\n            modules: ['userEdit', 'delete', 'settings'],\r\n            requireFields: ['name'],\r\n            disabledFields: ['email'],\r\n            hideFields: ['independentAccount'],\r\n            data: {\r\n                type: \"group\"\r\n            },\r\n        },\r\n        {\r\n            name: 'client',\r\n            icon: 'business',\r\n            module: 'user',\r\n            reqId: false,\r\n            view: {\r\n                'c': {\r\n                    pages: ['units'],\r\n                    access: ['userAdmin', 'userModerate'],\r\n                    noId: true\r\n                },\r\n            },\r\n            hash: null,\r\n            db: 'cards',\r\n            iniModule: 'userEdit',\r\n            modules: ['userEdit', 'delete', 'settings'],\r\n            requireFields: ['name'],\r\n            disabledFields: ['email'],\r\n            hideFields: [],\r\n            data: {\r\n                type: \"client\"\r\n            },\r\n        },\r\n        {\r\n            name: 'unity',\r\n            icon: 'badge',\r\n            module: 'user',\r\n            reqId: false,\r\n            view: {\r\n                'c': {\r\n                    pages: ['units'],\r\n                    access: ['master'],\r\n                    noId: true\r\n                },\r\n            },\r\n            hash: null,\r\n            db: 'users',\r\n            iniModule: 'userEdit',\r\n            modules: ['userEdit', 'delete', 'settings'],\r\n            requireFields: ['name'],\r\n            disabledFields: ['email'],\r\n            data: {\r\n                type: \"client\"\r\n            },\r\n        },\r\n        {\r\n            name: 'step',\r\n            icon: '123',\r\n            module: 'step',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'columnEdit',\r\n            modules: ['columnEdit', 'users', 'flow', 'delete', 'log'],\r\n            requireFields: ['name'],\r\n            disabledFields: [],\r\n            fieldsTitle: {\r\n                name: '$__columnName',\r\n                placeholder: '$__columnPlaceholder'\r\n            },\r\n            sharedIn: {\r\n                attach: [],\r\n                copy: [],\r\n                shared: []\r\n            }\r\n        },\r\n        {\r\n            name: 'chatGroup',\r\n            icon: 'group_work',\r\n            module: 'chat',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['cardEdit', 'users', 'files', 'delete', 'log'],\r\n            hideFields: ['image', 'progress', 'status', 'tags', 'deadline', 'priority', 'recurrence', 'plan'],\r\n            requireFields: ['name'],\r\n            disabledFields: [],\r\n            fieldsTitle: {\r\n                name: '$__groupName',\r\n                placeholder: '$__groupNamePlaceholder'\r\n            },\r\n            sharedIn: {\r\n                attach: [],\r\n                copy: [],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'feed',\r\n            icon: 'rss_feed',\r\n            module: 'feeds',\r\n            reqId: false,\r\n            view: {\r\n                'bright-and-connected': {\r\n                    pages: ['feeds'],\r\n                },\r\n                'sp': {\r\n                    pages: ['bright-and-connected']\r\n                }\r\n            },\r\n            db: 'feeds',\r\n            iniModule: 'feedEdit',\r\n            modules: ['resumeFeed', 'feedEdit'],\r\n            disabledFields: [],\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: [],\r\n                copy: ['plan', 'client'],\r\n                shared: []\r\n            }\r\n        },\r\n        {\r\n            name: 'link',\r\n            icon: 'public',\r\n            module: 'insights',\r\n            reqId: true,\r\n            view: {\r\n                'bright-and-connected': {\r\n                    pages: ['radar']\r\n                },\r\n                'sp': {\r\n                    pages: ['radar']\r\n                }\r\n            },\r\n            hash: null,\r\n            db: 'cards',\r\n            iniModule: 'link',\r\n            modules: ['resumeLink', 'cardEdit', 'checklist', 'steps', 'timeline', 'sendTo', 'log', 'users', 'files', 'timeLog', 'settings', 'delete', 'myDay'],\r\n            hideFields: ['image', 'status', 'client', 'recurrence'],\r\n            disabledFields: ['url'],\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan', 'client'],\r\n                copy: ['plan', 'client'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'insight',\r\n            icon: BrightAndConnectedIcon,\r\n            module: 'insights',\r\n            reqId: true,\r\n            view: {\r\n                'bright-and-connected': {\r\n                    pages: ['insight-boards']\r\n                },\r\n                'sp': {\r\n                    pages: ['insight-boards']\r\n                }\r\n            },\r\n            hash: null,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resumeLink', 'cardEdit', 'checklist', 'timeline', 'sendTo', 'log', 'users', 'files', 'timeLog', 'settings', 'delete', 'myDay'],\r\n            hideFields: ['image', 'status', 'client', 'recurrence'],\r\n            // disabledFields: ['url'],\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan', 'client'],\r\n                copy: ['plan', 'client'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'plan',\r\n            icon: 'view_comfy',\r\n            module: 'plan',\r\n            reqId: false,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['StrategyAndPlans', 'home'],\r\n                },\r\n            },\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'steps', 'timeline', 'users', 'sendTo', 'log', 'files', 'timeLog', 'delete', 'settings'],\r\n            hideFields: ['image', 'recurrence'],\r\n            requireFields: ['name'],\r\n            disabledFields: [],\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            loadChildrens: true,\r\n            sharedIn: {\r\n                attach: [],\r\n                copy: ['client'],\r\n                shared: []\r\n            },\r\n            fieldsTitle: {\r\n                name: \"$__planName\",\r\n                placeholder: \"$__setPlanName\"\r\n            }\r\n        }, {\r\n            name: 'plan',\r\n            icon: 'tips_and_updates',\r\n            module: 'plan',\r\n            reqId: false,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['templates'],\r\n                },\r\n            },\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'steps', 'templateOptions', 'steps', 'timeline', 'files', 'delete'],\r\n            hideFields: ['image', 'recurrence'],\r\n            requireFields: ['name'],\r\n            disabledFields: [],\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            fieldsTitle: {\r\n                name: \"$__planName\",\r\n                placeholder: \"$__setPlanName\"\r\n            },\r\n\r\n        },\r\n        {\r\n            name: 'objective',\r\n            icon: 'gps_fixed',\r\n            module: 'planning',\r\n            myTasks: true,\r\n            reqId: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['objectives'],\r\n                },\r\n            },\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'catenation', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'budget', 'myDay', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image', 'client'],\r\n            requireFields: ['name'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            loadChildrens: true,\r\n            sharedIn: {\r\n                attach: [\r\n                    'plan',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                ],\r\n                copy: [\r\n                    'plan',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                ],\r\n                shared: [\r\n                    'plan',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'goal',\r\n            icon: 'flag',\r\n            module: 'planning',\r\n            myTasks: true,\r\n            reqId: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['goals'],\r\n                },\r\n            },\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'catenation', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'budget', 'myDay', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image', 'client'],\r\n            requireFields: ['name'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            loadChildrens: true,\r\n            sharedIn: {\r\n                attach: [\r\n                    'plan',\r\n                    'objective',\r\n                ],\r\n                copy: [\r\n                    'plan',\r\n                    'objective',\r\n                ],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'iniciative', //action\r\n            icon: 'play_arrow',\r\n            module: 'agile',\r\n            myTasks: true,\r\n            reqId: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['agile', 'actions', 'dashboard'],\r\n                },\r\n                't': {\r\n                    pages: ['myDay', 'ourDay', 'allTasks', 'unlinkedCards', 'myTasks']\r\n                },\r\n            },\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'budget', 'myDay', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image', 'client'],\r\n            requireFields: ['name'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: [\r\n                    'plan',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'myTask',\r\n                ],\r\n                copy: [\r\n                    'plan',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'myTask',\r\n                ],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'myTask',\r\n            alias: 'task',\r\n            icon: 'person_pin',\r\n            module: 'myTasks',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'sendTo', 'myDay', 'client', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            myTasks: true,\r\n            // view: {\r\n            //     't': {\r\n            //         pages: ['myDay'],\r\n            //     },\r\n            // },\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ],\r\n                copy: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'task',\r\n            icon: 'fact_check',\r\n            module: 'agile',\r\n            myTasks: true,\r\n            reqId: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['agile', 'actions', 'dashboard'],\r\n                },\r\n                't': {\r\n                    pages: ['myDay', 'ourDay', 'allTasks', 'unlinkedCards', 'myTasks'],\r\n                },\r\n            },\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'budget', 'myDay', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image', 'client'],\r\n            requireFields: ['name'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: [\r\n                    'plan',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'myTask',\r\n                ],\r\n                copy: [\r\n                    'plan',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'myTask',\r\n                ],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'meeting',\r\n            icon: 'meeting_room',\r\n            module: 'agile',\r\n            myTasks: true,\r\n            reqId: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['agile', 'actions', 'dashboard'],\r\n                },\r\n                't': {\r\n                    pages: ['myDay', 'ourDay', 'allTasks', 'unlinkedCards', 'myTasks']\r\n                },\r\n            },\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'myDay', 'budget', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image', 'client'],\r\n            requireFields: ['name', 'startDate'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: [\r\n                    'plan',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'myTask',\r\n                ],\r\n                copy: [\r\n                    'plan',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'myTask',\r\n                ],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'strength',\r\n            icon: 'arrow_upward',\r\n            module: 'swot',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'timeline', 'log', 'files', 'timeLog', 'delete'],\r\n            hideFields: ['image', 'imageUpload', 'deadline', 'progress', 'priority', 'status', 'client', 'private'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan'],\r\n                copy: ['plan'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'weakness',\r\n            icon: 'arrow_downward',\r\n            module: 'swot',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'timeline', 'log', 'files', 'timeLog', 'delete'],\r\n            hideFields: ['image', 'imageUpload', 'deadline', 'progress', 'priority', 'status', 'client', 'private'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan'],\r\n                copy: ['plan'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'opportunity',\r\n            icon: 'trending_up',\r\n            module: 'swot',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'timeline', 'log', 'files', 'timeLog', 'delete'],\r\n            hideFields: ['image', 'imageUpload', 'deadline', 'progress', 'priority', 'status', 'client', 'private'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan'],\r\n                copy: ['plan'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'threat',\r\n            icon: 'trending_down',\r\n            module: 'swot',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'timeline', 'log', 'files', 'timeLog', 'delete'],\r\n            hideFields: ['image', 'imageUpload', 'deadline', 'progress', 'priority', 'status', 'client', 'private'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan'],\r\n                copy: ['plan'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'guideline',\r\n            icon: MatrixIcon,\r\n            module: 'matrix',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'catenation', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'myDay', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['client'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['guidelines', 'matrix'],\r\n                },\r\n            },\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan'],\r\n                copy: ['plan'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'guidelineD',\r\n            icon: GuidelineD,\r\n            module: 'matrix',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'catenation', 'steps', 'timeline', 'kpi', 'users', 'myDay', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image', 'imageUpload', 'client', 'recurrence'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            myTasks: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['matrix', 'guidelines'],\r\n                },\r\n            },\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan'],\r\n                copy: ['plan'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'guidelineR',\r\n            icon: GuidelineR,\r\n            module: 'matrix',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'catenation', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'myDay', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image', 'imageUpload', 'client', 'recurrence'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            myTasks: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['matrix', 'guidelines'],\r\n                },\r\n            },\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan'],\r\n                copy: ['plan'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'guidelineE',\r\n            icon: GuidelineE,\r\n            module: 'matrix',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'catenation', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'myDay', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image', 'imageUpload', 'client', 'recurrence'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            myTasks: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['matrix', 'guidelines'],\r\n                },\r\n            },\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan'],\r\n                copy: ['plan'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            name: 'guidelineC',\r\n            icon: GuidelineC,\r\n            module: 'matrix',\r\n            reqId: true,\r\n            db: 'cards',\r\n            iniModule: 'cardEdit',\r\n            modules: ['resume', 'cardEdit', 'checklist', 'catenation', 'steps', 'recurrence', 'timeline', 'kpi', 'users', 'myDay', 'sendTo', 'log', 'files', 'timeLog', 'settings', 'delete'],\r\n            hideFields: ['image', 'imageUpload', 'client', 'recurrence'],\r\n            disabledFields: [],\r\n            sendTo: true,\r\n            myTasks: true,\r\n            view: {\r\n                'sp': {\r\n                    pages: ['matrix', 'guidelines'],\r\n                },\r\n            },\r\n            data: {\r\n                status: \"notStarted\"\r\n            },\r\n            sharedIn: {\r\n                attach: ['plan'],\r\n                copy: ['plan'],\r\n                shared: [\r\n                    'plan',\r\n                    'objective',\r\n                    'goal',\r\n                    'iniciative',\r\n                    'task',\r\n                    'meeting',\r\n                    'chatGroup',\r\n                    'strength',\r\n                    'weakness',\r\n                    'opportunity',\r\n                    'threat',\r\n                    'guideline',\r\n                    'guidelineD',\r\n                    'guidelineR',\r\n                    'guidelineE',\r\n                    'guidelineC',\r\n                    'myTask',\r\n                    'user'\r\n                ]\r\n            }\r\n        },\r\n\r\n        {\r\n            name: 'swot',\r\n            icon: SwotIcon,\r\n            db: 'cards',\r\n            hash: ['matrix'],\r\n        },\r\n        {\r\n            name: 'matrix',\r\n            icon: MatrixIcon,\r\n            db: 'cards',\r\n            hash: ['matrix'],\r\n        },\r\n    ],\r\n    cards: {},\r\n    users: {},\r\n    feeds: {},\r\n    notifications: {},\r\n    loaded: false,\r\n    viewList: false,\r\n    myTasksMenuExpanded: false,\r\n    adminView: false,\r\n    adminViewLoader: false,\r\n    orderByTitle: true,\r\n    orderByTitlePosition: 'ASC',\r\n    groupByColor: false,\r\n}\r\n\r\nconst session = (state = initialState, data) => {\r\n    if (data.action === 'SET_DB' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    }\r\n    else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default session;","import MD5 from \"crypto-js/md5\";\r\nimport moment from \"moment-timezone\";\r\n\r\n//REDUX\r\nimport reduxStore from \"store/\";\r\n\r\n//API\r\nimport apims from \"apims\"\r\n\r\nlet ld = []\r\n\r\nlet newCards = {}\r\n\r\nconst loadCardsV2 = async (props, data) => {\r\n    // const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\r\n    const {\r\n        idRel,\r\n        adminView = false,\r\n        callback = null,\r\n        cardLoad = \"my\",\r\n        completed = false,\r\n        status,\r\n        deleted = false,\r\n        archived = false,\r\n        templates = false,\r\n        allStatus = false,\r\n        search = \"\",\r\n        completedDays = 7,\r\n        limit = 0,\r\n        skip = 0,\r\n        startDate = null,\r\n        endDate = null,\r\n    } = data\r\n\r\n    let ignoreLoader = data.ignoreLoader ? true : false\r\n    if (cardLoad === 'search' || props.ignoreLoader)\r\n        ignoreLoader = true\r\n\r\n    // if (cardLoad === 'search' && (search === \"\" || !search)){\r\n    //     return true\r\n    // }\r\n\r\n\r\n\r\n    const { sessionLoads } = reduxStore.getState()\r\n    let loads = {\r\n        ...sessionLoads.cards.load\r\n    }\r\n\r\n    let reqMd5 = MD5(`${JSON.stringify(data)}`).toString()\r\n\r\n    if (Object.keys(loads).length > 0 && loads[reqMd5])\r\n        return true\r\n\r\n\r\n    if (!ignoreLoader)\r\n        props.reduxFunction(\"ASYNC\", \"SET_SESSION_LOADS\", {\r\n            ...reduxStore.getState().sessionLoads,\r\n            cards: {\r\n                ...reduxStore.getState().sessionLoads.cards,\r\n                load: {\r\n                    ...reduxStore.getState().sessionLoads.cards.load,\r\n                    [reqMd5]: ignoreLoader ? \"completed\" : \"loading\",\r\n                }\r\n            }\r\n        })\r\n\r\n    let subtractDays = String(reduxStore.getState().session.dashboard.period).replace('$__last', '')\r\n    subtractDays = subtractDays.replace('Days', '')\r\n\r\n\r\n    const load = await new Promise(async (resolve) => {\r\n        try {\r\n            let cards = await apims.post(`/Card_List/`,\r\n                {\r\n                    //Parametros\r\n                    idRel,\r\n                    adminView,\r\n                    load: cardLoad,\r\n                    completed,\r\n                    archived,\r\n                    templates,\r\n                    status,\r\n                    allStatus,\r\n                    limit,\r\n                    skip,\r\n                    startDate,\r\n                    endDate,\r\n                    ...completed ? {\r\n                        completedDays: completedDays || subtractDays\r\n                    } : {},\r\n                    ...search ? { search: search } : {},\r\n                    ...deleted ? { deleted: true } : {},\r\n                }\r\n            )\r\n            if (cards && cards.data) {\r\n                let reqData = cards.data\r\n                // console.log(reqData)\r\n\r\n                let mount = await mountCards(props, reqData)\r\n                if (mount) {\r\n                    props.reduxFunction(\"ASYNC\", \"SET_SESSION_LOADS\", {\r\n                        ...reduxStore.getState().sessionLoads,\r\n                        cards: {\r\n                            ...reduxStore.getState().sessionLoads.cards,\r\n                            load: {\r\n                                ...reduxStore.getState().sessionLoads.cards.load,\r\n                                [reqMd5]: \"completed\",\r\n                            }\r\n                        }\r\n                    })\r\n                    if (callback)\r\n                        callback()\r\n                    resolve({ total: reqData.length, cards: mount })\r\n                }\r\n            }\r\n\r\n        } catch (e) {\r\n            console.log('loadCards::ERR::')\r\n            console.log(e)\r\n        }\r\n    })\r\n\r\n    if (load) {\r\n        props.reduxFunction(\"ASYNC\", \"preLoader\", {\r\n            ...reduxStore.getState().preLoader,\r\n            cards: false\r\n        })\r\n        return load\r\n    }\r\n}\r\n\r\nconst reqCards = async (props, data) => {\r\n    if (ld.indexOf(JSON.stringify(ld)) === -1) {\r\n        ld.push(JSON.stringify(ld))\r\n    }\r\n    const today = moment().tz('America/Sao_Paulo').format('YYYY/MM/DD');\r\n    const {\r\n        idRel,\r\n        adminView = false,\r\n        callback = null,\r\n        cardLoad = \"my\",\r\n        completed = false,\r\n        status,\r\n        deleted = false,\r\n        archived = false,\r\n        templates = false\r\n    } = data\r\n\r\n    let ignoreLoader = false\r\n    if (cardLoad === 'search' || props.ignoreLoader)\r\n        ignoreLoader = true\r\n\r\n    const { sessionLoads } = reduxStore.getState()\r\n    let loads = {\r\n        ...sessionLoads.cards.load\r\n    }\r\n\r\n    let reqMd5 = MD5(`${JSON.stringify(data)}`).toString()\r\n    if (Object.keys(loads).length > 0 && loads[reqMd5])\r\n        return true\r\n\r\n\r\n    props.reduxFunction(\"ASYNC\", \"SET_SESSION_LOADS\", {\r\n        ...reduxStore.getState().sessionLoads,\r\n        cards: {\r\n            ...reduxStore.getState().sessionLoads.cards,\r\n            load: {\r\n                ...reduxStore.getState().sessionLoads.cards.load,\r\n                [reqMd5]: ignoreLoader ? \"completed\" : \"loading\",\r\n            }\r\n        }\r\n    })\r\n    const load = await new Promise(async (resolve, reject) => {\r\n        try {\r\n            let cards = await apims.post(`/Card_List/`,\r\n                {\r\n                    //Parametros\r\n                    idRel,\r\n                    adminView,\r\n                    load: cardLoad,\r\n                    completed,\r\n                    archived,\r\n                    templates,\r\n                    status,\r\n                    ...props.search ? { search: props.search } : {},\r\n                    ...deleted || props.deleted ? { deleted: true } : {},\r\n                }\r\n            )\r\n            if (cards && cards.data) {\r\n\r\n\r\n                let reqData = cards.data\r\n\r\n                let mount = await mountCards(props, reqData)\r\n                if (mount) {\r\n\r\n\r\n                    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                        ...reduxStore.getState().db,\r\n                        cards: {\r\n                            ...reduxStore.getState().db.cards,\r\n                            ...newCards\r\n                        },\r\n                    }, () => {\r\n                    });\r\n                    // if (!ignoreLoader)\r\n                    props.reduxFunction(\"ASYNC\", \"SET_SESSION_LOADS\", {\r\n                        ...reduxStore.getState().sessionLoads,\r\n                        cards: {\r\n                            ...reduxStore.getState().sessionLoads.cards,\r\n                            load: {\r\n                                ...reduxStore.getState().sessionLoads.cards.load,\r\n                                [reqMd5]: \"completed\",\r\n                            }\r\n                        }\r\n                    })\r\n                    if (callback)\r\n                        callback()\r\n                    resolve(mount)\r\n                }\r\n            }\r\n\r\n        } catch (e) {\r\n            console.log('loadCards::ERR::')\r\n            console.log(e)\r\n        }\r\n    })\r\n\r\n    if (load) {\r\n        newCards = {}\r\n        props.reduxFunction(\"ASYNC\", \"preLoader\", {\r\n            ...reduxStore.getState().preLoader,\r\n            cards: false\r\n        })\r\n        return load\r\n    }\r\n}\r\n\r\nconst mountCards = async (props, ndata = []) => {\r\n    const { session } = reduxStore.getState()\r\n\r\n    const filterCards = (d) => {\r\n        if (d\r\n            && d.data\r\n            && d.data._id\r\n            && (\r\n                (!d.data.private || d.data.private === false)\r\n                ||\r\n                (\r\n                    d.data.private\r\n                    && (\r\n                        d.users.filter(u => u._id === session._id).length > 0\r\n                    )\r\n                )\r\n            )\r\n        )\r\n            return true\r\n        return false\r\n    }\r\n    let mount = await new Promise((resolve, reject) => {\r\n        let newCards = {}\r\n        if (\r\n            ndata\r\n            && ndata.filter(d => filterCards(d)).length > 0) {\r\n            ndata.filter(d => filterCards(d)).map((d, i) => {\r\n                let a = d.data._id\r\n                if (\r\n                    !reduxStore.getState().db.cards[d.data._id]\r\n                ) {\r\n                    let users = {}\r\n                    let groups = {}\r\n                    let showGroups = []\r\n                    if (d.users.length > 0) {\r\n                        d.users\r\n                            .filter(user =>\r\n                                user._id\r\n                            )\r\n                            .map(user => {\r\n                                let myDay = null\r\n                                if (d && d.myDayUsers && d.myDayUsers.filter(a => a._id).length > 0) {\r\n                                    myDay = d.myDayUsers.filter(a =>\r\n                                        a._id === user._id\r\n                                    ).length > 0 ?\r\n                                        d.myDayUsers.filter(a =>\r\n                                            a._id === user._id\r\n                                        )[0].date\r\n                                        : null\r\n                                }\r\n\r\n                                users = {\r\n                                    ...users,\r\n                                    [user._id]: {\r\n                                        ...user,\r\n                                        ...myDay ? { myDay } : {}\r\n                                    }\r\n                                }\r\n                            })\r\n                    }\r\n                    if (d.data.type === \"step\" && d.showGroups?.filter(group => group.value).length > 0) {\r\n                        showGroups = d.showGroups.filter(group => group.value)\r\n                        // .map(group => {\r\n                        //     showGroups = {\r\n                        //         ...showGroups,\r\n                        //         [group._id]: {\r\n                        //             ...group,\r\n                        //         }\r\n                        //     }\r\n                        // })\r\n                    }\r\n                    if (d.groups?.filter(group => group._id).length > 0) {\r\n                        d.groups.filter(group => group._id).map(group => {\r\n                            groups = {\r\n                                ...groups,\r\n                                [group._id]: {\r\n                                    ...group,\r\n                                }\r\n                            }\r\n                        })\r\n                    }\r\n                    if (d && d.data && d.data.planId)\r\n                        delete d.data.planId\r\n                    // if (d.createdBy && d.createdBy[0] && d.createdBy[0].channel)\r\n                    //     console.log({\r\n                    //         ...reduxStore.getState().db.cards[a] && reduxStore.getState().db.cards[a]._selected ? { _selected: true } : {},\r\n                    //         ...d.data,\r\n                    //         _cardCode: d.cardCode,\r\n                    //         _requireApproval: d.requireApproval || false,\r\n                    //         _isFavorite: String(d.favorite) === 'false' ? true : false,\r\n                    //         ...d.account ? { _account: MD5(d.account).toString() } : {},\r\n                    //         ...d && d.createdBy && d.createdBy.filter(a => a._id).length > 0 ? { _createdBy: d.createdBy.filter(a => a._id)[0] } : {},\r\n                    //         ...d.myDay ? { _myDay: d.myDay } : {},\r\n                    //         ...d.parent ? { _parent: d.parent } : {},\r\n                    //         ...d.plan ? { _planId: d.plan } : {},\r\n                    //         ...d.users ? { _users: users } : {},\r\n                    //         ...d.groups ? { _groups: groups } : {},\r\n                    //         ...d.tags ? { _tags: d.tags } : {},\r\n                    //         ...d.aspects ? { _aspects: d.aspects } : {},\r\n                    //         ...d.inFlow ? { _hasStep: d.inFlow } : {},\r\n                    //         ...showGroups && showGroups.length > 0 ? { showGroups: showGroups } : {},\r\n                    //         _notifications: d.notifications,\r\n                    //         ...d.parentCompleted\r\n                    //             && d.parentCompleted.card\r\n                    //             ?\r\n                    //             {\r\n                    //                 _parentCompleted: d.parentCompleted,\r\n                    //                 status: \"completed\",\r\n                    //                 completed_at: {\r\n                    //                     low: d.parentCompleted.date ? d.parentCompleted.date : d.updated_at && d.updated_at.low ? d.updated_at.low : null\r\n                    //                 }\r\n                    //             } : {},\r\n\r\n                    //         ...d.timer ? {\r\n                    //             _kpiTimer: {\r\n                    //                 [d.timer._id]: {\r\n                    //                     ...d.timer,\r\n                    //                     userId: session._id\r\n                    //                 }\r\n                    //             }\r\n                    //         } : {},\r\n                    //         ...d.parentPrivate ? { private: true } : {},\r\n                    //     })\r\n                    newCards = {\r\n                        ...newCards,\r\n                        [a]: {\r\n                            ...reduxStore.getState().db.cards[a] && reduxStore.getState().db.cards[a]._selected ? { _selected: true } : {},\r\n                            ...d.data,\r\n                            _cardCode: d.cardCode,\r\n                            _requireApproval: d.requireApproval || false,\r\n                            _isFavorite: String(d.favorite) === 'false' ? true : false,\r\n                            ...d.account ? { _account: MD5(d.account).toString() } : {},\r\n                            ...d && d.createdBy && d.createdBy.filter(a => a._id).length > 0 ? { _createdBy: d.createdBy.filter(a => a._id)[0] } : {},\r\n                            ...d.myDay ? { _myDay: d.myDay } : {},\r\n                            ...d.parent ? { _parent: d.parent } : {},\r\n                            ...d.plan ? { _planId: d.plan } : {},\r\n                            ...d.users ? { _users: users } : {},\r\n                            ...d.groups ? { _groups: groups } : {},\r\n                            ...d.tags ? { _tags: d.tags } : {},\r\n                            ...d.aspects ? { _aspects: d.aspects } : {},\r\n                            ...d.inFlow ? { _hasStep: d.inFlow } : {},\r\n                            ...showGroups && showGroups.length > 0 ? { showGroups: showGroups } : {},\r\n                            _notifications: d.notifications,\r\n                            ...d.parentCompleted\r\n                                && d.parentCompleted.card\r\n                                ?\r\n                                {\r\n                                    _parentCompleted: d.parentCompleted,\r\n                                    status: \"completed\",\r\n                                    completed_at: {\r\n                                        low: d.parentCompleted.date ? d.parentCompleted.date : d.updated_at && d.updated_at.low ? d.updated_at.low : null\r\n                                    }\r\n                                } : {},\r\n\r\n                            ...d.timer ? {\r\n                                _kpiTimer: {\r\n                                    [d.timer._id]: {\r\n                                        ...d.timer,\r\n                                        userId: session._id\r\n                                    }\r\n                                }\r\n                            } : {},\r\n                            ...d.parentPrivate ? { private: true } : {},\r\n                        },\r\n                    }\r\n                }\r\n                if (i + 1 === ndata.filter(d => filterCards(d)).length)\r\n                    resolve(newCards)\r\n            })\r\n        } else {\r\n            resolve({})\r\n        }\r\n    })\r\n    if (mount) {\r\n        props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n            ...reduxStore.getState().db,\r\n            cards: {\r\n                ...reduxStore.getState().db.cards,\r\n                ...mount\r\n            },\r\n        }, () => {\r\n        });\r\n        return mount\r\n    }\r\n}\r\nconst loadCards = async (props, idRel, adminView = false, callback = null, cardLoad = \"my\", completed = false, status, ignoreLoader = false) => {\r\n    let res = await loadCardsV2(props, {\r\n        idRel,\r\n        adminView,\r\n        callback,\r\n        cardLoad,\r\n        completed,\r\n        status,\r\n        ignoreLoader\r\n    })\r\n    if (res)\r\n        return res\r\n    return false\r\n}\r\n\r\nconst loadFiles = async (props, nodeId, dbR, searchText, skip = null, limit = null) => {\r\n    let db = dbR ? dbR : 'cards'\r\n    let result = await new Promise(async (resolve, reject) => {\r\n        if (typeof nodeId === 'string') {\r\n            try {\r\n                let reqFiles = await apims.post(`/M_Files_List/`,\r\n                    {\r\n                        nodeId,\r\n                        skip,\r\n                        limit,\r\n                        searchText\r\n                    }\r\n                )\r\n                if (reqFiles && reqFiles.data) {\r\n                    let data = reqFiles.data\r\n                    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                        ...reduxStore.getState().db,\r\n                        [db]: {\r\n                            ...reduxStore.getState().db[db],\r\n                            [nodeId]: {\r\n                                ...reduxStore.getState().db[db][nodeId],\r\n                                _files: {\r\n                                    ...reduxStore.getState().db[db][nodeId]._files ? reduxStore.getState().db[db][nodeId]._files : {},\r\n                                    ...data[nodeId],\r\n                                },\r\n                            }\r\n                        }\r\n                    });\r\n                    resolve(true)\r\n                }\r\n            } catch (e) {\r\n                console.group('loadFiles::ERR::')\r\n                console.log(e)\r\n                console.groupEnd()\r\n                reject(true)\r\n            }\r\n        } else if (typeof nodeId === 'object') {\r\n            try {\r\n                let reqFiles = await apims.post(`/M_Files_List/`,\r\n                    {\r\n                        nodesIds: nodeId\r\n                    }\r\n                )\r\n                if (reqFiles && reqFiles.data) {\r\n                    let data = reqFiles.data\r\n                    let cardsUpdate = {}\r\n                    Object.keys(data).map(id => {\r\n                        cardsUpdate = {\r\n                            ...cardsUpdate,\r\n                            [id]: {\r\n                                ...reduxStore.getState().db[db][id],\r\n                                _files: data[id],\r\n                                _loadedFiles: true,\r\n                            }\r\n                        }\r\n                    })\r\n                    props.reduxFunction(\"ASYNC\", \"SET_DB\", {\r\n                        ...reduxStore.getState().db,\r\n                        cards: {\r\n                            ...reduxStore.getState().db.cards,\r\n                            ...cardsUpdate\r\n                        }\r\n                    });\r\n                    resolve(true)\r\n                }\r\n            } catch (e) {\r\n                console.group('loadFiles::ERR::')\r\n                console.log(e)\r\n                console.groupEnd()\r\n                reject(false)\r\n            }\r\n        } else {\r\n            return true\r\n        }\r\n    })\r\n    if (result)\r\n        return true\r\n}\r\n\r\nconst pageLoadCards = async (props, days = 7) => {\r\n    let h = window.location.hash.split(\"/\")\r\n    h[0] = h[0].replace(\"#\", \"\")\r\n    const request = await new Promise(async (resolve, reject) => {\r\n        if (window.location.pathname === '/calendar') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'calendar',\r\n                iniDate: moment().startOf('month').unix('x'),\r\n                endDate: moment().endOf('month').unix('x')\r\n            })\r\n            resolve(true)\r\n        }\r\n        if (window.location.pathname === '/sp' && h[0].length !== 36 && h[1] === 'archived') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'plans',\r\n                archived: true\r\n            })\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'plans',\r\n                archived: true,\r\n                completed: true,\r\n                completedDays: days\r\n            })\r\n            resolve(true)\r\n        }\r\n        if (window.location.pathname === '/sp' && h[0].length !== 36 && h[1] === 'completed') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'plans',\r\n                completed: true,\r\n                completedDays: days\r\n            })\r\n            resolve(true)\r\n        }\r\n        if (window.location.pathname === '/sp' && h[0].length !== 36 && h[1] === 'templates') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'templates',\r\n                templates: true\r\n            })\r\n            resolve(true)\r\n        }\r\n        if (window.location.pathname === '/sp' && h[0].length !== 36 && h[1] === 'admin') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'plans',\r\n                adminView: true,\r\n            })\r\n            resolve(true)\r\n        }\r\n        if (window.location.pathname === '/sp' && h[0].length !== 36 && h[1] === 'deleted') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'plans',\r\n                deleted: true\r\n            })\r\n            resolve(true)\r\n        }\r\n\r\n        //DASHBOARD DATA\r\n        if ((window.location.pathname === '/d' || window.location.pathname === '/login' || window.location.pathname === '/') && (h[1] !== 'dayTasks')) {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'dashboard'\r\n            })\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'showIn'\r\n            })\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'channel'\r\n            })\r\n            resolve(true)\r\n        }\r\n        if (window.location.pathname === '/d' && h[1] === 'dayTasks') {\r\n            await loadCardsV2(props, {\r\n                adminView: true,\r\n                cardLoad: 'myDay',\r\n            })\r\n            resolve(true)\r\n        }\r\n        if (window.location.pathname === '/d' && h[1] === 'ourTasks') {\r\n            await loadCardsV2(props, {\r\n                adminView: true,\r\n                cardLoad: 'myDay',\r\n            })\r\n            resolve(true)\r\n        }\r\n\r\n        //PLANS DATA\r\n        if (window.location.pathname === '/sp' && h[0] && h[0].length === 36) {\r\n            await loadCardsV2(props, {\r\n                idRel: h[0],\r\n                cardLoad: 'plan',\r\n            })\r\n            await loadCardsV2(props, {\r\n                idRel: h[0],\r\n                cardLoad: 'plan',\r\n                completed: true,\r\n            })\r\n            resolve(true)\r\n        }\r\n\r\n        //PLAN DATA\r\n        if (window.location.pathname === '/sp' && h[0].length !== 36) {\r\n            resolve(true)\r\n        }\r\n\r\n        if (window.location.pathname === '/sp' && h[0].length !== 36 && h[1] === 'archived') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'plans',\r\n                archived: true\r\n            })\r\n        }\r\n        if (window.location.pathname === '/sp' && h[0].length !== 36 && h[1] === 'templates') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'templates',\r\n            })\r\n        }\r\n        if (window.location.pathname === '/sp' && h[0].length !== 36 && h[1] === 'trash') {\r\n            loadCardsV2(props, {\r\n                cardLoad: 'deletedPlans',\r\n                deleted: true,\r\n                adminView: reduxStore.getState().session._access && reduxStore.getState().session._access['plan'] && reduxStore.getState().session._access['planAdmin'] ? true : false\r\n            })\r\n        }\r\n\r\n        //Library\r\n        if (window.location.pathname === '/library') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'plans',\r\n            })\r\n            resolve(true)\r\n        }\r\n\r\n        //Calendar\r\n        if (window.location.pathname === '/calendar') {\r\n            await loadCardsV2(props, {\r\n                cardLoad: 'calendar',\r\n                startDate: null,\r\n                endDate: null\r\n            })\r\n            resolve(true)\r\n        }\r\n\r\n        //COMPANY PROFILE\r\n        if (\r\n            window.location.pathname === '/p'\r\n            || window.location.pathname === '/acc'\r\n        ) {\r\n            // await loadCardsV2(props, {\r\n            //     cardLoad: 'calendar',\r\n            //     startDate: null,\r\n            //     endDate: null\r\n            // })\r\n            resolve(true)\r\n        }\r\n\r\n        //PLAN DATA\r\n        if (window.location.pathname === '/bright-and-connected') {\r\n            if (h[0] === 'tab' && h[1] === 'radar') {\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'links',\r\n                    limit: 9,\r\n                    skip: 0\r\n                })\r\n            }\r\n\r\n            // }\r\n            if (h[0] === 'tab' && h[1] === 'insight-boards') {\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'insights',\r\n                    limit: 9,\r\n                    skip: 0\r\n                })\r\n\r\n            }\r\n            resolve(true)\r\n        }\r\n\r\n        //DATA USERS\r\n        if (window.location.pathname === '/c') {\r\n            if (h[0] === 'tab' && h[1] !== 'users') {\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'plans',\r\n                })\r\n            }\r\n            resolve(true)\r\n        }\r\n\r\n        //DATA TASKS\r\n        if (window.location.pathname === '/t') {\r\n            if (!h[1] || (h[1] && h[1] === 'myTasks')) {\r\n                //MY RESPONSIBLE TASKS DATA\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'myResponsible',\r\n                })\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'myResponsible',\r\n                    completed: true,\r\n                    completedDays: days\r\n                })\r\n                resolve(true)\r\n\r\n            }\r\n\r\n            if (h[1] && (h[1] === 'myDay' || h[1] === 'ourDay')) {\r\n\r\n                //MY DAY DATA\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'myDay',\r\n                    completed: true,\r\n                    completedDays: days\r\n                })\r\n                resolve(true)\r\n            }\r\n\r\n            if (h[1] && h[1] !== 'myTasks' && h[1] !== 'myDay') {\r\n                //ALL TASKS DATA\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'in',\r\n                })\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'in',\r\n                    completed: true,\r\n                    completedDays: days\r\n                })\r\n\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'myResponsible',\r\n                })\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'myResponsible',\r\n                    completed: true,\r\n                    completedDays: days\r\n                })\r\n                resolve(true)\r\n\r\n            }\r\n        }\r\n        //TAGS DATA\r\n        if (window.location.pathname === '/tags') {\r\n            //ALL TASKS DATA\r\n            if (h[0].length === 36)\r\n                await loadCardsV2(props, {\r\n                    cardLoad: 'tags',\r\n                    idRel: h[0]\r\n                })\r\n            resolve(true)\r\n        }\r\n\r\n        //CALENDAR Admin\r\n        if (window.location.pathname === '/calendar') {\r\n            resolve(true)\r\n        }\r\n        //MASTER Admin\r\n        if (window.location.pathname === '/masterAdmin' || window.location.pathname === '/plataformAdministrator') {\r\n            resolve(true)\r\n        }\r\n        //SubscriptionsPages\r\n        if (window.location.pathname === \"/subscriptionUpgrade\")\r\n            resolve(true)\r\n\r\n        //B&C\r\n        if (\r\n            h[0].length === 36\r\n            && reduxStore.getState().db.cards\r\n            &&\r\n            (\r\n                !reduxStore.getState().db.cards[h[0]] ||\r\n                (reduxStore.getState().db.cards[h[0]]\r\n                )\r\n            )\r\n        ) {\r\n            if (reduxStore.getState().db.cards\r\n                && reduxStore.getState().db.cards[h[0]]\r\n                && h[0]\r\n                && !reduxStore.getState().db.cards[h[0]]._loadedFeeds\r\n            ) {\r\n                if (h[1] === 'bright-and-connected') {\r\n                    // await loadFeeds({ ...props, fnIdentification: 'Layout/pageDataRequest() - withHASH' }, h[0].length === 36 ? h[0] : null)\r\n                    resolve(true)\r\n                }\r\n            }\r\n        }\r\n    })\r\n    if (request)\r\n        return true\r\n}\r\n\r\nexport {\r\n    reqCards,\r\n    loadCards,\r\n    loadCardsV2,\r\n    loadFiles,\r\n    mountCards,\r\n    pageLoadCards,\r\n}","//CORE\nimport React from \"react\"\n\nimport CustomButton from \"components/Buttons/custom\"\n\n//REDUX\nimport * as reduxActions from \"store/actions\"\nimport history from \"store/history\"\nimport reduxStore from \"store\"\nimport { bindActionCreators } from \"redux\"\nimport { connect } from \"react-redux\"\n\n//@MATERIAL\nimport { makeStyles } from \"@material-ui/core/styles\"\n\n//FUNCTIONS\nimport { customApp } from \"functions/\"\nimport { countNotifications } from \"functions/cards\"\n\nconst useStyles = makeStyles((theme) => ({\n    iconButtonStyle: {\n        margin: 0,\n        marginTop: \"-8px\",\n        backgroundColor: \"#FFFFFF\",\n        \"&:hover\": {\n            backgroundColor: \"rgba(250,250,250,0.9)\"\n        }\n    },\n}))\n\nfunction Component(props) {\n    const classes = useStyles()\n\n    React.useEffect(() => {\n        return () => {\n            // return false\n        }\n    }, [])\n\n    let notifications = countNotifications(props.nodeId)\n\n    if (notifications.total < 1)\n        return (<React.Fragment></React.Fragment>)\n\n    return (\n        <div id=\"notificationsBt\"\n            style={{\n                top: 0,\n                zIndex: 0\n            }}\n        >\n            <CustomButton\n                className={classes.iconButtonStyle}\n                badgeContent={notifications.total}\n                color={customApp(\"menu\")}\n                icon={notifications.total === 0 ? \"notifications_none\" : \"notifications_active\"}\n                size={\"17px\"}\n                transparent\n            />\n        </div>\n    )\n}\n\n//REACT\nconst mapStateToProps = (store, props) => {\n    return ({\n        cards: store.db.cards[props.nodeId],\n        timeline: store.timeline[props.nodeId]\n    })\n}\n\nconst mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(\n    mapStateToProps,\n    mapDispatchToProps\n)(Component)\n","// ##############################\r\n// // // javascript library for creating charts\r\n// #############################\r\nvar Chartist = require(\"chartist\");\r\n\r\n// ##############################\r\n// // // Charts used in Dahsboard view\r\n// #############################\r\n\r\n// ##############################\r\n// // // variables used to create animation on charts\r\n// #############################\r\n\r\nvar delays = 80,\r\n  durations = 500;\r\nvar delays2 = 80,\r\n  durations2 = 500;\r\n\r\n// ##############################\r\n// // // Daily Sales\r\n// #############################\r\n\r\nconst model = {\r\n  data: {\r\n    // labels: [\"M\", \"T\", \"W\", \"T\", \"F\", \"S\", \"S\"],\r\n    // series: [[12, 17, 7, 17, 23, 18, 38]]\r\n  },\r\n  options: {\r\n    lineSmooth: Chartist.Interpolation.cardinal({\r\n      tension: 0\r\n    }),\r\n    low: 0,\r\n    high: 100, // creative tim: we recommend you to set the high sa the biggest value + something for a better look\r\n    chartPadding: {\r\n      top: 0,\r\n      right: 0,\r\n      bottom: 0,\r\n      left: 0\r\n    }\r\n  },\r\n};\r\n\r\n// ##############################\r\n// // // Email Subscriptions\r\n// #############################\r\n\r\nconst emailsSubscriptionChart = {\r\n  data: {\r\n    labels: [\r\n      \"Jan\",\r\n      \"Feb\",\r\n      \"Mar\",\r\n      \"Apr\",\r\n      \"Mai\",\r\n      \"Jun\",\r\n      \"Jul\",\r\n      \"Aug\",\r\n      \"Sep\",\r\n      \"Oct\",\r\n      \"Nov\",\r\n      \"Dec\"\r\n    ],\r\n    series: [[542, 443, 320, 780, 553, 453, 326, 434, 568, 610, 756, 895], [150, 133, 440, 199, 799, 100, 499, 657, 50, 352, 117, 400], [900, 700, 800, 600, 100, 200, 700, 400, 410, 333, 355, 499]]\r\n  },\r\n  options: {\r\n    axisX: {\r\n      showGrid: false\r\n    },\r\n    low: 0,\r\n    high: 1000,\r\n    chartPadding: {\r\n      top: 0,\r\n      right: 5,\r\n      bottom: 0,\r\n      left: 0\r\n    }\r\n  },\r\n  responsiveOptions: [\r\n    [\r\n      \"screen and (max-width: 640px)\",\r\n      {\r\n        seriesBarDistance: 5,\r\n        axisX: {\r\n          labelInterpolationFnc: function (value) {\r\n            return value[0];\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  ],\r\n  animation: {\r\n    draw: function (data) {\r\n      if (data.type === \"bar\") {\r\n        data.element.animate({\r\n          opacity: {\r\n            begin: (data.index + 1) * delays2,\r\n            dur: durations2,\r\n            from: 0,\r\n            to: 1,\r\n            easing: \"ease\"\r\n          }\r\n        });\r\n      }\r\n    }\r\n  }\r\n};\r\n\r\n// ##############################\r\n// // // Completed Tasks\r\n// #############################\r\n\r\nconst completedTasksChart = {\r\n  data: {\r\n    labels: [\"12am\", \"3pm\", \"6pm\", \"9pm\", \"12pm\", \"3am\", \"6am\", \"9am\"],\r\n    series: [[230, 750, 450, 300, 280, 240, 200, 190]]\r\n  },\r\n  options: {\r\n    lineSmooth: Chartist.Interpolation.cardinal({\r\n      tension: 0\r\n    }),\r\n    low: 0,\r\n    high: 1000, // creative tim: we recommend you to set the high sa the biggest value + something for a better look\r\n    chartPadding: {\r\n      top: 0,\r\n      right: 0,\r\n      bottom: 0,\r\n      left: 0\r\n    }\r\n  },\r\n  animation: {\r\n    draw: function (data) {\r\n      if (data.type === \"line\" || data.type === \"area\") {\r\n        data.element.animate({\r\n          d: {\r\n            begin: 600,\r\n            dur: 700,\r\n            from: data.path\r\n              .clone()\r\n              .scale(1, 0)\r\n              .translate(0, data.chartRect.height())\r\n              .stringify(),\r\n            to: data.path.clone().stringify(),\r\n            easing: Chartist.Svg.Easing.easeOutQuint\r\n          }\r\n        });\r\n      } else if (data.type === \"point\") {\r\n        data.element.animate({\r\n          opacity: {\r\n            begin: (data.index + 1) * delays,\r\n            dur: durations,\r\n            from: 0,\r\n            to: 1,\r\n            easing: \"ease\"\r\n          }\r\n        });\r\n      }\r\n    }\r\n  }\r\n};\r\n\r\n// ##############################\r\n// // // Rounded Line Chart\r\n// #############################\r\n\r\nconst roundedLineChart = {\r\n  data: {\r\n    labels: [\"M\", \"T\", \"W\", \"T\", \"F\", \"S\", \"S\"],\r\n    series: [[12, 17, 7, 17, 23, 18, 38]]\r\n  },\r\n  options: {\r\n    lineSmooth: Chartist.Interpolation.cardinal({\r\n      tension: 10\r\n    }),\r\n    axisX: {\r\n      showGrid: false\r\n    },\r\n    low: 0,\r\n    high: 50, // creative tim: we recommend you to set the high sa the biggest value + something for a better look\r\n    chartPadding: {\r\n      top: 0,\r\n      right: 0,\r\n      bottom: 0,\r\n      left: 0\r\n    },\r\n    showPoint: false\r\n  },\r\n  animation: {\r\n    draw: function (data) {\r\n      if (data.type === \"line\" || data.type === \"area\") {\r\n        data.element.animate({\r\n          d: {\r\n            begin: 600,\r\n            dur: 700,\r\n            from: data.path\r\n              .clone()\r\n              .scale(1, 0)\r\n              .translate(0, data.chartRect.height())\r\n              .stringify(),\r\n            to: data.path.clone().stringify(),\r\n            easing: Chartist.Svg.Easing.easeOutQuint\r\n          }\r\n        });\r\n      } else if (data.type === \"point\") {\r\n        data.element.animate({\r\n          opacity: {\r\n            begin: (data.index + 1) * delays,\r\n            dur: durations,\r\n            from: 0,\r\n            to: 1,\r\n            easing: \"ease\"\r\n          }\r\n        });\r\n      }\r\n    }\r\n  }\r\n};\r\n\r\n// ##############################\r\n// // // Straight Lines Chart\r\n// #############################\r\n\r\nconst straightLinesChart = {\r\n  data: {\r\n    labels: [\"'07\", \"'08\", \"'09\", \"'10\", \"'11\", \"'12\", \"'13\", \"'14\", \"'15\"],\r\n    series: [[10, 16, 8, 13, 20, 15, 20, 34, 30]]\r\n  },\r\n  options: {\r\n    lineSmooth: Chartist.Interpolation.cardinal({\r\n      tension: 0\r\n    }),\r\n    low: 0,\r\n    high: 50, // creative tim: we recommend you to set the high sa the biggest value + something for a better look\r\n    chartPadding: {\r\n      top: 0,\r\n      right: 0,\r\n      bottom: 0,\r\n      left: 0\r\n    },\r\n    classNames: {\r\n      point: \"ct-point ct-white\",\r\n      line: \"ct-line ct-white\"\r\n    }\r\n  },\r\n  animation: {\r\n    draw: function (data) {\r\n      if (data.type === \"line\" || data.type === \"area\") {\r\n        data.element.animate({\r\n          d: {\r\n            begin: 600,\r\n            dur: 700,\r\n            from: data.path\r\n              .clone()\r\n              .scale(1, 0)\r\n              .translate(0, data.chartRect.height())\r\n              .stringify(),\r\n            to: data.path.clone().stringify(),\r\n            easing: Chartist.Svg.Easing.easeOutQuint\r\n          }\r\n        });\r\n      } else if (data.type === \"point\") {\r\n        data.element.animate({\r\n          opacity: {\r\n            begin: (data.index + 1) * delays,\r\n            dur: durations,\r\n            from: 0,\r\n            to: 1,\r\n            easing: \"ease\"\r\n          }\r\n        });\r\n      }\r\n    }\r\n  }\r\n};\r\n\r\n// ##############################\r\n// // // Simple Bar Chart\r\n// #############################\r\n\r\nconst simpleBarChart = {\r\n  data: {\r\n    labels: [\r\n      \"Jan\",\r\n      \"Feb\",\r\n      \"Mar\",\r\n      \"Apr\",\r\n      \"Mai\",\r\n      \"Jun\",\r\n      \"Jul\",\r\n      \"Aug\",\r\n      \"Sep\",\r\n      \"Oct\",\r\n      \"Nov\",\r\n      \"Dec\"\r\n    ],\r\n    series: [[542, 443, 320, 780, 553, 453, 326, 434, 568, 610, 756, 895]]\r\n  },\r\n  options: {\r\n    seriesBarDistance: 10,\r\n    axisX: {\r\n      showGrid: false\r\n    }\r\n  },\r\n  responsiveOptions: [\r\n    [\r\n      \"screen and (max-width: 640px)\",\r\n      {\r\n        seriesBarDistance: 5,\r\n        axisX: {\r\n          labelInterpolationFnc: function (value) {\r\n            return value[0];\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  ],\r\n  animation: {\r\n    draw: function (data) {\r\n      if (data.type === \"bar\") {\r\n        data.element.animate({\r\n          opacity: {\r\n            begin: (data.index + 1) * delays2,\r\n            dur: durations2,\r\n            from: 0,\r\n            to: 1,\r\n            easing: \"ease\"\r\n          }\r\n        });\r\n      }\r\n    }\r\n  }\r\n};\r\n\r\n// ##############################\r\n// // // Coloured Line Chart\r\n// #############################\r\n\r\nconst colouredLineChart = {\r\n  data: {\r\n    labels: [\r\n      \"'06\",\r\n      \"'07\",\r\n      \"'08\",\r\n      \"'09\",\r\n      \"'10\",\r\n      \"'11\",\r\n      \"'12\",\r\n      \"'13\",\r\n      \"'14\",\r\n      \"'15\"\r\n    ],\r\n    series: [[287, 480, 290, 554, 690, 690, 500, 752, 650, 900, 944]]\r\n  },\r\n  options: {\r\n    lineSmooth: Chartist.Interpolation.cardinal({\r\n      tension: 10\r\n    }),\r\n    axisY: {\r\n      showGrid: true,\r\n      offset: 40\r\n    },\r\n    axisX: {\r\n      showGrid: false\r\n    },\r\n    low: 0,\r\n    high: 1000,\r\n    showPoint: true,\r\n    height: \"300px\"\r\n  },\r\n  animation: {\r\n    draw: function (data) {\r\n      if (data.type === \"line\" || data.type === \"area\") {\r\n        data.element.animate({\r\n          d: {\r\n            begin: 600,\r\n            dur: 700,\r\n            from: data.path\r\n              .clone()\r\n              .scale(1, 0)\r\n              .translate(0, data.chartRect.height())\r\n              .stringify(),\r\n            to: data.path.clone().stringify(),\r\n            easing: Chartist.Svg.Easing.easeOutQuint\r\n          }\r\n        });\r\n      } else if (data.type === \"point\") {\r\n        data.element.animate({\r\n          opacity: {\r\n            begin: (data.index + 1) * delays,\r\n            dur: durations,\r\n            from: 0,\r\n            to: 1,\r\n            easing: \"ease\"\r\n          }\r\n        });\r\n      }\r\n    }\r\n  }\r\n};\r\n\r\n// ##############################\r\n// // // Multiple Bars Chart\r\n// #############################\r\n\r\nconst multipleBarsChart = {\r\n  data: {\r\n    labels: [\r\n      \"Jan\",\r\n      \"Feb\",\r\n      \"Mar\",\r\n      \"Apr\",\r\n      \"Mai\",\r\n      \"Jun\",\r\n      \"Jul\",\r\n      \"Aug\",\r\n      \"Sep\",\r\n      \"Oct\",\r\n      \"Nov\",\r\n      \"Dec\"\r\n    ],\r\n    series: [\r\n      [542, 443, 320, 780, 553, 453, 326, 434, 568, 610, 756, 895],\r\n      [412, 243, 280, 580, 453, 353, 300, 364, 368, 410, 636, 695]\r\n    ]\r\n  },\r\n  options: {\r\n    seriesBarDistance: 10,\r\n    axisX: {\r\n      showGrid: false\r\n    },\r\n    height: \"300px\"\r\n  },\r\n  responsiveOptions: [\r\n    [\r\n      \"screen and (max-width: 640px)\",\r\n      {\r\n        seriesBarDistance: 5,\r\n        axisX: {\r\n          labelInterpolationFnc: function (value) {\r\n            return value[0];\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  ],\r\n  animation: {\r\n    draw: function (data) {\r\n      if (data.type === \"bar\") {\r\n        data.element.animate({\r\n          opacity: {\r\n            begin: (data.index + 1) * delays2,\r\n            dur: durations2,\r\n            from: 0,\r\n            to: 1,\r\n            easing: \"ease\"\r\n          }\r\n        });\r\n      }\r\n    }\r\n  }\r\n};\r\n\r\n// ##############################\r\n// // // Coloured Lines Chart\r\n// #############################\r\n\r\nconst colouredLinesChart = {\r\n  data: {\r\n    labels: [\r\n      \"'06\",\r\n      \"'07\",\r\n      \"'08\",\r\n      \"'09\",\r\n      \"'10\",\r\n      \"'11\",\r\n      \"'12\",\r\n      \"'13\",\r\n      \"'14\",\r\n      \"'15\"\r\n    ],\r\n    series: [\r\n      [287, 385, 490, 554, 586, 698, 695, 752, 788, 846, 944],\r\n      [67, 152, 143, 287, 335, 435, 437, 539, 542, 544, 647],\r\n      [23, 113, 67, 190, 239, 307, 308, 439, 410, 410, 509]\r\n    ]\r\n  },\r\n  options: {\r\n    lineSmooth: Chartist.Interpolation.cardinal({\r\n      tension: 10\r\n    }),\r\n    axisY: {\r\n      showGrid: true,\r\n      offset: 40\r\n    },\r\n    axisX: {\r\n      showGrid: false\r\n    },\r\n    low: 0,\r\n    high: 1000,\r\n    showPoint: true,\r\n    height: \"300px\"\r\n  },\r\n  animation: {\r\n    draw: function (data) {\r\n      if (data.type === \"line\" || data.type === \"area\") {\r\n        data.element.animate({\r\n          d: {\r\n            begin: 600,\r\n            dur: 700,\r\n            from: data.path\r\n              .clone()\r\n              .scale(1, 0)\r\n              .translate(0, data.chartRect.height())\r\n              .stringify(),\r\n            to: data.path.clone().stringify(),\r\n            easing: Chartist.Svg.Easing.easeOutQuint\r\n          }\r\n        });\r\n      } else if (data.type === \"point\") {\r\n        data.element.animate({\r\n          opacity: {\r\n            begin: (data.index + 1) * delays,\r\n            dur: durations,\r\n            from: 0,\r\n            to: 1,\r\n            easing: \"ease\"\r\n          }\r\n        });\r\n      }\r\n    }\r\n  }\r\n};\r\n\r\n// ##############################\r\n// // // Pie Chart\r\n// #############################\r\n\r\nconst pieChart = {\r\n  data: {\r\n    labels: [\"62%\", \"32%\", \"6%\"],\r\n    series: [62, 32, 6]\r\n  },\r\n  options: {\r\n    height: \"230px\"\r\n  }\r\n};\r\n\r\nmodule.exports = {\r\n  // Charts used in Dahsboard view\r\n  model,\r\n  emailsSubscriptionChart,\r\n  completedTasksChart,\r\n  // Charts used in Charts view\r\n  roundedLineChart,\r\n  straightLinesChart,\r\n  simpleBarChart,\r\n  colouredLineChart,\r\n  multipleBarsChart,\r\n  colouredLinesChart,\r\n  pieChart\r\n};\r\n","import {\r\n  defaultFont\r\n} from \"assets/jss/material-dashboard-pro-react.js\";\r\n\r\n//FUNCTIONS\r\nimport { customApp } from \"functions/\";\r\n\r\nconst style = {\r\n  container: {\r\n    ...defaultFont,\r\n    position: 'relative',\r\n    border: `0.5px solid ${customApp('light')}`,\r\n    borderRadius: '2px',\r\n    padding: '0px',\r\n    backgroundColor: '#FFFFFF',\r\n    boxShadow: '0px 0px 10px rgba(0,0,0,0.1)',\r\n    padding: '3px',\r\n    minWidth: '150px',\r\n    display: 'flow-root',\r\n  },\r\n  cardContainer: {\r\n    ...defaultFont,\r\n    position: 'relative',\r\n    minWidth: '150px',\r\n    display: 'flow-root',\r\n  },\r\n  parent: {\r\n    width: '100%',\r\n    padding: '0 5px',\r\n    '& .title': {\r\n      color: customApp('medium'),\r\n      fontSize: '10px',\r\n      textTransform: 'uppercase'\r\n    },\r\n    '& .info': {\r\n      marginTop: '-8px',\r\n      color: customApp('color'),\r\n      fontWeight: '500',\r\n      //display: 'flex',\r\n      alignItems: 'center',\r\n    }\r\n  },\r\n  infos: {\r\n    position: 'absolute',\r\n    float: 'left',\r\n    width: '100%',\r\n    height: 'auto',\r\n    display: 'block',\r\n  },\r\n  description: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    padding: '5px',\r\n    width: '100%',\r\n    overflow: 'hidden'\r\n  },\r\n  dates: {\r\n    position: 'relative',\r\n    float: 'left',\r\n    width: '100%',\r\n    marginTop: '7px',\r\n    padding: '0 5px',\r\n    marginRight: '15px',\r\n    color: customApp('medium'),\r\n    fontSize: '10px',\r\n    display: 'flex',\r\n  },\r\n  dateInfo: {\r\n    marginRight: '15px',\r\n    display: 'flex',\r\n    alignItems: 'center'\r\n  },\r\n  usersContent: {\r\n    position: 'relative',\r\n    minHeight: '20px',\r\n    minWidth: '40px',\r\n    float: 'right'\r\n  },\r\n  users: {\r\n    position: 'absolute',\r\n    bottom: '7px',\r\n    right: '2px',\r\n    fontSize: '10px',\r\n    '& .MuiAvatarGroup-root': {\r\n      justifyContent: 'flex-end',\r\n    },\r\n    '& .MuiAvatar-root': {\r\n      width: '25px',\r\n      height: '25px',\r\n      fontSize: '10px',\r\n    }\r\n  }\r\n};\r\n\r\nexport default style;\r\n","module.exports = __webpack_public_path__ + \"static/media/strategy-pt.625a0c5b.png\";","module.exports = __webpack_public_path__ + \"static/media/userCover.49044f68.jpg\";","const initialState = {\r\n    sideModuleWindow: false,\r\n    period: '$__last7Days',\r\n    users: {},\r\n    showDeleted: false,\r\n    hidePrivate: false,\r\n    lockPrivate: false,\r\n    unlockedPrivates: 0,\r\n    board: null,\r\n    agileOrderBy: \"name\",\r\n    agileOrderDesc: \"DESC\",\r\n};\r\n\r\nconst session = (state = initialState, data) => {\r\n    if (data.action === 'SET_CONTROL' && data.value) {\r\n        return {\r\n            ...state,\r\n            ...data.value,\r\n        }\r\n    } else if (data.action === 'RESET_CONTROLS') {\r\n        return {\r\n            ...state,\r\n        }\r\n\r\n    } else {\r\n        return state\r\n    }\r\n};\r\n\r\nexport default session;","module.exports = __webpack_public_path__ + \"static/media/fundoLogin.a16e608c.jpg\";","//CORE\nimport React from 'react'\n\n//@Material\nimport Icon from \"@material-ui/core/Icon\"\nimport Tooltip from \"@material-ui/core/Tooltip\"\n\n//@MATERIAL\nimport { makeStyles, withStyles } from '@material-ui/core/styles';\nimport Badges from '@material-ui/core/Badge';\n\n//FUNCTIONS\nimport { translate, customApp } from \"functions/\";\n\nconst useStyles = makeStyles(() => ({\n    customColor: {\n        display: 'flex',\n        alignItems: 'center',\n        '& .MuiBadge-badge': {\n            backgroundColor: customApp('color'),\n            color: customApp('light'),\n            display: 'flex',\n            alignItems: 'center',\n            zIndex: '1500 !important',\n        },\n    },\n    root: {\n        '& .MuiBadge-badge': {\n            display: 'flex',\n            alignItems: 'center',\n            zIndex: 20\n        },\n    },\n}));\n\nconst HtmlTooltip = withStyles((theme) => ({\n    tooltip: {\n        backgroundColor: '#f5f5f9',\n        color: 'rgba(0, 0, 0, 0.87)',\n        fontSize: theme.typography.pxToRem(12),\n        border: '1px solid #dadde9',\n        borderRadius: '7px',\n        boxShadow: '0 0 3px 3px rgba(0,0,0,0.03)',\n        display: 'flex',\n        alignItems: 'center',\n        justifyContent: 'center',\n        zIndex: '1000 !important'\n    },\n}))(Tooltip);\n\nexport default function Component(props) {\n    const classes = useStyles();\n    const [badgeVisible, setBadgeVisible] = React.useState(props.badgeVisible || false)\n    const [toolTipOpen, setToolTipOpen] = React.useState(props.tooltipprops\n        && props.tooltipprops.open\n        ? props.tooltipprops.open\n        : props.tooltipprops\n            && String(props.tooltipprops.open) === 'false'\n            ? false\n            : undefined)\n\n    React.useEffect(() => {\n        if (props && props.tooltipprops && props.tooltipprops.open && !toolTipOpen)\n            setToolTipOpen(true)\n        if (props && props.tooltipprops && toolTipOpen && String(props.tooltipprops.open) === 'false')\n            setToolTipOpen(false)\n    })\n\n    return (\n        <div\n            className={classes.root}\n        >\n            <HtmlTooltip\n                title={props.title && typeof props.title === 'string'\n                    ? (\n                        <React.Fragment>\n                            <div style={{ color: customApp('darkText'), display: 'flex', alignItems: 'center', justifyContent: 'center', textAlign: 'center', height: 'auto' }}>\n                                {translate(props.title, 1)}\n                            </div>\n                        </React.Fragment>\n                    )\n                    : props.title ? (\n                        <React.Fragment>\n                            <div className={classes.customColor}>\n                                <div style={{ position: 'relative' }}>\n                                    {props.title}\n                                    {props.onClose &&\n                                        <Icon\n                                            style={{\n                                                position: 'absolute',\n                                                left: '5px',\n                                                top: '0px',\n                                                zIndex: 10,\n                                                cursor: 'pointer'\n                                            }}\n                                            onClick={() => props.onClose()}\n                                            title=\"close\"\n                                        >close</Icon>\n                                    }\n                                </div>\n                            </div>\n                        </React.Fragment>\n                    )\n                        : ''\n                }\n                className={null}\n                open={toolTipOpen}\n                disableFocusListener={props.tooltipprops && props.tooltipprops.disableFocusListener ? props.tooltipprops.disableFocusListener : false}\n                disableHoverListener={props.tooltipprops && props.tooltipprops.disableHoverListener ? props.tooltipprops.disableHoverListener : false}\n                disableTouchListener={props.tooltipprops && props.tooltipprops.disableTouchListene ? props.tooltipprops.disableTouchListene : false}\n                onClose={() => {\n                    if (props.tooltipprops && props.tooltipprops.onClose)\n                        props.tooltipprops.onClose()\n                }}\n                interactive={typeof props.title !== 'string' && props.tooltipprops && props.tooltipprops.interactive ? props.tooltipprops.interactive : false}\n            >\n                <Badges\n                    overlap=\"rectangular\"\n                    badgeContent={props.count}\n                    style={{ opacity: 1, fontSize: '5px' }}\n                    max={props.max || 9}\n                    anchorOrigin={{\n                        vertical: 'top',\n                        horizontal: 'right',\n                    }}\n                    invisible={props.count && !badgeVisible}\n                >\n                    {typeof props.icon === 'string' ?\n                        <Icon\n                            onMouseEnter={() => !props.badgeVisible && setBadgeVisible(true)}\n                            onMouseLeave={() => !props.badgeVisible && setBadgeVisible(false)}\n                            onClick={props.onClick ? (e) => {\n                                props.onClick()\n                                e.stopPropagation();\n                            } : null\n                            }\n                            className={props.className}\n                            style={{\n                                width: props.size ? props.size : 'fit-content',\n                                height: props.size ? props.size : 'fit-content',\n                                fontSize: props.size || '22px',\n                                color: props.color || customApp('medium'),\n                                opacity: !props.disabled || badgeVisible ? '1' : '0.5',\n                                cursor: props.onClick ? 'pointer' : '',\n                                ...props.style\n                            }}>\n                            {props.icon}\n                        </Icon>\n                        :\n                        <props.icon\n                            onMouseEnter={() => !props.badgeVisible && setBadgeVisible(true)}\n                            onMouseLeave={() => !props.badgeVisible && setBadgeVisible(false)}\n                            onClick={props.onClick ? (e) => {\n                                props.onClick()\n                                e.stopPropagation();\n                            } : null\n                            }\n                            className={props.className}\n                            style={{\n                                width: props.size || '22px',\n                                height: props.size || '22px',\n                                fontSize: props.size || '22px',\n                                color: props.color || customApp('medium'),\n                                opacity: !props.disabled || badgeVisible ? '1' : '0.5',\n                                cursor: props.onClick ? 'pointer' : '',\n                                ...props.style\n                            }}\n                        />\n                    }\n                </Badges>\n            </HtmlTooltip >\n        </div>\n    )\n}","//\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"@material-ui/icons/utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(_react.default.Fragment, null ,_react.default.createElement(\"path\", {\n  fill: \"none\",\n   d: \"M.2,11.6H0V17H.2c0,.1,0,.1.1.1H1L18,.4H16.4L1.1,15.7V12.2L12.9.4H11.3L.2,11.6Z\"\n}),_react.default.createElement(\"path\", {\n    d: \"M.2,11.6H0V17H.2c0,.1,0,.1.1.1H1L18,.4H16.4L1.1,15.7V12.2L12.9.4H11.3L.2,11.6Z\"\n}),_react.default.createElement(\"path\", {\n    d: \"M0,1V7.1H0c.1,0,.1,0,.1.1H.4a.1.1,0,0,0,.1.1H1L7.1,1.4h0l1-1H.6A.6.6,0,0,0,0,1Z\"\n})), 'GuidelineC');\n\nexports.default = _default;","//\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"@material-ui/icons/utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(_react.default.Fragment, null ,_react.default.createElement(\"path\", {\n  fill: \"none\",\n   d: \"M17.8,6.4H18V1H17L0,17.6H1.6L16.9,2.3V5.8L5.1,17.6H6.7L17.8,6.4Z\"\n}),_react.default.createElement(\"path\", {\n    d: \"M17.8,6.4H18V1H17L0,17.6H1.6L16.9,2.3V5.8L5.1,17.6H6.7L17.8,6.4Z\"\n}),_react.default.createElement(\"path\", {\n    d: \"M18,17V10.9H17l-6.1,6.1h0l-1,1h7.5A.6.6,0,0,0,18,17Z\"\n})), 'GuidelineD');\n\nexports.default = _default;","//\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"@material-ui/icons/utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(_react.default.Fragment, null ,_react.default.createElement(\"path\", {\n  fill: \"none\",\n   d: \"M6.4.2H.6l17,17V16.4L2.3,1.1H5.8L17.6,12.9V11.3L6.4.2Z\"\n}),_react.default.createElement(\"path\", {\n    d: \"M6.4.2H.6l17,17V16.4L2.3,1.1H5.8L17.6,12.9V11.3L6.4.2Z\"\n}),_react.default.createElement(\"path\", {\n    d: \"M17,0H10.5l6.1,6.1h0l1,1V.6A.6.6,0,0,0,17,0Z\"\n})), 'GuidelineE');\n\nexports.default = _default;","//\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"@material-ui/icons/utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(_react.default.Fragment, null ,_react.default.createElement(\"path\", {\n  fill: \"none\",\n   d: \"M11.6,17.8h5.8c.1,0,.1,0,.1-.1h-.1L.4,0V1.6L15.7,16.9H12.2L.4,5.1V6.7L11.6,17.8Z\"\n}),_react.default.createElement(\"path\", {\n    d: \"M11.6,17.8h5.8c.1,0,.1,0,.1-.1h-.1L.4,0V1.6L15.7,16.9H12.2L.4,5.1V6.7L11.6,17.8Z\"\n}),_react.default.createElement(\"path\", {\n    d: \"M1,18H7.3c0-.1,0-.1.1-.1h.1a.1.1,0,0,0,.1-.1h0a.1.1,0,0,0,.1-.1H7.6a.1.1,0,0,1-.1-.1h0L1.4,10.9h0l-1-1v7.5A.6.6,0,0,0,1,18Z\"\n})), 'GuidelineR');\n\nexports.default = _default;","module.exports = __webpack_public_path__ + \"static/media/machen.b9c661d3.svg\";","module.exports = __webpack_public_path__ + \"static/media/fundo-sonne.6de93583.png\";","module.exports = __webpack_public_path__ + \"static/media/microsoftWord.113ac212.svg\";","module.exports = __webpack_public_path__ + \"static/media/microsoftExcel.c59164de.svg\";","module.exports = __webpack_public_path__ + \"static/media/microsoftPowerpoint.0e97c564.svg\";","var _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n    value: true\n});\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _createSvgIcon = _interopRequireDefault(require(\"@material-ui/icons/utils/createSvgIcon\"));\n\nvar _default = (0, _createSvgIcon.default)(_react.default.createElement(_react.default.Fragment, null, _react.default.createElement(\"path\", {\n    fill: \"none\",\n    d: \"M0 5.22H6.6V6.32H0z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M8.8 5.22H15.4V6.32H8.8z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M17.6 5.22H24.200000000000003V6.32H17.6z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M26.4 5.22H33V6.32H26.4z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M0 0H6.6V3.03H0z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M8.8 0H15.4V3.03H8.8z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M17.6 0H24.200000000000003V3.03H17.6z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M26.4 0H33V3.03H26.4z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M0 7.58H6.6V8.68H0z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M8.8 7.58H15.4V8.68H8.8z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M17.6 7.58H24.200000000000003V8.68H17.6z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M26.4 7.58H33V8.68H26.4z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M0 9.94H6.6V11.04H0z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M8.8 9.94H15.4V11.04H8.8z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M17.6 9.94H24.200000000000003V11.04H17.6z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M26.4 9.94H33V11.04H26.4z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M0 12.3H6.6V13.4H0z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M8.8 12.3H15.4V13.4H8.8z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M26.4 12.3H33V13.4H26.4z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M0 14.65H6.6V15.75H0z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M8.8 14.65H15.4V15.75H8.8z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M26.4 14.65H33V15.75H26.4z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M0 17.01H6.6V18.110000000000003H0z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M8.8 17.01H15.4V18.110000000000003H8.8z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M26.4 17.01H33V18.110000000000003H26.4z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M0 19.37H6.6V20.470000000000002H0z\"\n}), _react.default.createElement(\"path\", {\n    d: \"M26.4 19.37H33V20.470000000000002H26.4z\"\n})), 'SWOT');\n\nexports.default = _default;","module.exports = __webpack_public_path__ + \"static/media/pdf.3d17c449.svg\";"],"sourceRoot":""}