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/a1b2c3d4/static/js/main.688497b9.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","assets/jss/material-dashboard-pro-react/components/Tags.js","components/Tags/Card.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/Checkbox/index.js","functions/users.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/TextField/currency.js","components/Quick/functions.js","components/Quick/card.js","components/Checklist/index.js","components/ConnectedIn/index.js","components/Progress/linear.js","components/PopperMenu/index.js","functions/chat.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/CustomButtons/icon.js","assets/jss/material-dashboard-pro-react/components/Mentions-Input.js","assets/jss/material-dashboard-pro-react/components/timelineSending.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","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","functions/files.js","components/Navigation/index.js","components/Columns/edit.js","components/Columns/settings.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","components/Quick/copy_move.js","components/Quick/addCard.js","functions/socket.js","layouts/adminStyle.js","layouts/authStyle.js","layouts/index.js","root.js","index.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","functions/loadData.js","store/db.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","components/Icon/Badge.js","store/controls.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","assets/img/fundoLogin.jpg"],"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","store","dispatch","bindActionCreators","reduxActions","withStyles","styles","classes","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","functions","file","originalName","formData","FormData","append","Promise","resolve","reject","onUploadProgress","request","returnFile","onUploadError","tags","defaultFont","right","bottom","userSelect","overflow","marginRight","tagsOver","useStyles","makeStyles","CardTags","React","useState","ShowOptions","setShowTags","showHiddenButton","setshowHiddenButton","setOptions","useEffect","dbNode","expanded","onMouseOver","onMouseLeave","setTimeout","tg","t","tag","whiteSpace","rounded","colorPicker","ColorPicker","label","onChange","c","newTag","socket","emit","parent","tt","top","IconButton","Icon","useStylesFacebook","root","palette","grey","left","animationDuration","circle","strokeLinecap","FacebookCircularProgress","thickness","disableShrink","PolicyAndTerms","consent","privacy","setPrivacy","terms","setTerms","loading","setLoading","updateConsent","accepted_at","unix","method","version","Backdrop","zIndex","backdropFilter","open","innerWidth","background","onScroll","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","verticalAlign","touchAction","blackColor","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","RegularButton","forwardRef","muiClasses","rest","btnClasses","classNames","Button","pagesHeaderStyle","appBar","borderBottom","flex","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","CircularProgress","SVGIcon","onError","zoom","autoPlay","controls","PreLoaderContent","Escurecer","CircularIndeterminate","fullScreen","buttonText","reverse","flexDirection","iconButton","onlyIcon","btnClassesText","iconColor","iconBackground","setData","reactThis","react","user","newData","_reactions","displayName","reactDate","re","us","ReactionComp","primaryIcon","secondaryIcon","hideDisables","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","iconButtonStyle","setName","editing","setEditing","showPrivateCard","setShowPrivateCard","unlockedPrivates","editable","saveData","noLog","onEdit","backClick","onExpanding","private","lockPrivate","Badge","iconTitle","searchText","searchTextStyle","textStyle","inputStyle","fieldName","InputLabelProps","shrink","InputProps","autoComplete","placeholder","autoFocus","noAutoFocus","multiline","onCancel","actionsSize","onSave","viewAllName","onDoubleClick","showOrder","html","tmp","document","innerHTML","textContent","innerText","stripHtml","privateTitle","periodFilter","moreButton","show","noExpanding","isExpanded","MoreMenu","noButton","prev","setPrivate","optionsProps","Checkbox","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","removeUsers","setRemoveUsers","myDayUsers","setMyDayUsers","searchValue","setSearchValue","search","setSearch","selectToMyDay","setSelectToMyDay","getUserList","userList","CardAccess","getUserAccess","admin","plan","planAdmin","selectUser","acc","_planId","noNotification","deleteAccessUser","userIds","sendToDay","setMyDay","GroupMenuItem","UserMenuItem","pr","userPermission","permission","myDay","customDefine","backgroundImage","setResponsible","setUserParam","param","on","checked","mdu","splice","usersToRemove","validateUser","endAdornment","InputAdornment","onBlur","types","userGroup","group","AvatarGroup","flexWrap","AvatarList","u","limit","noLimit","avatarSize","avatarBorder","listingStyle","aa","aai","timeInfo","dataSave","fieldSet","progress","progressPercentage","setReqSave","description","setDescription","setValue","timer","changeKPI","newValue","uuid","idRel","PositiveValue","manualEntry","kpi_type","diff","ini","created_at","fin","updated_at","to","callBack","manualAdd","kpiTimerDelete","kpi_currency","selectedUser","setSelectedUser","admins","idu","isArray","getAdminList","onlyCard","selectedUsers","multiple","onSelect","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","total","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","n","linkCard","automation","parentCard","dataUpdate","automationDueDateType","add","automationDueDate","automationStatusType","automationStatus","completed_at","automationUsers","automationTags","newTags","removeTags","addTags","nt","removeCreatorUser","automationExec","destination","getKanbanData","columns","columnsOrder","c1","c2","step1","step2","column","items","cid","ca","cb","order","cIndex","columnOrder","reason","approval","approved","flowCard","moveTo","onConcludedStepMoveTo","nextStep","dataMessage","filesCount","requireApproval","showCard","edit","setEdit","over","setOver","update","updateCardData","deleteThis","cardContainer","viewTimer","noDelete","dragStatus","checklist","_hasStep","setCompleted","switchBase","track","Switch","CurrencyTextField","getValue","bind","callEventHandler","others","currencySymbol","autonumeric","AutoNumeric","input","preDefined","digitGroupSeparator","decimalCharacter","decimalCharacterAlternative","onFocus","onKeyPress","onKeyUp","watchExternalChanges","remove","newProps","set","string","numeric","getNumericString","number","getNumber","outputFormat","eventName","otherProps","forEach","inputRef","startAdornment","defaultProps","maximumValue","minimumValue","getPredefinedOptions","addCard","rows","parentData","showInPanel","channel","nameI","_createdBy","refUsers","addValue","addDescription","setSelectedUsers","createRef","descriptionRef","valueRef","saveRef","createCards","initialData","placeHolder","explain","resize","fontFamily","which","shiftKey","requireDescription","minRows","requireValue","defineResponsible","focus","setAdd","addLoad","setDragStatus","setChecklist","today","tasksCards","fil","noChecklist","onDragEnd","source","draggableId","droppableId","index","itemOrderIds","onDragStart","onDragUpdate","openCards","listStepLock","control","board","showProgress","direction","droppableProps","isDraggingOver","dataA","dataB","alignContent","ConnectedIn","connectedIn","connectInMount","returnConnections","connectedCardAccess","planModerate","planAccountVerify","showLegend","legend","ProgressLinear","textSize","bar","showText","customColor","LinearProgress","Comp","cloneElement","chatReaded","newTimeline","timeline","readedBy","m","mi","readedDate","_notifications","notifications","interact","reactions","timelineComment","dt","loadCardsV2","cardLoad","ignoreLoader","node","comment","idUser","_toUser","loadTimeline","lastMessageDate","chat","ids","skip","toId","reqChildrens","newUpdates","lastDate","nodes","nodesIds","reqTimeline","timelines","chatOpenId","tm","params","toUsers","msg","noReg","groupEnd","load","countUnRead","unReadCountGroup","unReadCountUser","externalGroups","externalUsers","deleteMessage","req","deletedReason","comm","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","isSubscribed","init","_loadTimeline","kpiType","reqParents","reqFullData","onExpand","openSideModule","hasYoutube","url","alignSelf","frameBorder","allow","allowFullScreen","vmQuery","allowfullscreen","BrightAndConnectedIco","MachenIco","viewList","Resume","ignoreList","_aspects","SWOT","kpi","_timelineCount","onlyOption","_logCount","_kpiCount","_timerCount","borderTopLeftRadius","borderTopRightRadius","Checklist","CustomButton","highlighter","boxSizing","suggestions","item","timelineStyle","rootRelative","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","urlPreview","mentionInput","mentionWrapper","outline","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","sendingInput","find","textInput","inputId","getElementById","reply","mentionedUsers","usersMentioned","test1","sendMessage","replyData","mentions","notifyUsers","_client","client","onSending","userAccessNew","sendFiles","fi","percentCompleted","loaded","sendedList","fileUpload","nFilesSend","verifyText","pattern","dataUrl","contentSnippet","urlErrorsArray","usersSuggestion","owner","fs","offsetHeight","FileDrop","relative","onDragOver","disabledSend","onDrop","accept","editorStyle","Skeleton","hideCards","showUserName","noReactions","URL","createObjectURL","deleteFile","valueBuffer","xs","md","xl","site","clientHeight","onPaste","clipboardData","mentionInputStyle","forceSuggestionsAboveCursor","autosize","maxRows","trigger","renderSuggestion","suggestion","highlightedDisplay","closeOption","onEmojiClick","emojiObject","emoji","groupVisibility","recently_used","onDragLeave","drawer","box","iconList","showList","setShowList","setSelected","buttonsHover","setButtonsHover","setIcon","modMessageOpen","setModMessageOpen","customButtons","bt","saveName","onMouseEnter","permitIcon","iconOnEditable","onChangeIcon","noCancel","tooltipText","actionButtonsStyle","actionsButtons","timelineMessage","tooltipprops","disableFocusListener","disableHoverListener","disableTouchListener","PopperProps","disablePortal","interactive","component","cropperStyle","avatarImage","addImage","cropper","circleCropper","CroppedImage","SetCroppedImage","ImageCropDialog","SetImageCropDialog","ImagetoCrop","SetImagetoCrop","setFiles","fileInput","ff","_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","showPrivate","Card","setExpanded","globalExpanded","setGlobalExpanded","useTemplate","setUseTemplate","showMoreButton","setShowMoreButton","cardColorPicker","getCardColor","cardColor","setCardColor","combine","setCombine","cardRef","onResize","newSize","manualExpanded","combineTargetFor","isMounted","selectThis","activeCards","saveMATRIX","selectSWOT","countChildrens","updateCardStatus","cardStatus","openPlan","deleteCard","directDeletion","restoreThis","restoreCard","noExpanded","notGlobalExpanded","_expanded","modules","noShadow","onContextMenu","parentPrivate","planEdit","archived","_isFavorite","myDayOption","myDayClick","onAction","at","selectOption","viewButton","toCopyMove","updateCard","disableDelete","my","showCompleteOption","prevExpanded","_cardCode","showTags","_recurrenceId","noShowRecurrenceCard","recurrenceCreatedDate","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","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","ws","secondaryParent","valueSelect","returnArray","validation","all","autoCompleteProps","inNode","Autocomplete","CustomChip","deleteIcon","textField","labelTop","noLabel","labelTopLight","noLabelLight","values","setValues","newValues","getOptionLabel","limitTags","freeSolo","disableClearable","renderInput","renderOption","renderTags","getTagProps","colorPickerCallBack","icons","instruction","picture","changeTags","switch","accessDescription","iniData","emailError","setEmailError","changeData","cl","saveUser","exist","disabledFields","userAdmin","userEdit","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","loadFiles","page","asc","childrens","reqFiles","navFolders","reqFolders","navFiles","selectedParent","setSelectedParent","setPreloader","folders","setFolders","searchFolder","setSearchFolder","idPlan","fds","lf","folder","openFolder","nFolders","RenderFolder","reqSubFolders","AutomationAction","ignoreValues","setOnConcludedStepMoveTo","showSumValues","ignoreTypes","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","ColumnSettings","CardSettings","mod","rq","ic","tagUpdate","newTagResult","tagDelete","localTagDelete","tagUnlink","localTagUnlink","tagLink","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","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","ended","setEnded","setHashs","setLinks","setMax","refs","Nhashs","_feeds","back","li","setFeeds","iniFeeds","showHidden","aFeeds","nfeeds","sp","follow","editorInput","messageWithUrl","setStories","timelineD","readMessages","showUnReaded","endLinks","setEndLinks","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","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","strategicStatement","noPagination","Ideas","Dashboard","myDayTasksContent","showStatus","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","agileOrderBy","agileOrderDesc","groupByColor","rowExpandeds","separators","showDeleted","ac","parentId","orderAN","orderAN2","bc","orderBN","orderBN2","columnName","columnIcon","customColumns","cardbyGroup","separatorTitle","separatorColor","Item","clone","isDropAnimating","setRowExpanded","columnId","isDropDisabled","columnsSettings","isCombineEnabled","mode","renderClone","rubric","inLineAdd","outerRef","itemData","typeAdd","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","discount","useLayoutEffect","scrollTo","RowProps","itens","isUsingPlaceholder","Column","hideDescription","hideValue","discountHeight","setDiscountHeight","columnHeaderRef","ColumnData","sumValues","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","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","focused","accountData","secretView","setSecretView","reqIntegrationToken","ntk","secretKey","clipboard","writeText","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","Modal","aria-describedby","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","move","copyName","setCopyName","copyModel","copyRel","setCopyRel","selectTarget","setSelectTarget","duplicateLoader","setDuplicateLoader","duplicateCard","isModel","planningTypes","setParentCard","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","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","allStatus","completedDays","reqData","mount","ndata","filterCards","cardCode","favorite","_myDay","inFlow","parentCompleted","startOf","endOf","_loadedFeeds","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","lineSmooth","Interpolation","cardinal","tension","chartPadding","emailsSubscriptionChart","responsiveOptions","seriesBarDistance","labelInterpolationFnc","draw","begin","dur","easing","completedTasksChart","scale","chartRect","Svg","Easing","easeOutQuint","roundedLineChart","showPoint","straightLinesChart","point","simpleBarChart","colouredLineChart","multipleBarsChart","colouredLinesChart","pieChart","setBadgeVisible","toolTipOpen","setToolTipOpen","disableTouchListene","invisible"],"mappings":";+1BACA,kmGAAAA,GAAA,wBAAAA,EAAA,sBAAAA,GAAA,iBAAAA,GAAA,ssDAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,4bAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,yhBAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,qGAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,sQAYAC,EAAQ,KAAUC,SAElB,IAAMC,EAAcC,OAAOC,SAASC,SAASC,QAAQ,cAAgB,GAA4C,SAAvCC,OAAOC,QAG3EC,EAAY,SAACC,EAAIC,GACnB,GAAID,EAAI,CACJ,IAAME,EAAQC,IAAWC,WAAWC,WAAa,GACzCC,EAAYH,IAAWC,WAAvBE,QAEJC,EAAWD,GAAWA,EAAQC,SAAWD,EAAQC,SAAW,QAG5DC,EAAUR,EAEd,KAAIA,GAAMA,EAAGJ,QAAQ,QAAU,GAoB3B,OAAOI,EAnBPA,EAAGS,MAAM,KAAKC,KAAI,SAACC,EAAGtB,GAClB,GAAIsB,GAAKA,EAAEf,QAAQ,QAAU,EAAG,CAC5B,IAAIgB,EAAOD,EAAEE,QAAQ,MAAO,IAAIC,OAAOC,cACvC,GAAIvB,IAAgBU,EAAMU,GAAO,CAC7BI,QAAQC,IAAI,MAAOL,GACnB,IACIM,IAAIC,KAAK,eAAgB,CACrBC,KAAMR,IAEZ,MAAOS,GACLL,QAAQC,IAAII,IAGhBnB,EAAMU,IAASV,EAAMU,GAAMU,QAAQC,QAAO,SAAAZ,GAAC,OAAIA,EAAEa,SAAWjB,KAAUkB,OAAS,GAAKvB,EAAMU,GAAMU,QAAQC,QAAO,SAAAZ,GAAC,OAAIA,EAAEa,SAAWjB,KAAU,GAAGa,OAC9IZ,EAAUA,EAAQK,QAAQ,GAAD,OAAIF,GAAC,UAAOtB,EAAI,EAAC,QAAW,OAAGa,EAAMU,GAAMU,QAAQC,QAAO,SAAAZ,GAAC,OAAIA,EAAEa,SAAWjB,KAAU,GAAGa,YAQlI,IAAIM,EAASlB,EAEb,IAAKkB,EACD,MAAO,GAEX,IAAKzB,EACD,OAAOyB,EAEX,GAAc,MAAVzB,EACA,OAAOyB,EAAOC,cAElB,GAAc,IAAV1B,EACA,OAAOyB,EAAOE,UAAU,EAAG,GAAGD,cAAcE,OAAOH,EAAOE,UAAU,MAIhF,SAASE,EAAMC,EAAKC,GAA8C,IAApCC,EAAM,uDAAG,QAASC,EAAM,uDAAG,OACrD,GAAmB,qBAARH,GAA+B,OAARA,EAC9B,MAAO,GAEX,IAAII,EAAYH,GAAgC,qBAAbA,EAA4BC,EAASC,EACxE,OAAQH,EAAM,IAAIlB,QAAQ,gCAAiC,KAAOsB,EAAW,MAIjF,SAASC,EAAUL,EAAKM,GACpB,GAAI,iCAAiCC,KAAKP,GAAM,CAC5C,IAAIQ,EAAMR,EAAIS,OAAO,GACrBD,EAAoB,GAAdA,EAAId,OAAcc,EAAI1B,QAAQ,OAAQ,QAAU0B,EACtD,IAAIE,EAAMC,SAASH,EAAK,IACxB,MAAM,QAAN,OAAe,CAAEE,GAAO,GAAM,IAAMA,GAAO,EAAK,IAAW,IAANA,GAAU,aAAKJ,GAAW,EAAC,KAEpF,OAAIA,GAAWN,GAAOA,EAAInC,QAAQ,QAAU,IAA8B,IAAzBmC,EAAInC,QAAQ,QAClDmC,EAAIlB,QAAQ,IAAI,KAAD,OAAOwB,EAAO,MAAKxB,QAAQ,OAAQ,SAElDkB,EAOf,SAASY,EAAUC,EAAMP,GACrB,GAAIlC,IAEA,OAAOiC,EADOjC,IAAWC,WAAWE,QAAQuC,OACrBD,GAAOP,IAAYO,EAIlD,SAASE,EAAcC,GAEnB,QADa,qFACDT,KAAKS,GAsBrB,SAASC,IAAwB,IAAfC,EAAO,uDAAG,GACpBC,EAAMC,IAAIC,KAAKC,UAAUJ,IAAUK,WAEnCC,EAAUN,EAAQM,QAAUN,EAAQM,QAAUN,EAAQO,QACtDP,EAAQQ,UACRF,EACI,yBAAKtD,MAAO,CAAEyD,SAAU,UACnBH,EACD,yBAAKtD,MAAO,CAAE0D,QAAS,OAAQC,MAAO,OAAQC,UAAW,GAAIC,eAAgB,WACzE,kBAAC,IAAY,CACTC,QAAM,EACNC,MAAOjE,EAAU,cACjBkE,KAAMlE,EAAU,cAChBmE,MAAM,QACNC,KAAM,QACNC,KAAM,OACNC,QAAS,WACLpB,EAAQQ,UACRa,IAAMC,QAAQrB,MAItB,kBAAC,IAAY,CACTa,QAAM,EACNC,MAAOjE,EAAU,aACjBkE,KAAMlE,EAAU,aAChBmE,MAAM,MACNC,KAAM,QACNC,KAAM,OACNC,QAAS,WACLC,IAAMC,QAAQrB,IAElBjD,MAAO,CAAEuE,WAAY,SAMrCvB,EAAQwB,SAAWxB,EAAQwB,QAAQhD,OAAS,IAC5C8B,EACI,yBAAKtD,MAAO,CAAEyD,SAAU,UACnBH,EACD,yBAAKtD,MAAO,CAAE2D,MAAO,OAAQC,UAAW,GAAIC,eAAgB,WACvDb,EAAQwB,QAAQ/D,KAAI,SAACgE,EAAGC,GAAE,OACvB,kBAAC,IAAY,eACTzB,IAAKyB,GACDD,EAAC,CACLzE,MAAK,2BACEgD,GAAWA,EAAQhD,MAAQgD,EAAQhD,MAAQ,IAAE,IAChD2E,aAAc,KAElBP,QAAS,WACDK,EAAEL,SACFK,EAAEL,UACNC,IAAMC,QAAQrB,aAS1C,IAAI2B,EAAY,qCACZC,QAAS5B,EACT6B,SAAUT,IAAMU,SAASC,cACtBhC,EAAQA,QAAUA,EAAQA,QAAU,IACnCA,EAAQiC,QAAwE,GAA9D,CAAEC,UAAWlC,EAAQkC,UAAYlC,EAAQkC,UAAY,MAAW,IACtFlF,MAAO,CAAEyD,SAAU,WAiCvB,MA9B2B,SAAvBT,EAAQmC,aACRP,EAAY,2BACLA,GAAY,IACfE,SAAUT,IAAMU,SAASK,eAEN,UAAvBpC,EAAQmC,aACRP,EAAY,2BACLA,GAAY,IACfE,SAAUT,IAAMU,SAASC,gBAEN,WAAvBhC,EAAQmC,aACRP,EAAY,2BACLA,GAAY,IACfE,SAAUT,IAAMU,SAASM,iBAI5BhB,IAAMiB,SAASrC,KACQ,SAApBD,EAAQuC,SAAuBvC,EAAQuC,SACvClB,IAAMmB,KAAKlC,EAASsB,GAEA,YAApB5B,EAAQuC,SACRlB,IAAMoB,QAAQnC,EAASsB,GAEH,YAApB5B,EAAQuC,SACRlB,IAAMqB,KAAKpC,EAASsB,GAEA,UAApB5B,EAAQuC,SACRlB,IAAMsB,MAAMrC,EAASsB,KAEtB,EAGX,IAAMgB,EAAU,SAACC,GAAqB,IAAhBC,EAAM,uDAAG,EAC3B,IAAKD,EACD,MAAM,GAEV,IAAIE,EAAQF,EAAIjF,QAAQ,MAAO,IAC/B,IAAKmF,EAAMC,MAAM,OAAS,IAAIxE,OAAS,EAAG,CAEtC,IAAIyE,GADJF,EAAQF,EAAIjF,QAAQ,IAAK,MACVJ,MAAM,KACrB,GAAkB,IAAdyF,EAAGzE,OACH,OAAO0E,WAAWH,GACtBA,EAAQA,EAAMI,WAAW,IAAD,OAAKF,EAAGA,EAAGzE,OAAS,IAAE,IAC9CuE,EAAQnG,OAAOmG,GAAOI,WAAW,IAAK,IACtC,IAAIP,EAAUK,EAAGA,EAAGzE,OAAS,GAAGG,UAAU,EAAGmE,GAC7CC,EAAK,UAAMA,EAAK,YAAIH,GAExB,OAAOG,GAGLK,EAAe,SAAC1F,GAAgC,IAA7B2F,EAAC,uDAAG,UAAWC,EAAQ,uCAC5C,IAAK5F,EACD,MAAO,GACX,MAAoBR,IAAWC,WAAvBE,EAAO,EAAPA,QAEJ0F,EAAQnG,OAAOc,GAAGE,QAAQ,IAAK,KAC/BZ,EAAQqG,EAGZ,GAAc,WAAVrG,GAAgC,SAAVA,GAA8B,YAAVA,EAC1CA,EAAQ,cACL,IAAc,YAAVA,EACP,MAAM,GAAN,OAAU+F,EAAK,KAEZ,GAAc,aAAV/F,EACP,OAAOJ,OAAOc,GAGlB,IAAIe,EAAS,IAAI8E,KAAKC,aAAanG,EAAQuC,OAAOrB,OAAQ,CAAEvB,MAAOA,EAAOsG,SAAUA,IAAsBjG,EAAQuC,OAAO0D,SAAWjG,EAAQuC,OAAO0D,SAAW,SAG9J,OADA7E,EAAOgF,yBAAiC,WAANJ,EAAiB,EAAI,EAChD5E,EAAOiF,OAAOX,IAGnBY,EAAc,SAACC,EAAOC,GAExB,IAAIC,EAAa5G,IAAWC,WAAWC,UAAUyG,EAAKE,QAAU7G,IAAWC,WAAWC,UAAUyG,EAAKE,OAAO1F,QAAU2F,MAAMC,KAAK/G,IAAWC,WAAWC,UAAUyG,EAAKE,OAAO1F,SAAW,GAExLyF,EAAWI,SAAQ,SAAAxG,GACf,GAAIA,EAAEa,SAAWsF,EAAKtF,OAClB,MAAO,CAACb,EAAES,KAAO0F,EAAK7C,SAEoC,IAA9D8C,EAAWxF,QAAO,SAAA6F,GAAE,OAAIA,EAAG5F,SAAWsF,EAAKtF,UAAQC,QACnDsF,EAAWM,KAAK,CACZC,IAAKR,EAAKQ,IACV9F,OAAQsF,EAAKtF,OACbJ,KAAM0F,EAAK7C,OAGnB4C,EAAMU,cAAc,QAAS,eAAe,2BACrCpH,IAAWC,WAAWC,WAAS,kBACjCyG,EAAKE,MAAK,2BACJ7G,IAAWC,WAAWC,UAAUyG,EAAKE,QAAU7G,IAAWC,WAAWC,UAAUyG,EAAKE,QAAM,IAC7F1F,QAASyF,QAKfS,EAAU,uCAAG,WAAOX,EAAOC,EAAMW,GAAS,uFAAiB,gCAAQ,EACxDtH,IAAWC,WAAlBsH,EAAE,EAAFA,GACFC,EAAW,QACXD,EAAGE,MAAMd,EAAKQ,KACdK,EAAW,QACJD,EAAGG,MAAMf,EAAKQ,OACrBK,EAAW,SAGfd,EAAMU,cAAc,QAAS,SAAS,2BAC/BpH,IAAWC,WAAWsH,IAAE,kBAC1BC,EAAQ,2BACFxH,IAAWC,WAAWsH,GAAGC,IAAS,kBACpCb,EAAKQ,IAAG,2BACFnH,IAAWC,WAAWsH,GAAGC,GAAUb,EAAKQ,MAAI,IAC/CQ,SAAS,SAGlB,2CACN,gBAnBe,0CAoBVC,EAAc,SAAChG,GAKjB,IAJA,IAAIiG,EAAQ,uQAGRC,EAAS,GACJ5I,EAAI,EAAGA,EAAI0C,EAAIN,OAAQpC,IAAK,CAEjC,IADA,IAAI6I,GAAS,EACJvH,EAAI,EAAGA,EAAIqH,EAAMvG,OAAQd,IAC9B,GAAIoB,EAAIS,OAAOnD,EAAG,IAAM2I,EAAMxF,OAAO7B,EAAG,GAAI,CACxCsH,GAPG,mEAOgBzF,OAAO7B,EAAG,GAC7BuH,GAAS,EACT,MAGM,GAAVA,IACAD,GAAUlG,EAAIS,OAAOnD,EAAG,IAGhC,OAAO4I,GAGLE,EAAc,SAAClE,EAAMmE,EAAWC,GAClC,IAAKD,GAAcA,IAAcA,EAAUtH,OACvC,OAAO,0BAAMb,MAAO,CAAEqI,UAAW,cAAgBC,wBAAyB,CACtEC,OAAQ1G,EAAMmC,MAGtB,IACMwE,EADQ3G,EAAMmC,GACExD,MAAM,IAAIiI,OAAO,IAAD,OAAKN,EAAUvH,QAAQ,KAAM,KAAI,KAAK,OAC5E,OACI,kCAAQ4H,EAAM/H,KAAI,SAACiI,EAAMtJ,GAAC,OACtB,0BAAM6D,IAAK7D,EAAGY,MAAO0I,EAAK5H,gBAAkBqH,EAAUrH,cAAgB,CAAE6H,WAAY,OAAQC,WAAY,MAAOC,cAAe,MAAOC,gBAAiB,YAAa7E,MAAOmE,EAAO,qBAAuB,IAAO,GAC3ME,wBAAyB,CACrBC,OAAQ1G,EAAM6G,SAGd,MAKdK,EAAQ,SAAC/E,GACX,IACMgF,EADQnH,EAAMmC,GACExD,MAAM,MAExBiB,EAAS,GAqCb,OApCAuH,EAAMvI,KAAI,SAACwI,GACOA,EAAGzI,MAAM,KACjBC,KAAI,SAAAyI,GACN,IAAIC,EAAMD,EAAK1I,MAAM,MACrB,GAAI2I,EAAI3H,OAAS,EACb2H,EAAI1I,KAAI,SAAC2I,GACL,GAAIA,EAAIzJ,QAAQ,wBAA0B,EAAG,CACzC,IAAI0J,EAAUD,EAAI5I,MAAM,KAAK,GAAGA,MAAM,MAAM,GAAGA,MAAM,KAAK,GACtD6I,IACA5H,GAAM,kHAA+G4H,EAAO,mLAC7H,GAAID,EAAIzJ,QAAQ,gBAAkB,EAAG,CACxC,IAAI0J,EAAUD,EAAI5I,MAAM,QAAQ,GAC5B6I,IACA5H,GAAM,kHAA+G4H,EAAO,mLACzHD,EAAIzJ,QAAQ,YAAc,GAAKyJ,EAAIzJ,QAAQ,aAAe,EACjE8B,GAAM,gDAA6C2H,EAAIxI,QAAQ,QAAS,IAAG,6BAAqBwI,EAAG,QAEnG3H,GAAU2H,KAGlB3H,GAAU,SACP,GAAI0H,EAAI,GAAGxJ,QAAQ,wBAA0B,GAC7CwJ,EAAI,GAAG3I,MAAM,KAAKgB,OAAS,GAC3B2H,EAAI,GAAG3I,MAAM,KAAK,GAAGA,MAAM,MAAMgB,OAAS,EAC/C,CACE,IAAI6H,EAAUF,EAAI,GAAG3I,MAAM,KAAK,GAAGA,MAAM,MAAM,GAAGA,MAAM,KAAK,GACzD6I,IACA5H,GAAM,kHAA+G4H,EAAO,mLACzHF,EAAI,GAAGxJ,QAAQ,YAAc,GAAKwJ,EAAI,GAAGxJ,QAAQ,aAAe,EACvE8B,GAAM,mBAAgB0H,EAAI,GAAGvI,QAAQ,QAAS,IAAG,6BAAqBuI,EAAI,GAAE,SAE5E1H,GAAM,UAAOyH,EAAI,QAGzBzH,GAAU,MAEPA,GA+BL6H,EAAe,WACjB,IAAQjJ,EAAYH,IAAWC,WAAvBE,QACJkJ,EAAY,GAGhB,OAFIlJ,GAAWA,EAAQmJ,UACnBD,EAAYlJ,EAAQmJ,SACjBD,GAGLE,EAAY,uCAAG,WAAO7C,EAAOS,GAAG,qFACxB,GAD0BqC,EAAG,gCAAQ,EAChCxJ,IAAWC,WAAhB,EAAFsH,GACHiC,EAAI,CAAD,yCAEuBzI,IAAI0I,IAAI,iBAAkB,CAAEtC,QAAM,OAA3C,uDAEdtG,QAAQC,IAAI,EAAD,IAAG,2DAISC,IAAI2I,OAAO,kBAAD,OAAmBvC,IAAM,QAA5C,0DAEdtG,QAAQC,IAAI,EAAD,IAAG,iEAGzB,gBAfiB,wCAiBZ6I,EAAU,SAACnJ,GAEb,IADA,IAAI2F,EAAI3F,EACY,IAAb2F,EAAE7E,QACL6E,EAAI,IAAMA,EAEd,OAAOA,GAGLyD,EAAY,SAACC,EAAUC,GAA6C,IAElEC,EACAC,EACAzF,EAJyB0F,EAAK,uDAAG,UAAW/B,EAAI,uDAAG,UACnDnE,EAAQ8F,EAKZ,GAAI9F,EAAMtE,QAAQ,SAAW,EAAG,CAE5B,IAAIyK,GADJnG,EAAQA,EAAMrD,QAAQ,QAAS,KACZJ,MAAM,KACzByJ,EAAIG,EAAO,GACXF,EAAIE,EAAO,GACX3F,EAAI2F,EAAO,OACR,CAOH,GAN2B,IAAvBnG,EAAMtE,QAAQ,OACdsE,EAAQA,EAAMoG,MAAM,IAEH,IAAjBpG,EAAMzC,SACNyC,EAAQA,EAAM,GAAKA,EAAM,GAAKA,EAAM,GAAKA,EAAM,GAAKA,EAAM,GAAKA,EAAM,IAEpD,IAAjBA,EAAMzC,OACN,MAAM,IAAI8I,MAAM,sBAEpBL,EAAIxH,SAASwB,EAAMoG,MAAM,EAAG,GAAI,IAChCH,EAAIzH,SAASwB,EAAMoG,MAAM,EAAG,GAAI,IAChC5F,EAAIhC,SAASwB,EAAMoG,MAAM,EAAG,GAAI,IAGpC,OAAIL,EACY,KAAJC,EAAgB,KAAJC,EAAgB,KAAJzF,EAAa,IACvC2D,EACA+B,GAEVF,GAAK,IAAMA,GAAG5G,SAAS,IACvB6G,GAAK,IAAMA,GAAG7G,SAAS,IACvBoB,GAAK,IAAMA,GAAGpB,SAAS,IAChB,IAAMwG,EAAQI,GAAKJ,EAAQK,GAAKL,EAAQpF,KAG7C8F,EAAU,SAACC,GACb,IAAIC,EAAO,EAMX,OAJIA,GADC,OAADD,QAAC,IAADA,OAAC,EAADA,EAAGE,KACIjI,SAAS+H,EAAEE,KAEXjI,SAAS+H,GAEhBG,IAAO,IAAIC,MAAQC,GAAG,qBAAqBnE,OAAO,gBAAkBiE,IAAc,IAAPF,GAAaI,GAAG,qBAAqBnE,OAAO,cAChHiE,IAAc,IAAPF,GAAaI,GAAG,qBAAqBnE,OAAO,QACnDiE,IAAO,IAAIC,MAAQC,GAAG,qBAAqBnE,OAAO,UAAYiE,IAAc,IAAPF,GAAaI,GAAG,qBAAqBnE,OAAO,QACjHiE,IAAc,IAAPF,GAAaI,GAAG,qBAAqBnE,OAAO,cAEnDiE,IAAc,IAAPF,GAAaI,GAAG,qBAAqBnE,OAAO,oBAIlE,SAASoE,EAAgBC,GAOrB,OANIA,GAAS,WAAcA,GAASA,EAAQ,YAAYC,QAAQ,GAAK,MAC5DD,GAAS,QAAWA,GAASA,EAAQ,SAASC,QAAQ,GAAK,MAC3DD,GAAS,KAAQA,GAASA,EAAQ,MAAMC,QAAQ,GAAK,MACrDD,EAAQ,EAAKA,GAAgB,SACpB,GAATA,EAAcA,GAAgB,QAChCA,EAAQ,UACRA,EAKX,SAASE,EAAaF,GAAsB,IAAfG,EAAQ,uDAAG,EACpC,GAAc,IAAVH,EAAa,MAAO,UACxB,IAAMI,EAAI,KACJC,EAAKF,EAAW,EAAI,EAAIA,EACxBG,EAAQ,CAAC,QAAS,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,MAC5DjM,EAAIkM,KAAKC,MAAMD,KAAKtK,IAAI+J,GAASO,KAAKtK,IAAImK,IAChD,OAAOjF,YAAY6E,EAAQO,KAAKE,IAAIL,EAAG/L,IAAI4L,QAAQI,IAAO,IAAMC,EAAMjM,K,qBCphB1EqM,EAAOC,QAAU,IAA0B,6C,qBCA3CD,EAAOC,QAAU,IAA0B,6C,mBCA3CD,EAAOC,QAAU,swH,6PCgCXC,EAAYC,UAAOC,IAAG,2JAC1B,SAAAjF,GAAK,OACCA,EAAMkF,YAAclF,EAAMmF,SAAQ,mBAE5BnF,EAAMkF,WAAU,2BAI5B,SAAAlF,GAAK,OACCA,EAAMoF,OAAM,kDAIlB,SAAApF,GAAK,OACCA,EAAMqF,SAAQ,gCACerF,EAAMqF,SAAQ,WAGjD,SAAArF,GAAK,OACEA,EAAMkF,YAAclF,EAAMmF,SAAQ,kCACJrJ,YAAU,SAAQ,WAGvD,SAAAkE,GAAK,OACCA,EAAMsF,cACA,GACAtF,EAAMuF,WAAU,yDAK5B,SAAAvF,GAAK,OACCA,EAAMwF,OAAM,4PAkNLC,iBAVS,SAACC,GACrB,MAAO,CACHA,MAAO,CACH3E,MAAO2E,EAAM7E,GAAGE,WAID,SAAA4E,GAAQ,OAC/BC,YAAmBC,EAAcF,KAEtBF,CAGbK,YAAWC,IAAXD,EApMF,SAAc9F,GACV,IAAQgG,EAAYhG,EAAZgG,QACAnF,EAAOvH,IAAWC,WAAlBsH,GAEJZ,EAAOD,EAAMC,MAAQD,EAAMC,KAAKQ,IAAMnH,IAAWC,WAAWsH,GAAGE,MAAMf,EAAMC,KAAKQ,KAAO,GAEvFwF,EAAQC,OAAOC,KAAK7M,IAAWC,WAAWsH,GAAGE,OAAOrG,QAAO,SAAA0L,GAAI,OAC/D9M,IAAWC,WAAWsH,GAAGE,MAAMqF,IAC5BnG,GACAA,EAAKoG,SACL/M,IAAWC,WAAWsH,GAAGE,MAAMd,EAAKoG,UACpC/M,IAAWC,WAAWsH,GAAGE,MAAMqF,GAAMC,UAAY/M,IAAWC,WAAWsH,GAAGE,MAAMd,EAAKoG,SAASA,SAChD,SAA9C/M,IAAWC,WAAWsH,GAAGE,MAAMqF,GAAME,OACpChN,IAAWC,WAAWsH,GAAGE,MAAMqF,GAAMnF,WAExCsF,MAAK,SAACzM,EAAG+D,GACN,IAAI2I,EAAS3K,SAASvC,IAAWC,WAAWsH,GAAGE,MAAMjH,GAAG2M,MACpDC,EAAS7K,SAASvC,IAAWC,WAAWsH,GAAGE,MAAMlD,GAAG4I,MAExD,OAAID,EAASE,GACD,EACRF,EAASE,EACF,EACJ,KACR7M,KAAI,SAAAuM,GAAI,OAAI9M,IAAWC,WAAWsH,GAAGE,MAAMqF,MAElD,OACI,kBAACrB,EAAS,iBACF/E,EAAM2G,UAAY3G,EAAM2G,SAASC,eAAc,CACnDC,IAAK7G,EAAM2G,UAAY3G,EAAM2G,SAASG,SACtCvB,WAAYvF,EAAM+G,UAAY/G,EAAM+G,SAASxB,WAC7CD,cAAerF,EAAKqF,eAAiBtF,EAAMsF,gBAAiB,EAC5DE,OAAQxF,EAAMwF,OACdwB,UAAWhB,EAAQiB,UACnB/B,WAAYlF,EAAMkH,aAClB/B,SAAUlF,EAAKkH,UACf9B,SAAUpF,EAAKoF,SAAWxE,EAAGwE,SAAS3K,QAAO,SAAAZ,GAAC,OAAId,OAAOc,EAAEqF,SAAWnG,OAAOiH,EAAKoF,aAAW,GAAGhI,MAAQ,KACxG+H,OAAQpF,EAAMoF,SAAU,EACxB5H,QAAS,WACLwC,EAAMU,cAAc,QAAS,aAAa,2BACnCpH,IAAWC,WAAW6N,YAAU,IACnCvG,GAAI,QACJwG,GAAIpH,EAAKQ,IACToE,OAAQ,WACRyC,aAAchO,IAAWC,WAAWsH,GAAG0G,SAAS7M,QAAO,SAAAZ,GAAC,OAAIA,EAAES,OAAS0F,EAAKqG,QAAM,GAAGkB,WAAa3C,EAClG5E,KAAMA,QAId,wBAASD,EAAM2G,UAAY3G,EAAM2G,SAASc,gBAEtC,yBACIrO,MAAO,CACH8E,SAAU,WACVwJ,WAAY,WAGhB,yBAAKtO,MAAO,CACR2D,MAAO,OACP4K,QAAS,MACT7K,QAAS,OACTG,eAAgB,kBAEfgD,EAAK1F,KAAO0F,EAAK1F,KAAOrB,YAAU,SAAU,GAC7C,kBAAC,IAAiB,CAAC0O,OAAQ3H,EAAKQ,OAEpC,yBAAKrH,MAAO,CACR8E,SAAU,WACV2J,MAAO,OACP9K,MAAO,SAEP,6BAAM7D,YAAU,UAAW,KAAI,IAAG+M,EAAM6B,WAAU,SAAAhO,GAAC,OAAIA,EAAE2G,MAAQR,EAAKoG,WAAW,EAAC,IAAGnN,YAAU,SAAQ,IAAG+M,EAAMrL,QAChH,yBACIxB,MAAO,CACH8E,SAAU,WACVnB,MAAO,OACPgL,OAAQ,4BACR9K,eAAgB,gBAChBH,QAAS,OACT4K,WAAY,SACZM,aAAc,IAGjB/B,EAAMpM,KAAI,SAACoO,EAAGC,GAAE,OACb,kBAAC,IAAW,CACRC,OAAK,EACLhL,MACI,6BACK8K,EAAE1N,KAAI,KAAI0L,EAAM6B,WAAU,SAAAhO,GAAC,OAAIA,EAAE2G,MAAQR,EAAKoG,WAAW6B,EAAKhP,YAAU,gBAAkB+M,EAAM6B,WAAU,SAAAhO,GAAC,OAAIA,EAAE2G,MAAQR,EAAKoG,aAAa6B,EAAKhP,YAAU,MAAD,OAAO+G,EAAKmI,SAAYlP,YAAU,6BAA4B,MAIhO,yBACImD,IAAK4L,EAAExH,IACPrH,MAAK,iDACDiP,OAAQ,GACLpC,EAAM6B,WAAU,SAAAhO,GAAC,OAAIA,EAAE2G,MAAQR,EAAKoG,WAAW6B,EAAK,CAAEhG,gBAAiB,WAAc,IACrF+D,EAAM6B,WAAU,SAAAhO,GAAC,OAAIA,EAAE2G,MAAQR,EAAKoG,aAAa6B,EAAK,CAAEhG,gBAAiB,WAAc,IACvF+D,EAAM6B,WAAU,SAAAhO,GAAC,OAAIA,EAAE2G,MAAQR,EAAKoG,WAAW6B,EAAK,CAAEhG,gBAAiB,WAAc,IAAE,IAC1FnF,MAAO,yBACPgL,OAAQ,4BAIxB,kBAAC,IAAW,CACRI,OAAK,EACLhL,MACI,6BACKjE,YAAU,MAAD,OAAO+G,EAAKmI,QAAU,OAIxC,6BACI,kBAAC,IAAI,CAAC/K,MAAO/D,IAAWC,WAAWsH,GAAGuH,OAAO1N,QAAO,SAAA4N,GAAE,OAAIA,EAAGnJ,QAAUc,EAAKmI,UAAQ,GAAG/K,OAAQ/D,IAAWC,WAAWsH,GAAGuH,OAAO1N,QAAO,SAAA4N,GAAE,OAAIA,EAAGnJ,QAAUc,EAAKmI,UAAQ,GAAG9K,UAMzL,yBAAKlE,MAAO,CACR2D,MAAO,OAAQ4K,QAAS,MACxBY,MAAO,UAEJtI,EAAKuI,WAAavI,EAAKwI,SAAaxI,EAAKuI,WAAavI,EAAKwI,UAC1D,yBAAKzB,UAAWhB,EAAQ0C,OACnBzI,EAAKuI,WACF,yBAAKxB,UAAWhB,EAAQ2C,UACpB,kBAAC,IAAK,CACFC,QAAQ,cACR5B,UAAWhB,EAAQ6C,QAASvL,KAAK,oBAAoBH,MAAO,YAAaI,KAAK,OAAOuL,UAAQ,IAC/F,IAAI9E,KAAsB,IAAjB/D,EAAKuI,qBAA6BxE,OAAS+E,MAAM,IAAI/E,KAAsB,IAAjB/D,EAAKuI,YACtEzE,IAAO,IAAIC,KAAsB,IAAjB/D,EAAKuI,YAAmBvE,GAAG,qBAAqBnE,OAAO,cAEvEiE,IAAO9D,EAAKuI,WAAWvE,GAAG,qBAAqBnE,OAAO,eAIjEG,EAAKwI,SACF,yBAAKzB,UAAWhB,EAAQ2C,UACpB,kBAAC,IAAK,CACFC,QAAQ,cACR5B,UAAWhB,EAAQ6C,QAASvL,KAAK,kBAAkBH,MAAO,UAAWI,KAAK,OAAOuL,UAAQ,IAC3F,IAAI9E,KAAoB,IAAf/D,EAAKwI,mBAA2BzE,OAAS+E,MAAM,IAAI/E,KAAoB,IAAf/D,EAAKwI,UACpE1E,IAAO,IAAIC,KAAoB,IAAf/D,EAAKwI,UAAiBxE,GAAG,qBAAqBnE,OAAO,cAErEiE,IAAO9D,EAAKwI,SAASxE,GAAG,qBAAqBnE,OAAO,gBAMvEG,GAAQA,EAAK+I,QAAU9C,OAAOC,KAAKlG,EAAK+I,QAAQpO,OAAS,GACtD,yBAAKoM,UAAWhB,EAAQiD,cACpB,yBAAKjC,UAAWhB,EAAQhF,OACpB,kBAAC,IAAW,CAACkI,IAAK,GACbhD,OAAOC,KAAKlG,EAAK+I,QAAQnP,KAAI,SAACC,EAAGtB,GAC9B,GAAIyH,EAAK+I,OAAOlP,IAAMmG,EAAK+I,OAAOlP,GAAGS,KACjC,OACI,kBAAC,IAAO,CACJ4C,MAAO8C,EAAK+I,OAAOlP,GAAGS,KACtB8B,IAAK7D,GAEL,kBAAC,IAAM,CAAC2Q,IAAKlJ,EAAK+I,OAAOlP,GAAGS,KAAM6O,IAAKnJ,EAAK+I,OAAOlP,GAAGuP,OAASC,KAC1DrJ,EAAK+I,OAAOlP,GAAGS,KAAKoB,OAAO,EAAG,YAUvE,kBAAC,IAAQ,CAACS,QAAS6D,EAAKsJ,MAAOC,aAAa,a,2CC9PhE3E,EAAOC,QAAU,IAA0B,4C,qBCA3CD,EAAOC,QAAU,IAA0B,2C,qBCA3CD,EAAOC,QAAU,IAA0B,0C,oBCE3C,IAAI2E,EAAyBhR,EAAQ,IAErCyN,OAAOwD,eAAe5E,EAAS,aAAc,CAC3C3F,OAAO,IAET2F,EAAQ6E,aAAU,EAElB,IAAIC,EAASH,EAAuBhR,EAAQ,IAIxCoR,GAAW,EAFMJ,EAAuBhR,EAAQ,MAElBkR,SAASC,EAAOD,QAAQG,cAAcF,EAAOD,QAAQI,SAAU,KAAMH,EAAOD,QAAQG,cAAc,OAAQ,CAC1IE,KAAM,OACNpG,EAAG,yHACDgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAG,yHACDgG,EAAOD,QAAQG,cAAc,IAAK,KAAMF,EAAOD,QAAQG,cAAc,OAAQ,CAC/ElG,EAAG,2GACDgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAG,iHACDgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAG,6HACDgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAG,4JACDgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAG,qJACC,UAENkB,EAAQ6E,QAAUE,G,8JClBH,SAASI,EAAUjK,GAC9B,OACI,kBAAC,IAAW,CACR7C,MAAO6C,EAAM7C,MAAQjE,YAAU8G,EAAM7C,MAAO,GAAK,IAEzB,kBAAf6C,EAAM1C,MAAiD,kBAAnB0C,EAAMkK,SAC/C,kBAAC,IAAI,CACDlD,UAAWhH,EAAMgH,UAAYhH,EAAMgH,UAAY,GAC/C5N,MAAK,aACD8E,SAAS,GAAD,OAAK8B,EAAMmK,OAAS,SAAW,IACvCrN,QAAS,OACTG,eAAgB,SAChByK,WAAY,SACZW,OAAQrI,EAAMzC,MAAQ,OACtBR,MAAOiD,EAAMzC,MAAQ,OACrB6M,SAAUpK,EAAMzC,MAAQ,OACxBF,MAAO2C,EAAM3C,OAASvB,YAAU,UAChCN,QAAUwE,EAAM8I,SAAiB,MAAN,IAC3BuB,OAAQrK,EAAMxC,QAAU,UAAY,IACjCwC,EAAM5G,OAEboE,QAASwC,EAAMxC,QAAU,SAAChD,GACtBwF,EAAMxC,UACNhD,EAAE8P,iBACF9P,EAAE+P,mBACF,MAGHvK,EAAM1C,MAAQ0C,EAAMkK,UAGzB,kBAAClK,EAAM1C,KAAI,CACP0J,UAAWhH,EAAMgH,UAAYhH,EAAMgH,UAAY,GAC/C5N,MAAK,aACD2D,MAAOiD,EAAMzC,MAAQ,OACrB8K,OAAQrI,EAAMzC,MAAQ,OACtB6M,SAAUpK,EAAMzC,MAAQ,OACxBF,MAAO2C,EAAM3C,OAASvB,YAAU,UAChCN,QAAUwE,EAAM8I,SAAiB,MAAN,IAC3BuB,OAAQrK,EAAMxC,QAAU,UAAY,GACpCgN,OAAQ,QACLxK,EAAM5G,OAEboE,QAASwC,EAAMxC,QAAU,SAAChD,GACtBwF,EAAMxC,UACNhD,EAAE8P,iBACF9P,EAAE+P,mBACF,U,kJCzDxB,IAAMd,EAAyBhR,EAAQ,IAEvCyN,OAAOwD,eAAe5E,EAAS,aAAc,CAC3C3F,OAAO,IAET2F,EAAQ6E,aAAU,EAElB,IAAMC,EAASH,EAAuBhR,EAAQ,IAIxCoR,GAAW,EAFMJ,EAAuBhR,EAAQ,MAElBkR,SAASC,EAAOD,QAAQG,cAAcF,EAAOD,QAAQI,SAAU,KAAMH,EAAOD,QAAQG,cAAc,OAAQ,CAC5IE,KAAM,OACNpG,EAAE,6cAIAgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAE,6cAIAgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAE,+VAGAgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAE,6UAGAgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAE,kOAEAgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAE,uZAIAgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAE,mUAGAgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAE,uIAEAgG,EAAOD,QAAQG,cAAc,OAAQ,CACvClG,EAAE,2HAEC,UAELkB,EAAQ6E,QAAUE,G,iCCpDlB,qBAGMY,EAAc3E,aAAW,SAAC4E,GAAK,MAAM,CACvCC,QAAS,CACLzI,gBAAiB,UACjB7E,MAAO,sBACPuN,SAAU,IACVR,SAAUM,EAAMG,WAAWC,QAAQ,IACnC/C,OAAQ,oBACRC,aAAc,MACd+C,UAAW,+BACXjO,QAAS,OACT4K,WAAY,SACZzK,eAAgB,aAXJ6I,CAahBkF,KAEWP,O,8JClBR,SAAS/J,EAAc4F,EAAM2E,EAAQ9L,GAAyD,IAAlD+L,EAAI,uDAAG,KAAMC,EAAS,wDAAUC,EAAQ,uDAAG,KAC1F,MAAO,CACH9E,KAAMA,EACN2E,OAAQA,EACR9L,MAAOA,EACP+L,KAAMA,EACNC,UAAWA,EACXC,SAAUA,GAPlB,sD,2OCCA,kmGAAA5S,GAAA,wBAAAA,EAAA,sBAAAA,GAAA,iBAAAA,GAAA,ssDAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,4bAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,yhBAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,qGAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,sQAEO,IAAM6S,EAAM,uCAAG,WAAOhE,EAAIiE,GAAQ,2FAKX,OALaC,EAAQ,gCAAUC,EAAS,wBAC9DC,EAAOH,GACNI,aAAeD,EAAKlR,MACrBoR,EAAW,IAAIC,UACVC,OAAO,OAAQJ,EAAMA,EAAKlR,MACnCoR,EAASE,OAAO,KAAMxE,GAAI,SAGT,IAAIyE,QAAO,uCAAC,WAAOC,EAASC,GAAM,wFAEvCR,IAAaA,EAAUS,iBAAgB,gBAEvC,OADQA,EAAqBT,EAArBS,iBACR,SACoB5R,IAAIC,KAAK,eAAgBqR,EAAU,CACnDM,qBACF,QAFEC,EAAO,UAIPC,EAAaD,EAAQjM,MAAI,wCAET5F,IAAIC,KAAK,eAAgBqR,GAAS,SAAlDO,EAAO,UAEPC,EAAaD,EAAQjM,MAAI,0DAG7BuL,GAAaA,EAAUY,eACvBZ,EAAUY,cAAc,EAAD,IAC3BJ,GAAO,GAAM,QAEA,OAFA,UAEbD,GAAQ,GAAK,6EAGpB,qDAvB2B,IAuB1B,OAvBM,WAyBC,CAAD,mBACCR,EAAS,CAAD,gFAC8BY,EAAWV,OAAI,iCAE/CU,GAAU,0DAGd,GAAK,4CAEnB,gBA1CkB,yC,kIC8CJ/S,EA1CD,CACViT,KAAK,2BACEC,KAAW,IACdpO,SAAU,WACVnB,MAAO,OACPwP,MAAO,MACPC,OAAQ,OACRC,WAAY,OACZpE,OAAQ,MACRtK,aAAc,MACdjB,QAAS,OACTG,eAAgB,WAChByP,SAAU,SACV,SAAU,CACN3P,MAAO,OACP4P,YAAa,MACbtC,OAAQ,UACRhC,OAAQ,MACRL,aAAc,sBAItB4E,SAAS,2BACFN,KAAW,IACdpO,SAAU,WACVnB,MAAO,OACP0P,WAAY,OACZzP,UAAW,MACXe,aAAc,MACdsK,OAAQ,OACRqE,SAAU,SAEV,SAAU,CACNtC,SAAU,OACVzC,QAAS,QACT6C,OAAQ,MACRxC,aAAc,OACd3K,MAAOvB,YAAU,a,mEC1BvB+Q,EAAYC,YAAW/G,GA8HdgH,IA5Hf,SAAkB/M,GACd,IAAMgG,EAAU6G,IAChB,EAAmCG,IAAMC,WAASjN,EAAMwJ,aAA2B,mBAA5E0D,EAAW,KAAEC,EAAW,KAC/B,EAAgDH,IAAMC,UAAS,GAAM,mBAA9DG,EAAgB,KAAEC,EAAmB,KAC5C,EAA8BL,IAAMC,SAAS,IAAG,mBAAzC7Q,EAAO,KAAEkR,EAAU,KAU1B,OARAN,IAAMO,WAAU,WAEZ,OADAD,EAAWhU,IAAWC,WAAWsH,GAAGb,EAAMwN,OAASxN,EAAMwN,OAAS,QAC3D,WACHF,EAAW,IACXD,GAAoB,MAEzB,CAACrN,EAAM5D,UAGN,kBAAC,IAAM2N,SAAQ,KACX,yBAAK/C,UAAYkG,GAAelN,EAAMyN,SAAYzH,EAAQ4G,SAAW5G,EAAQqG,KACzE7O,QACI,SAAChD,GACOwF,EAAM5D,SAAW4D,EAAM5D,QAAQxB,OAAS,IAAMsS,GAC9CC,GAAY,GAEhB3S,EAAE+P,mBAGVmD,YAAa,WACTL,GAAoB,IAExBM,aAAc,WACVC,YAAW,WACPP,GAAoB,KACrB,OAINjR,GAAWA,EAAQxB,OAAS,GAAKoF,EAAM5D,SACpC4D,EAAM5D,QACD1B,QAAO,SAAAmT,GAAE,OAAIA,EAAG1O,SAChBtF,KAAI,SAACgU,EAAIrV,GACN,IAAIsV,EAAID,EACR,GAAIvU,IAAWC,WAAWsH,GAAGkN,IAAIrT,QAAO,SAAAZ,GAAC,OAAIA,EAAEqF,QAAU0O,EAAG1O,SAAOvE,OAAS,EAAG,CAC3EkT,EAAIxU,IAAWC,WAAWsH,GAAGkN,IAAIrT,QAAO,SAAAZ,GAAC,OAAIA,EAAEqF,QAAU0O,EAAG1O,SAAO,GACnE,IAAI9B,EAAQjB,EAAQ1B,QAAO,SAAAZ,GAAC,OAAIA,EAAEqF,QAAU2O,EAAE3O,SAAOvE,OAAS,GAAKwB,EAAQ1B,QAAO,SAAAZ,GAAC,OAAIA,EAAEqF,QAAU2O,EAAE3O,SAAO,GAAG9B,MAAQjB,EAAQ1B,QAAO,SAAAZ,GAAC,OAAIA,EAAEqF,QAAU2O,EAAE3O,SAAO,GAAG9B,MAAQvB,YAAU,UACrL,OACI,yBACIO,IAAK7D,EACLwO,UAAW,MACX5N,MAAK,aACD8E,SAAU,WACV2J,MAAO,OACPmG,WAAY,SACZ9L,gBAAiB7E,GACd2C,EAAMiO,QAAU,CAAEjG,aAAc,kBAAqB,IAE5DxK,QAAS,WACAwC,EAAMkO,aAAgBlO,EAAMwJ,aAC7B2D,GAAY,MAGjBnN,EAAMwJ,aAAe0D,GAAelN,EAAMkO,YACzC,kBAACC,EAAA,EAAW,CACRC,MAAON,EAAEM,MACT/Q,MAAOA,EACPoD,IAAKqN,EAAE3O,MACPkP,SAAU,SAACC,GACP,IAAIC,EAAST,EACbS,EAAOlR,MAAQiR,EACfhV,IAAWC,WAAWiS,UAAUgD,OAAOC,KAAK,UAAWF,OAK9DrB,GAAelN,EAAMyN,WACtB,yBACIzG,UAAW,MACX5N,MAAK,aACD8I,gBAAiB7E,EACjBA,MAAOyQ,EAAEzQ,MAAQ6F,YAAU4K,EAAEzQ,OAAO,GAAQ,UAC5CP,QAAS,OAAQ4K,WAAY,UAC1B1H,EAAMiO,QAAU,CAAEjG,aAAc,kBAAqB,KAG3D8F,EAAEY,QAAUpV,IAAWC,WAAWsH,GAAGkN,IAAIrT,QAAO,SAAAiU,GAAE,OAAIA,EAAGxP,QAAU2O,EAAEY,UAAQ9T,OAAS,EACnF,yBACIxB,MAAO,CACHgR,SAAU,EACVuC,YAAa,IAEnBrT,IAAWC,WAAWsH,GAAGkN,IAAIrT,QAAO,SAAAiU,GAAE,OAAIA,EAAGxP,QAAU2O,EAAEY,UAAQ,GAAGN,MAAK,OACzE,kBAAC,IAAMrE,SAAQ,MACpB+D,EAAEM,aAOjCpO,EAAMwJ,aAAe0D,IAAgBlN,EAAMyN,UAAYL,GACrD,yBAAKhU,MAAO,CAAE8E,SAAU,WAAY0Q,IAAK,IAAKrC,MAAO,MACjD,kBAACvB,EAAA,EAAO,CACJ7N,MAAOjE,YAAU,gBAEjB,kBAAC,IAAM6Q,SAAQ,KACX,kBAAC8E,EAAA,EAAU,CACPrR,QAAS,SAAChD,GACDwF,EAAMwJ,aACP2D,GAAY,KAGpB,kBAAC2B,EAAA,EAAI,CACDvR,KAAM,OACNF,MAAOvB,YAAU,UACjBwB,KAAM,2B,iCCpI9C,8CAQMyR,EAAoBjC,aAAW,SAACpC,GAAK,MAAM,CAC7CsE,KAAM,CACF9Q,SAAU,YAEdsO,OAAQ,CACJnP,MAAOqN,EAAMuE,QAAQC,KAA4B,UAAvBxE,EAAMuE,QAAQ3I,KAAmB,IAAM,KACjEpI,SAAU,WACViR,KAAM,GAEVP,IAAK,CACDvR,MAAOvB,YAAU,oBACjBsT,kBAAmB,QACnBlR,SAAU,WACViR,KAAM,GAEVE,OAAQ,CACJC,cAAe,aAoCRC,IAhCf,SAAkCvP,GAC9B,IAAMgG,EAAU+I,IAEhB,OACI,yBAAK/H,UAAWhB,EAAQgJ,KACpB5V,MAAO,CACH2D,MAAOiD,EAAMzC,KAAOyC,EAAMzC,KAAO,OACjC8K,OAAQrI,EAAMzC,KAAOyC,EAAMzC,KAAO,SAEtC,kBAAC,IAAgB,eACboB,QAAQ,cACRqI,UAAWhB,EAAQwG,OACnBjP,KAAMyC,EAAMzC,KAAOyC,EAAMzC,KAAO,GAChCiS,UAAW,GACPxP,EAAK,CACTb,MAAO,OAEX,kBAAC,IAAgB,eACbR,QAAQ,gBACR8Q,eAAa,EACbzI,UAAWhB,EAAQ4I,IACnB5I,QAAS,CACLqJ,OAAQrJ,EAAQqJ,QAEpB9R,KAAMyC,EAAMzC,KAAOyC,EAAMzC,KAAO,GAChCiS,UAAW,GACPxP,O,oWCrDpB,kmGAAAxH,GAAA,wBAAAA,EAAA,sBAAAA,GAAA,iBAAAA,GAAA,ssDAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,4bAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,yhBAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,qGAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,sQAee,SAASkX,EAAe1P,GACrC,MAA8BgN,IAAMC,WAAS3T,IAAWC,WAAWE,QAAQkW,SAAuB,mBAA3FA,EAAO,KACd,GAD0B,KACI3C,IAAMC,UAAS,IAAM,mBAA5C2C,EAAO,KAAEC,EAAU,KAC1B,EAA0B7C,IAAMC,UAAS,GAAM,mBAAxC6C,EAAK,KAAEC,EAAQ,KACtB,EAA8B/C,IAAMC,UAAS,GAAK,mBAA3C+C,EAAO,KAAEC,EAAU,KAE1BjD,IAAMO,WAAU,WACdK,YAAW,WACTqC,GAAW,KACV,OACF,CAACL,IAEJ,IAAMM,EAAa,uCAAG,oFACpBD,GAAW,GACXF,GAAS,GACLJ,EAAU,CACZQ,YAAY,GAAD,OAAKpM,MAASqM,KAAK,MAC9BR,QAAS,oGACTE,MAAO,qGAEUxW,IAAWC,WAAWiS,UAAjCgD,OACDC,KAAK,OAAQ,CAClB5J,OAAQ,OACRwL,OAAQ,OACRpF,OAAQ,WACP,CACDqF,QAAS/T,KAAKC,UAAUmT,KACxB,2CACH,kBAhBkB,mCAkBnB,OAAIG,EACM,kBAAC,IAAM/F,SAAQ,MAGvB,yBAAK1C,GAAE,yBAGL,kBAACkJ,EAAA,EACC,CACAnX,MAAO,CACLoX,OAAQ,IACRC,eAAgB,uBAChB3T,QAAS,OACT4K,WAAY,SACZzK,eAAgB,UAElByT,MAAOf,EAASnS,QAAS,SAAChD,MAG1B,yBACEpB,MAAK,qCACH8E,SAAU,SACPtF,OAAO+X,WAAa,IAAM,CAC3B/B,IAAK,GACLO,KAAM,GACN5C,MAAO,GACPC,OAAQ,IACN,CACFoC,IAAK,GACLO,KAAM,EACN5C,MAAO,EACPC,OAAQ,IAEP5T,OAAO+X,WAAa,IAAM,CAC3BH,OAAQ,GACN,CACFA,OAAQ,MACT,IACDzF,UAAW,mCACX/C,aAAc,OACd0E,SAAU,SACVxK,gBAAiB,aAGnB,yBAAK9I,MAAO,CACV8E,SAAU,WACV0Q,IAAK,EACLO,KAAM,EACN5C,MAAO,EACPlE,OAAQ,GACRuI,WAAY9U,YAAU,oBACtBgB,QAAS,OACT4K,WAAY,SAEZzK,eAAgB,SAChBI,MAAOvB,YAAU,SACjBiG,WAAY,SAEX7I,YAAU,kCAEb,yBAAKE,MAAO,CACV8E,SAAU,WACV0Q,IAAK,GACLO,KAAM,EACN5C,MAAO,EACPC,OAAQ,EACR1P,QAAS,OACT4K,WAAY,SACZzK,eAAgB,WAEd2S,EAoBA,4BACEvI,GAAG,QACHjO,MAAO,CACL8E,SAAU,WACV0Q,IAAK,EACLO,KAAM,EACN5C,MAAO,EACPC,OAAQ,GACRzP,MAAO,OACPsL,OAAQ,qBAEVtL,MAAO,OACPsL,OAAQ,OACRe,IAAI,iEAhCN,4BACE/B,GAAG,SACHjO,MAAO,CACL8E,SAAU,WACV0Q,IAAK,EACLO,KAAM,EACN5C,MAAO,EACPC,OAAQ,GACRzP,MAAO,OACPsL,OAAQ,qBAEVtL,MAAO,OACPsL,OAAQ,OACRwI,SAAU,WACR1W,QAAQC,IAAI,WAEdgP,IAAI,uEAoBV,yBACEhQ,MAAO,CACL8E,SAAU,WACVsO,OAAQ,EACR2C,KAAM,EACN5C,MAAO,EACPlE,OAAQ,GACRvL,QAAS,OACTG,eAAgB,WAGlB,yBACE7D,MAAO,CACL0D,QAAS,OACT4K,WAAY,SACZzK,eAAgB,gBAChBU,WAAY,KAGd,kBAAC,IAAY,CACX0J,GAAE,sBACFlK,MAAOjE,YAAW0W,EAAO,kCAAwC,KACjExS,KAAOwS,EAAgD,KAAtC1W,YAAU,oBAAqB,KAChDmE,MAAQuS,EAA8B,QAApB9T,YAAU,QAC5BwB,KAAM,WACNE,QAAUoS,EAEN,KAFgB,WAClBC,GAAW,IAEbtS,KAAM,SAGPqS,EACC1W,YAAU,mBAAoB,KAC5B,kBAAC,IAAM6Q,SAAQ,OAGpB6F,IAAYI,EACX,yBACE5W,MAAO,CACL0D,QAAS,OACT4K,WAAY,SACZzK,eAAgB,kBAGlB,kBAAC,IAAY,CACXoK,GAAE,0BACFlK,MAAOjE,YAAU,iCAAkC,KACnDkE,KAAMlE,YAAU,iCAAkC,KAClDmE,MAAOvB,YAAU,QACjBwB,KAAM,WACNE,QAAS,WACP0S,KAEF3S,KAAM,UAGR,kBAAC,IAAMwM,SAAQ,U,iCChN/B,kmGAAAvR,GAAA,wBAAAA,EAAA,sBAAAA,GAAA,iBAAAA,GAAA,ssDAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,4bAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,yhBAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,qGAAAA,EAAA,yBAAAA,GAAA,IAAAA,EAAA,uBAAAA,GAAA,sQAwLA,IAOeiN,eAPS,SAACC,GAAK,MAAM,CAClCjM,QAASiM,EAAMjM,YAGU,SAAAkM,GAAQ,OACjCC,YAAmBC,EAAcF,KAEpBF,EA9Kf,SAA4BzF,GAC1B,IAAQvG,EAAYH,IAAWC,WAAvBE,QAER,EAA8BuT,IAAMC,UAAS,GAAK,mBAAlCgD,GAAF,KAAY,MACpBa,EAAW9D,IAAM+D,SAQvB,GANA/D,IAAMO,WAAU,WACd,OAAO,eAGN,IAEC9T,KAAaA,EAAQhB,SAAYgB,EAAQhB,UAAYgB,EAAQhB,QAAQuY,oBACvE,OAAQ,kBAAC,IAAMjH,SAAQ,MAGzB,IAAMkH,EAAK,uCAAG,oFACZhB,GAAW,GACPN,EAAU,CACZQ,YAAY,GAAD,OAAKpM,MAASqM,KAAK,MAC9BE,QAAS,cAEQhX,IAAWC,WAAWiS,UAAjCgD,OACDC,KAAK,OAAQ,CAClB5J,OAAQ,UACRwL,OAAQ,OACRpF,OAAQ,aACP,CACDqF,QAAS/T,KAAKC,UAAUmT,KACxB,2CACH,kBAdU,mCAwBX,OACE,yBAAKtI,GAAE,sBAGL,kBAACkJ,EAAA,EAAQ,CACPnX,MAAO,CACLoX,OAAQ,IACRC,eAAgB,uBAChB3T,QAAS,OACT4K,WAAY,SACZzK,eAAgB,UAElByT,MAAM,GAEN,yBACEtX,MAAK,qCACH8E,SAAU,SACPtF,OAAO+X,WAAa,IAAM,CAC3B/B,IAAK,GACLO,KAAM,GACN5C,MAAO,GACPC,OAAQ,IACN,CACFoC,IAAK,GACLO,KAAM,EACN5C,MAAO,EACPC,OAAQ,IAEP5T,OAAO+X,WAAa,IAAM,CAC3BH,OAAQ,GACN,CACFA,OAAQ,MACT,IACDzF,UAAW,mCACX/C,aAAc,OACd0E,SAAU,SACVxK,gBAAiB,aAGnB,yBAAK9I,MAAO,CACV8E,SAAU,WACV0Q,IAAK,EACLO,KAAM,EACN5C,MAAO,EACPlE,OAAQ,GACRuI,WAAY9U,YAAU,oBACtBgB,QAAS,OACT4K,WAAY,SACZzK,eAAgB,SAChBI,MAAOvB,YAAU,SACjBiG,WAAY,SAEX7I,YAAU,0BAEb,yBAAKE,MAAO,CACV8E,SAAU,WACV0Q,IAAK,GACLO,KAAM,EACN5C,MAAO,EACPC,OAAQ,EACR1P,QAAS,OACT4K,WAAY,SACZzK,eAAgB,WAEhB,4BACEoK,GAAG,YACHR,IAAKiK,EACLI,OAAQ,WA1ElB/W,QAAQC,IAAI0W,EAASK,QAASL,EAASK,QAAQC,cAAcxY,QA4EjDuB,QAAQC,IAAI,cAEdhB,MAAO,CACL8E,SAAU,WACV0Q,IAAK,EACLO,KAAM,EACN5C,MAAO,EACPC,OAAQ,GACRzP,MAAO,OACPsL,OAAQ,qBAEVtL,MAAO,OACPsL,OAAQ,OACRe,IAAI,oGAGR,yBACEhQ,MAAO,CACL8E,SAAU,WACVsO,OAAQ,EACR2C,KAAM,EACN5C,MAAO,EACPlE,OAAQ,GACRvL,QAAS,OACTG,eAAgB,WAGlB,yBACE7D,MAAO,CACL0D,QAAS,OACT4K,WAAY,SACZzK,eAAgB,gBAChBU,WAAY,KAGd,kBAAC,IAAY,CACX0J,GAAE,yBACFlK,MAAOjE,YAAU,oBAAqB,KACtCkE,KAAMlE,YAAU,oBAAqB,KACrCmE,MAAOvB,YAAU,QACjBwB,KAAM,WACNE,QAAS,WACPyT,KAEF1T,KAAM,iB,gCC7HP8T,EA1CI,kDACf,WAAYrR,GAAQ,IAAD,EAMb,OANa,qBACf,cAAMA,IACDsR,MAAQ,CACTC,UAAU,EACVxS,MAAO,KACPyS,UAAW,MACb,EAML,OALA,8CAOD,SAAkBzS,EAAOyS,GAGrBC,KAAKC,SAAS,CACV3S,MAAOA,EACPyS,UAAWA,IAEfrX,QAAQC,IAAIxB,OAAOC,SAASC,SAASC,QAAQ,gBAAiBH,OAAOC,SAASC,SAASC,QAAQ,qBACrC,IAAtDH,OAAOC,SAASC,SAASC,QAAQ,kBAC2B,IAAzDH,OAAOC,SAASC,SAASC,QAAQ,oBAEpCoB,QAAQC,IAAI2E,EAAOyS,KAC1B,oBAED,WACI,OAAIC,KAAKH,MAAMC,SAEP,6BACKrY,YAAU,6CAKhBuY,KAAKzR,MAAMkK,YACrB,uCA7BD,SAAgCnL,GAE5B,MAAO,CAAEwS,UAAU,OACtB,EAbc,CAASvE,IAAM/C,W,0ECquBnB0H,EAhtBK,CAClBC,OAAQ,CACNC,UAAW,OACXhV,SAAU,OACVqF,gBAAiB4P,IAAU,GAC3BzU,MAAO0U,IACPhH,UACE,oBACAiH,YAASF,IAAU,IACnB,gCACAE,YAASF,IAAU,IACnB,4BACAE,YAASF,IAAU,IACnB,UACF/J,OAAQ,OACRC,aAAc,MACd9J,SAAU,WACVyJ,QAAS,YACT6C,OAAQ,eACRJ,SAAU,OACVrI,WAAY,MACZkQ,cAAe,YACfC,cAAe,IACfC,WAAY,wBACZC,WACE,iGACFC,WAAY,aACZC,UAAW,SACXtE,WAAY,SACZuE,cAAe,SACfC,YAAa,eACbnI,OAAQ,UACR,kBAAmB,CACjBhN,MAAO0U,IACP7P,gBAAiB4P,IAAU,GAC3B/G,UACE,0BACAiH,YAASF,IAAU,IACnB,gCACAE,YAASS,KACT,iCACAT,YAASF,IAAU,IACnB,UAEJ,gDAAiD,CAC/C5T,SAAU,WACVpB,QAAS,eACT8R,IAAK,IACL5R,UAAW,OACXe,aAAc,OACdqM,SAAU,SACVuC,YAAa,MACb4F,cAAe,UAEjB,QAAS,CACPrU,SAAU,WACVpB,QAAS,eACT8R,IAAK,IACL7R,MAAO,OACPsL,OAAQ,OACRsE,YAAa,MACb4F,cAAe,UAEjB,aAAc,CACZ,gDAAiD,CAC/CvV,UAAW,MACXkB,SAAU,WACVnB,MAAO,OACP2V,UAAW,OACXvD,KAAM,MACNP,IAAK,MACLvG,OAAQ,OACRgK,WAAY,OACZjI,SAAU,UAIhBuI,UAAW,CACT5V,MAAO,QAET6V,aAAc,CACZ1Q,gBAAiBpG,YAAU,SAC3BiP,UACE,eACAjP,YAAU,QAAS,KACnB,oBACAA,YAAU,QAAS,IACnB,sBACAA,YAAU,QAAS,KACrB,kBAAmB,CACjBoG,gBAAiBpG,YAAU,SAC3BiP,UACE,qBACAjP,YAAU,QAAS,KACnB,oBACAA,YAAU,QAAS,KACnB,0BACAA,YAAU,QAAS,MAGzB+W,iBAAkB,CAChB3Q,gBAAiBpG,YAAU,QAC3BiP,UACE,eACAjP,YAAU,OAAQ,KAClB,oBACAA,YAAU,OAAQ,IAClB,sBACAA,YAAU,OAAQ,KACpB,kBAAmB,CACjBoG,gBAAiBpG,YAAU,QAC3BiP,UACE,qBACAjP,YAAU,OAAQ,KAClB,oBACAA,YAAU,OAAQ,KAClB,0BACAA,YAAU,OAAQ,MAGxBgX,mBAAoB,CAClB5Q,gBAAiBpG,YAAU,UAC3BiP,UACE,eACAjP,YAAU,SAAU,KACpB,oBACAA,YAAU,SAAU,IACpB,sBACAA,YAAU,SAAU,KACtB,kBAAmB,CACjBoG,gBAAiBpG,YAAU,UAC3BiP,UACE,qBACAjP,YAAU,SAAU,KACpB,oBACAA,YAAU,SAAU,KACpB,0BACAA,YAAU,SAAU,MAG1BiX,QAAS,CACP7Q,gBAAiB8Q,IAAa,GAC9BjI,UACE,oBACAiH,YAASgB,IAAa,IACtB,gCACAhB,YAASgB,IAAa,IACtB,4BACAhB,YAASgB,IAAa,IACtB,UACF,kBAAmB,CACjB9Q,gBAAiB8Q,IAAa,GAC9BjI,UACE,0BACAiH,YAASgB,IAAa,IACtB,gCACAhB,YAASS,KACT,iCACAT,YAASgB,IAAa,IACtB,WAGNpU,KAAM,CACJsD,gBAAiB+Q,IAAU,GAC3BlI,UACE,oBACAiH,YAASiB,IAAU,IACnB,gCACAjB,YAASiB,IAAU,IACnB,4BACAjB,YAASiB,IAAU,IACnB,UACF,kBAAmB,CACjB/Q,gBAAiB+Q,IAAU,GAC3BlI,UACE,0BACAiH,YAASiB,IAAU,IACnB,gCACAjB,YAASS,KACT,iCACAT,YAASiB,IAAU,IACnB,WAGNpU,QAAS,CACPqD,gBAAiBgR,IAAa,GAC9BnI,UACE,oBACAiH,YAASkB,IAAa,IACtB,gCACAlB,YAASkB,IAAa,IACtB,4BACAlB,YAASkB,IAAa,IACtB,UACF,kBAAmB,CACjBhR,gBAAiBgR,IAAa,GAC9BnI,UACE,0BACAiH,YAASkB,IAAa,IACtB,gCACAlB,YAASS,KACT,iCACAT,YAASkB,IAAa,IACtB,WAGNC,QAAS,CACPjR,gBAAiBkR,IAAa,GAC9BrI,UACE,oBACAiH,YAASoB,IAAa,IACtB,gCACApB,YAASoB,IAAa,IACtB,4BACApB,YAASoB,IAAa,IACtB,UACF,kBAAmB,CACjBlR,gBAAiBkR,IAAa,GAC9BrI,UACE,0BACAiH,YAASoB,IAAa,IACtB,gCACApB,YAASS,KACT,iCACAT,YAASoB,IAAa,IACtB,WAGNC,OAAQ,CACNnR,gBAAiBoR,IAAY,GAC7BvI,UACE,oBACAiH,YAASsB,IAAY,IACrB,gCACAtB,YAASsB,IAAY,IACrB,4BACAtB,YAASsB,IAAY,IACrB,UACF,kBAAmB,CACjBpR,gBAAiBoR,IAAY,GAC7BvI,UACE,0BACAiH,YAASsB,IAAY,IACrB,gCACAtB,YAASS,KACT,iCACAT,YAASsB,IAAY,IACrB,WAGNC,KAAM,CACJrR,gBAAiBsR,IAAU,GAC3BzI,UACE,oBACAiH,YAASwB,IAAU,IACnB,gCACAxB,YAASwB,IAAU,IACnB,4BACAxB,YAASwB,IAAU,IACnB,UACF,kBAAmB,CACjBtR,gBAAiBsR,IAAU,GAC3BzI,UACE,0BACAiH,YAASwB,IAAU,IACnB,gCACAxB,YAASS,KACT,iCACAT,YAASwB,IAAU,IACnB,WAGNC,MAAO,CACL,oBAAqB,CACnBvR,gBAAiB6P,IACjB1U,MAAOyU,IAAU,KAGrB4B,QAAS,CACPxR,gBAAiByR,IACjBtW,MAAO0U,IACPhH,UACE,oBACAiH,YAAS2B,KACT,gCACA3B,YAAS2B,KACT,4BACA3B,YAAS2B,KACT,UACF,4BAA6B,CAC3BzR,gBAAiByR,IACjBtW,MAAO0U,IACPhH,UACE,0BACAiH,YAAS2B,KACT,gCACA3B,YAASS,KACT,iCACAT,YAAS2B,KACT,WAGNC,SAAU,CACR1R,gBAAiB2R,IACjBxW,MAAO0U,IACPhH,UACE,oBACAiH,YAAS6B,KACT,gCACA7B,YAAS6B,KACT,4BACA7B,YAAS6B,KACT,UACF,kBAAmB,CACjB3R,gBAAiB2R,IACjBxW,MAAO0U,IACPhH,UACE,0BACAiH,YAAS6B,KACT,gCACA7B,YAASS,KACT,iCACAT,YAAS6B,KACT,WAGNC,OAAQ,CACN5R,gBAAiB6R,IACjB1W,MAAO0U,IACPhH,UACE,oBACAiH,YAAS+B,KACT,gCACA/B,YAAS+B,KACT,4BACA/B,YAAS+B,KACT,UACF,kBAAmB,CACjB7R,gBAAiB6R,IACjB1W,MAAO0U,IACPhH,UACE,0BACAiH,YAAS+B,KACT,gCACA/B,YAASS,KACT,iCACAT,YAAS+B,KACT,WAGNC,SAAU,CACR9R,gBAAiB+R,IACjB5W,MAAO0U,IACPhH,UACE,oBACAiH,YAASiC,KACT,gCACAjC,YAASiC,KACT,4BACAjC,YAASiC,KACT,UACF,kBAAmB,CACjB/R,gBAAiB+R,IACjB5W,MAAO0U,IACPhH,UACE,0BACAiH,YAASiC,KACT,gCACAjC,YAASS,KACT,iCACAT,YAASiC,KACT,WAGNC,UAAW,CACThS,gBAAiBiS,IACjB9W,MAAO0U,IACPhH,UACE,oBACAiH,YAASmC,KACT,gCACAnC,YAASmC,KACT,4BACAnC,YAASmC,KACT,UACF,kBAAmB,CACjBjS,gBAAiBiS,IACjB9W,MAAO0U,IACPhH,UACE,0BACAiH,YAASmC,KACT,gCACAnC,YAASS,KACT,iCACAT,YAASmC,KACT,WAGNC,QAAS,CACPlS,gBAAiBmS,IACjBhX,MAAO0U,IACPhH,UACE,oBACAiH,YAASqC,KACT,gCACArC,YAASqC,KACT,4BACArC,YAASqC,KACT,UACF,kBAAmB,CACjBnS,gBAAiBmS,IACjBhX,MAAO0U,IACPhH,UACE,0BACAiH,YAASqC,KACT,gCACArC,YAASS,KACT,iCACAT,YAASqC,KACT,WAGNC,OAAQ,CACNpS,gBAAiBqS,IACjBlX,MAAO0U,IACPhH,UACE,oBACAiH,YAASuC,KACT,gCACAvC,YAASuC,KACT,4BACAvC,YAASuC,KACT,UACF,kBAAmB,CACjBrS,gBAAiBqS,IACjBlX,MAAO0U,IACPhH,UACE,0BACAiH,YAASuC,KACT,gCACAvC,YAASS,KACT,iCACAT,YAASuC,KACT,WAGNC,OAAQ,CACNtS,gBAAiB4P,IAAU,GAC3BzU,MAAO0U,IACPhH,UACE,oBACAiH,YAASF,IAAU,IACnB,gCACAE,YAASF,IAAU,IACnB,4BACAE,YAASF,IAAU,IACnB,UACF,kBAAmB,CACjB5P,gBAAiB4P,IAAU,GAC3BzU,MAAO0U,IACPhH,UACE,0BACAiH,YAASF,IAAU,IACnB,gCACAE,YAASS,KACT,iCACAT,YAASF,IAAU,IACnB,WAGN2C,QAAS,CACPvS,gBAAiBwS,IACjBrX,MAAO0U,IACPhH,UACE,oBACAiH,YAAS0C,KACT,gCACA1C,YAAS0C,KACT,4BACA1C,YAAS0C,KACT,UACF,kBAAmB,C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AMyC,EAAMzC,MAAQ,OACpBC,QAAS,WACDwC,EAAMqO,UACNm/B,GAAY,OAsCxC,IAAMF,GAAW,CACb,OAAU,CACN,cACA,gBACA,oBACA,aACA,qBACA,kBACA,yBACA,cACA,iBACA,oBACA,WACA,uBACA,QACA,YACA,YACA,WACA,YACA,UACA,YACA,SACA,UACA,eACA,MACA,eACA,oBACA,kBACA,kBACA,UACA,eACA,aACA,aACA,iBACA,kBACA,oBACA,sBACA,uBACA,YACA,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,a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","file":"static/js/main.688497b9.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 { db } = reduxStore.getState();\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]\r\n        && data\r\n        && data._parent\r\n        && reduxStore.getState().db.cards[data._parent]\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 mapStateToProps = (store) => {\r\n    return {\r\n        store: {\r\n            cards: store.db.cards,\r\n        }\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)(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 {\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';\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","//@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","//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            console.log(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 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={reduxStore.getState().db.users[selectedUserId] && reduxStore.getState().db.users[selectedUserId].displayName ? reduxStore.getState().db.users[selectedUserId].displayName : reduxStore.getState().db.users[selectedUserId].name || \"\"}\n                                >\n                                    <div\n                                        style={{ display: \"flex\", alignItems: \"center\" }}\n                                    >\n                                        <Avatar\n                                            alt={reduxStore.getState().db.users[selectedUserId].name}\n                                            src={reduxStore.getState().db.users[selectedUserId].image || null}\n                                            style={{ width: props && props.avatarSize ? props && props.avatarSize : 'none', height: props && props.avatarSize ? props.avatarSize : 'none' }}>\n                                            {reduxStore.getState().db.users[selectedUserId].name.substr(0, 1)}\n                                        </Avatar>\n                                        {!props.multiple &&\n                                            <span style={{ marginLeft: 15 }}>\n                                                {reduxStore.getState().db.users[selectedUserId].displayName ? reduxStore.getState().db.users[selectedUserId].displayName : reduxStore.getState().db.users[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                console.log(card)\r\n                if (!parentCard.removeCreatorUser && card._users) console.log(\"ok\")\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, options = {}) => {\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\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                        (\r\n                            cards[cid]._parent === column\r\n                            && (\r\n                                (\r\n                                    !options.deleted\r\n                                    && !cards[cid].deleted\r\n                                )\r\n                                ||\r\n                                (\r\n                                    options.deleted\r\n                                )\r\n                            )\r\n                        )\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                            if (cards[cid].deleted)\r\n                                console.log(cards[cid])\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 React from \"react\"\r\nimport PropTypes from \"prop-types\"\r\nimport AutoNumeric from \"autonumeric\"\r\nimport { withStyles } from \"@material-ui/styles\"\r\nimport { TextField, InputAdornment } from \"@material-ui/core\"\r\n\r\n// const styles = theme => ({\r\n//     textField: props => ({\r\n//         textAlign: props.textAlign || \"right\",\r\n//     }),\r\n// })\r\n\r\n/**\r\n * CurrencyTextField is a [react](https://reactjs.org/) component with automated currency and number format, and with [Material-ui](https://material-ui.com/) look and feel.\r\n *\r\n * CurrencyTextField is a wrapper component for <a href=\"https://github.com/autoNumeric/autoNumeric\">autonumeric</a> and based on <a href=\"https://github.com/mkg0/react-numeric\">react-numeric</a>.\r\n *\r\n * Main features:\r\n * * Adds thousands separator automatically.\r\n * * Adds automatically the decimals on blur.\r\n * * Smart input. User can only type the accepted characters depending on the current value.\r\n * * Lots of config options...\r\n * * It accepts all the `props` and `classes` of Material-Ui <a href=\"https://material-ui.com/api/text-field/#textfield-api\">TextField API</a> (Ex: classes, label, helperText, variant).\r\n * * And also all the `options` from <a href=\"http://autonumeric.org/guide\">AutoNumeric</a>\r\n */\r\n\r\nclass CurrencyTextField extends React.Component {\r\n    constructor(props) {\r\n        super(props)\r\n        this.getValue = this.getValue.bind(this)\r\n        this.callEventHandler = this.callEventHandler.bind(this)\r\n    }\r\n\r\n    componentDidMount() {\r\n        const { currencySymbol, ...others } = this.props\r\n\r\n        this.autonumeric = new AutoNumeric(this.input, this.props.value, {\r\n            ...this.props.preDefined,\r\n            ...others,\r\n            digitGroupSeparator: '.',\r\n            decimalCharacter: ',',\r\n            decimalCharacterAlternative: '.',\r\n            onChange: undefined,\r\n            onFocus: undefined,\r\n            onBlur: undefined,\r\n            onKeyPress: undefined,\r\n            onKeyUp: undefined,\r\n            onKeyDown: undefined,\r\n            watchExternalChanges: false,\r\n        })\r\n    }\r\n    componentWillUnmount() {\r\n        this.autonumeric.remove()\r\n    }\r\n\r\n    componentWillReceiveProps(newProps) {\r\n        const isValueChanged =\r\n            this.props.value !== newProps.value && this.getValue() !== newProps.value\r\n\r\n        if (isValueChanged) {\r\n            this.autonumeric.set(newProps.value)\r\n        }\r\n    }\r\n\r\n    getValue() {\r\n        if (!this.autonumeric) return\r\n        const valueMapper = {\r\n            string: numeric => numeric.getNumericString(),\r\n            number: numeric => numeric.getNumber(),\r\n        }\r\n        let result = valueMapper[this.props.outputFormat](this.autonumeric)\r\n\r\n        return result\r\n    }\r\n    callEventHandler(event, eventName) {\r\n        if (!this.props[eventName]) return\r\n        this.props[eventName](event, this.getValue())\r\n    }\r\n    render() {\r\n        const {\r\n            classes,\r\n            currencySymbol,\r\n            inputProps,\r\n            InputProps,\r\n            ...others\r\n        } = this.props\r\n\r\n        const otherProps = {}\r\n            ;[\r\n                \"id\",\r\n                \"label\",\r\n                \"className\",\r\n                \"autoFocus\",\r\n                \"variant\",\r\n                \"style\",\r\n                \"error\",\r\n                \"disabled\",\r\n                \"type\",\r\n                \"name\",\r\n                \"defaultValue\",\r\n                \"tabIndex\",\r\n                \"fullWidth\",\r\n                \"rows\",\r\n                \"rowsMax\",\r\n                \"select\",\r\n                \"required\",\r\n                \"helperText\",\r\n                \"unselectable\",\r\n                \"margin\",\r\n                \"SelectProps\",\r\n                \"multiline\",\r\n                \"size\",\r\n                \"FormHelperTextProps\",\r\n                \"placeholder\",\r\n            ].forEach(prop => (otherProps[prop] = this.props[prop]))\r\n\r\n        return (\r\n            <TextField\r\n                inputRef={ref => (this.input = ref)}\r\n                onChange={e => this.callEventHandler(e, \"onChange\")}\r\n                onFocus={e => this.callEventHandler(e, \"onFocus\")}\r\n                onBlur={e => this.callEventHandler(e, \"onBlur\")}\r\n                onKeyPress={e => this.callEventHandler(e, \"onKeyPress\")}\r\n                onKeyUp={e => this.callEventHandler(e, \"onKeyUp\")}\r\n                onKeyDown={e => this.callEventHandler(e, \"onKeyDown\")}\r\n                InputProps={{\r\n                    startAdornment: (\r\n                        <InputAdornment position=\"start\">{currencySymbol}</InputAdornment>\r\n                    ),\r\n                    ...InputProps,\r\n                }}\r\n                inputProps={{\r\n                    // className: classes.textField,\r\n                    ...inputProps,\r\n                }}\r\n                {...otherProps}\r\n            />\r\n        )\r\n    }\r\n}\r\n\r\nCurrencyTextField.propTypes = {\r\n    type: PropTypes.oneOf([\"text\", \"tel\", \"hidden\"]),\r\n    /** The variant to use. */\r\n    variant: PropTypes.string,\r\n    id: PropTypes.string,\r\n    /** The CSS class name of the wrapper element. */\r\n    className: PropTypes.string,\r\n    /** Inline styling for element */\r\n    style: PropTypes.object,\r\n    /** If true, the input element will be disabled. */\r\n    disabled: PropTypes.bool,\r\n    //\r\n    comma: PropTypes.bool,\r\n    /** The label content. */\r\n    label: PropTypes.string,\r\n    /** Align the numbers in the textField.\r\n     * If you pass the `inputProps` from TextFieldAPI text align won't work.\r\n     * then, you have handle it by className with your own class inside inputProps.\r\n     */\r\n    textAlign: PropTypes.oneOf([\"right\", \"left\", \"center\"]),\r\n    /** Tab index for the element */\r\n    tabIndex: PropTypes.number,\r\n    /** If true, the input element will be focused during the first mount. */\r\n    autoFocus: PropTypes.bool,\r\n    /** The short hint displayed in the input before the user enters a value. */\r\n    placeholder: PropTypes.string,\r\n    /** value to be enter and display in input */\r\n    value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\r\n    /** Callback fired when the value is changed. */\r\n    onChange: PropTypes.func,\r\n    /** Callback fired when focused on element. */\r\n    onFocus: PropTypes.func,\r\n    /** Callback fired on blur. */\r\n    onBlur: PropTypes.func,\r\n    /** Callback fired on key press. */\r\n    onKeyPress: PropTypes.func,\r\n    /** Callback fired on key press. */\r\n    onKeyUp: PropTypes.func,\r\n    /** Callback fired on key press. */\r\n    onKeyDown: PropTypes.func,\r\n    /** Defines the currency symbol string. */\r\n    currencySymbol: PropTypes.string,\r\n    /** Defines what decimal separator character is used. */\r\n    decimalCharacter: PropTypes.string,\r\n    /** Allow to declare an alternative decimal separator which is automatically replaced by `decimalCharacter` when typed. */\r\n    decimalCharacterAlternative: PropTypes.string,\r\n    /** Defines the default number of decimal places to show on the formatted value. */\r\n    decimalPlaces: PropTypes.number,\r\n    /** Defines how many decimal places should be visible when the element is unfocused null. */\r\n    decimalPlacesShownOnBlur: PropTypes.number,\r\n    /** Defines how many decimal places should be visible when the element has the focus. */\r\n    decimalPlacesShownOnFocus: PropTypes.number,\r\n    /** Defines the thousand grouping separator character */\r\n    digitGroupSeparator: PropTypes.string,\r\n    /** Controls the leading zero behavior   */\r\n    leadingZero: PropTypes.oneOf([\"allow\", \"deny\", \"keep\"]),\r\n    /** maximum value that can be enter */\r\n    maximumValue: PropTypes.string,\r\n    /** minimum value that can be enter */\r\n    minimumValue: PropTypes.string,\r\n    /** placement of the negitive and possitive sign symbols */\r\n    negativePositiveSignPlacement: PropTypes.oneOf([\"l\", \"r\", \"p\", \"s\"]),\r\n    /** Defines the negative sign symbol to use   */\r\n    negativeSignCharacter: PropTypes.string,\r\n    /** how the value should be formatted,before storing it */\r\n    outputFormat: PropTypes.oneOf([\"string\", \"number\"]),\r\n    /** Defines if the element value should be selected on focus. */\r\n    selectOnFocus: PropTypes.bool,\r\n    /** Defines the positive sign symbol to use. */\r\n    positiveSignCharacter: PropTypes.string,\r\n    /** Defines if the element should be set as read only on initialization. */\r\n    readOnly: PropTypes.bool,\r\n    /** predefined objects are available in <a href=\"https://www.nodenpm.com/autonumeric/4.5.1/detail.html#predefined-options\">AutoNumeric</a>*/\r\n    preDefined: PropTypes.object,\r\n}\r\n\r\nCurrencyTextField.defaultProps = {\r\n    type: \"text\",\r\n    variant: \"standard\",\r\n    currencySymbol: \"$\",\r\n    outputFormat: \"number\",\r\n    textAlign: \"right\",\r\n    maximumValue: \"10000000000000\",\r\n    minimumValue: \"-10000000000000\",\r\n}\r\n// export default withStyles(styles)(CurrencyTextField)\r\nexport default CurrencyTextField\r\n\r\nexport const predefinedOptions = AutoNumeric.getPredefinedOptions()\r\n","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\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    data.users.map((uid, i) => {\r\n        let userData = {\r\n            ...i === 0 ? {\r\n                access: 5,\r\n                isResponsible: true,\r\n                ...parentData?.showInPanel ? { 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                ...parentData.showInPanel ? { channel: true } : {},\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                    ...parentData.showInPanel ? {\r\n                        _createdBy: {\r\n                            name: reduxStore.getState().db.users[session._id].name,\r\n                            image: reduxStore.getState().db.users[session._id].image,\r\n                            _id: session._id,\r\n                            channel: true\r\n                        }\r\n                    } : {},\r\n                    ...parentData._planId ? { _planId: parentData._planId } : {},\r\n                    ...parentData.type === \"plan\" ? { _planId: parentData._id } : {},\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\nimport CustomButton from \"components/Buttons/custom\"\r\nimport Icon from \"components/Icon\"\r\nimport SelectUsers from \"components/User/select\"\r\nimport TextField from \"components/TextField\"\r\nimport TextareaAutosize from 'react-textarea-autosize';\r\nimport CurrencyTextField from 'components/TextField/currency'\r\n\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\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    const [addValue, setAddValue] = React.useState(false);\r\n    const [addDescription, setAddDescription] = React.useState(false);\r\n\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\r\n    const inputRef = React.createRef()\r\n    const descriptionRef = React.createRef()\r\n    const valueRef = 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\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                ...descriptionRef && descriptionRef.current && descriptionRef.current.value ? { description: descriptionRef.current.value } : {},\r\n                ...valueRef && valueRef.current && valueRef.current.getValue() ? { value: valueRef.current.getValue() } : {},\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                {/* {console.log(parentCard)} */}\r\n                {(\r\n                    parentCard.requireDescription\r\n                    || addDescription\r\n                ) &&\r\n                    <TextField\r\n                        inputRef={descriptionRef}\r\n                        label={translate(\"$__description\", 1)}\r\n                        variant={customApp(\"fieldVariant\")}\r\n                        name=\"description\"\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=\"description\" color={\"lightgray\"} />\r\n                                </InputAdornment>\r\n                            ),\r\n                        }}\r\n                        placeholder={translate(\"$__description\", 1)}\r\n                    />\r\n                }\r\n                {(\r\n                    parentCard.requireValue\r\n                    || addValue\r\n                ) &&\r\n                    <CurrencyTextField\r\n                        label={translate(\"$__value\", 1)}\r\n                        variant=\"standard\"\r\n                        currencySymbol=\"$\"\r\n                        outputFormat=\"string\"\r\n                        inputRef={valueRef}\r\n                        ref={valueRef}\r\n                    />\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={{\r\n                // display: 'flex'\r\n            }}>\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 => {\r\n            // console.log(db.cards[card])\r\n            return card\r\n        })\r\n    console.log(moment(moment().format(\"YYYY-MM-DD 00:00:01\")).unix(\"x\"))\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//@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","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 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\";\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 && (\n        data.url.indexOf(\".youtube.com/watch?\") > -1\n        || data.url.indexOf(\"youtu.be\") > -1\n    )) {\n        let ybQuery = data.url.indexOf(\".youtube.com/watch?\") > -1 ? data.url.split(\"?\")[1].split(\"v=\")[1].split(\"&\")[0] : 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    if (data && data.url && (\n        data.url.indexOf(\"https://vimeo.com\") > -1\n    )) {\n        let vmQuery = data.url.replace(\"https://\", \"\").split(\"/\")[1]\n        if (vmQuery) {\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://player.vimeo.com/video/${vmQuery}`}\n                    title=\"Vimeo video player\"\n                    frameBorder=\"0\"\n                    allow=\"autoplay; fullscreen; picture-in-picture\"\n                    allowfullscreen\n                >\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                            (hasYoutube || (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))","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","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","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 QuickUsers_List from \"components/User/avatarList\"\nimport Timer from \"components/Timer/timer\"\n\n//@MATERIAL\nimport Avatar from \"@material-ui/core/Avatar\"\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    cardStatus,\n    deleteCard,\n    getCardColor,\n    getUserAccess,\n    kpiTimerStart,\n    restoreCard,\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 [combine, setCombine] = React.useState(false)\n\n    const cardRef = 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        // if (data.name === \"Área X\")\n        //     console.log('AAAAAAAAAAAAAAAAAAA')\n        // eslint-disable-next-line\n    }, [cardRef, isExpanded, props.manualExpanded, combine]);\n\n    // useEffect(() => {\n    //     // if (data.name === \"Área X\")\n    //     //     console.log('BBBBBBBBBBBBBBBBBBBBBBBBBBBB')\n    // }, [])\n\n    // useEffect(() => {\n    //     if (!cardRef.current) return; // wait for the elementRef to be available\n    //     if (props.onResize) {\n    //         const resizeObserver = new ResizeObserver(() => {\n    //             let newSize = cardRef.current.clientHeight\n    //             if (props.separator)\n    //                 newSize = newSize + 55\n    //             props.onResize(newSize, isExpanded)\n    //         });\n    //         resizeObserver.observe(cardRef.current);\n    //         return () => resizeObserver.disconnect(); // clean up \n    //     }\n    // }, []);\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            isMounted = false\n        }\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    //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\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\n\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                                        props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\n                                            ...reduxStore.getState().control,\n                                            toCopyMove: data._id,\n                                        })\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                {data && (data._cardCode || data.value) ?\n                    <div style={{\n                        width: \"100%\",\n                        clear: \"both\",\n                        display: \"flex\",\n                        alignContent: \"center\",\n                        justifyContent: \"space-between\"\n                    }}>\n                        {data && data._cardCode ?\n                            <div\n                                style={{\n                                    paddingLeft: 36,\n                                    fontSize: 11,\n                                    marginTop: -9,\n                                    color: \"gray\",\n                                    display: \"flex\",\n                                    alignItems: \"center\",\n                                    whiteSpace: \"nowrap\"\n                                }}>\n                                # {data._cardCode}\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                        {data && data.value ?\n                            <div\n                                style={{\n                                    width: \"100%\",\n                                    textAlign: \"right\",\n                                    fontSize: 11,\n                                    marginTop: -9,\n                                    color: \"black\",\n                                }}>\n                                $ {data.value}\n                            </div>\n                            : <React.Fragment></React.Fragment>\n                        }\n                    </div>\n                    : <React.Fragment></React.Fragment>\n                }\n                {(((data.type === 'insight' || data.type === 'link') && data._createdBy && db.users[data._createdBy._id])\n                    ||\n                    (data._createdBy && data._createdBy.channel && data._createdBy._id && data._createdBy._id !== session._id)\n                ) &&\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={data._createdBy.name || db.users[data._createdBy._id].name}\n                            >\n                                <Avatar\n                                    alt={data._createdBy.name || db.users[data._createdBy._id].name}\n                                    src={db.users[data._createdBy._id]?.image || null}\n                                    size=\"12px\"\n                                    style={{ width: 16, height: 16 }}\n                                >\n                                    {data._createdBy?.name?.substr(0, 1) || db.users[data._createdBy._id].name.substr(0, 1)}\n                                </Avatar>\n                            </Tooltip>\n                        </div>\n                        <div style={{\n                            position: 'relative',\n                            float: 'right',\n                            width: '100%',\n                            paddingLeft: '7px',\n                            display: \"flex\",\n                            alignItems: \"center\",\n                            justifyContent: \"space-between\",\n                            fontSize: '12px'\n                        }}>\n                            <div style={{\n                                color: customApp('menu'),\n                                fontWeight: 'bold',\n                            }}>\n                                <span style={{ fontSize: 10, color: \"gray\" }}>{translate(\"$__createdBy\", '*')}</span>: {data._createdBy?.name?.split(' ')[0] || db.users[data._createdBy._id].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                }\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                {(\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            <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 Approve from \"components/Card/approval\"\nimport Autocomplete from \"components/AutoComplete\"\nimport Card from \"components/Card\"\nimport CardTags from \"components/Tags/Card\"\nimport ConnectedIn from \"components/ConnectedIn\"\nimport CurrencyTextField from 'components/TextField/currency'\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                        {\n                            (data.type === \"task\"\n                                || data.type === \"iniciative\"\n                            )\n                                ?\n\n                                <CurrencyTextField\n                                    label={translate(\"$__price\", 1)}\n                                    variant=\"standard\"\n                                    currencySymbol=\"$\"\n                                    outputFormat=\"string\"\n                                    style={{ width: \"100%\", marginBottom: 10 }}\n                                    value={data && data.value ? data.value : \"\"}\n                                    onChange={(event, value) =>\n                                        changeData({\n                                            name: \"value\",\n                                            value: value\n                                        })\n                                    }\n\n                                />\n                                : <React.Fragment></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                                    {\n                                        data\n                                            && data.type\n                                            &&\n                                            (\n                                                data.type === \"step\"\n                                                || data.type === \"objective\"\n                                                || data.type.indexOf(\"guideline\") > -1\n                                                || data.type === \"goal\"\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                                            : <React.Fragment></React.Fragment>\n                                    }\n\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","//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)","//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\nfunction Component(props) {\n    const { classes, sideModule } = props;\n    const { db, session } = reduxStore.getState();\n    const { planType } = db;\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                        <div className={classes.switch}>\n                            <Switch\n                                checked={\n                                    data.showSumValues\n                                        ? true\n                                        : false\n                                }\n                                onChange={(d) => {\n                                    changeData({\n                                        name: \"showSumValues\",\n                                        value: data.showSumValues ? false : true\n                                    })\n                                }}\n                                name=\"showSumValues\"\n                                inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                            />\n                            {translate(\"$__showSumValues\", 1)}\n                        </div>\n                        <div className={classes.switch}>\n                            <Switch\n                                checked={\n                                    data.requireValue\n                                        ? true\n                                        : false\n                                }\n                                onChange={(d) => {\n                                    changeData({\n                                        name: \"requireValue\",\n                                        value: data.requireValue ? false : true\n                                    })\n                                }}\n                                name=\"requireValue\"\n                                inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                            />\n                            {translate(\"$__requireValue\", 1)}\n                        </div>\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                            {(data.automationUsers && (\n                                data.automationUsers === \"remove\"\n                                || data.automationUsers === \"replace\"\n                            )) ?\n                                <div className={classes.switch}>\n                                    <Switch\n                                        checked={\n                                            data.removeCreatorUser\n                                                ? true\n                                                : false\n                                        }\n                                        onChange={(d) => {\n                                            changeData({\n                                                name: \"removeCreatorUser\",\n                                                value: data.removeCreatorUser ? false : true\n                                            })\n                                        }}\n                                        name=\"removeCreatorUser\"\n                                        inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                    />\n                                    {translate(\"$__keepUserWhoCreatedActivity\", 1)}\n                                </div>\n                                : <React.Fragment></React.Fragment>\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                                    <div className={classes.switch}>\n                                        <Switch\n                                            checked={\n                                                data.requireDescription\n                                                    ? true\n                                                    : false\n                                            }\n                                            onChange={(d) => {\n                                                changeData({\n                                                    name: \"requireDescription\",\n                                                    value: data.requireDescription ? false : true\n                                                })\n                                            }}\n                                            name=\"requireDescription\"\n                                            inputProps={{ \"aria-label\": \"secondary checkbox\" }}\n                                        />\n                                        {translate(\"$__requireDescription\", 1)}\n                                    </div>\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'\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 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-Card.js\"\n\n//FUNCTIONS\n\nimport { translate, customApp, appAlert } from \"functions/\"\n\nfunction Component(props) {\n    const { classes } = props\n    const { db, sideModule } = reduxStore.getState()\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    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                <fieldset style={{ textAlign: \"center\" }}>\n                    <legend style={{ color: customApp(\"color\") }}>{translate(\"$__integration\", 1)}</legend>\n                    <div style={{ textAlign: \"center\", width: \"100%\" }}>\n                        {translate(\"$__useIdToFeelFlowIdIntegration\", 1)}\n                    </div>\n                    <div\n                        style={{ fontSize: 14, fontWeight: \"bold\", color: \"blue\" }}\n                    >{data._id}</div>\n                </fieldset>\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\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                console.log(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 ColumnSettings from \"components/Columns/settings\"\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        }] : [],\n        ...data.type === 'step' && permission ? [{\n            name: 'settings',\n            icon: 'settings',\n            title: '$__settings',\n            reqId: true,\n            module: ColumnSettings,\n            closeOption: false,\n            permission: 5,\n            template: true,\n        }] : [],\n        ...data.type !== 'user' && data.type !== 'step' ? [{\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\n                        if (!a.dragItem.parent && a.dragItem.id === target.id)\n                            return false\n\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    let cardRef = React.useRef({})\n\n    React.useEffect(() => {\n        if (!cardRef.current) return; // wait for the elementRef to be available\n        if (props.onResize) {\n            const resizeObserver = new ResizeObserver(() => {\n                let newSize = cardRef.current.clientHeight\n                props.onResize(newSize)\n            });\n            resizeObserver.observe(cardRef.current);\n            return () => resizeObserver.disconnect(); // clean up \n        }\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            ref={cardRef}\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 [ended, setEnded] = React.useState(false)\n    const [hashs, setHashs] = React.useState(window.location.hash.split(\"/\"))\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    const refs = React.useRef({})\n\n\n    React.useEffect(() => {\n        refs.current = {\n            loading: false\n        }\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        if (props.max) {\n            setMax(props.max)\n        }\n\n        return () => {\n\n        }\n    }, [])\n\n    React.useEffect(() => {\n        if (hashs.length > 0 && !mounted) {\n            loadLinks()\n            if (hashs[2] && hashs[2].length !== 36) {\n                setLoading(true)\n            }\n            setMounted(true)\n        }\n    }, [hashs])\n\n    React.useEffect(() => {\n        if (!ended > Object.keys(links).length) {\n            setLoading(true)\n            loadLinks()\n        }\n    }, [page])\n\n    React.useEffect(() => {\n        setLoading(false)\n    }, [links])\n\n    const loadLinks = async () => {\n        if (!ended && !refs.current.loading) {\n            refs.current = {\n                loading: true\n            }\n            setLoading(true)\n            const response = await apims.post(\"/Feed_Links_V2\", {\n                ids: hashs[2] && hashs[2].length ? hashs[2] : null,\n                skip: Object.keys(links).length,\n                limit: 21\n            })\n\n            let loadFeeds = Array.from(links)\n            if (response && response.data) {\n                response.data.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.length === 0) {\n                setEnded(true)\n            }\n            setLinks(loadFeeds)\n            refs.current = {\n                loading: false\n            }\n        }\n    }\n\n    const setTitle = async (title) => {\n        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        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\n        var scrollDiv = document.getElementById(`linkList`);\n\n        if (!loading && scrollDiv.scrollTop + window.innerHeight + 400 > scrollDiv.scrollHeight && !props.horizontal)\n            loadLinks()\n    }\n\n    const RenderSkeleton = () => {\n        let rows = []\n        for (var i = 0; i < 21; 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                    {!ended && 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\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    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) => {\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    let cardRef = React.useRef({})\n\n    React.useEffect(() => {\n        if (cardRef.current) {\n            if (props.onResize) {\n                // let newSize = cardRef.current.clientHeight\n                // props.onResize(newSize)\n                // cardRef.current.addEventListener(\"DOMNodeInserted\", () => {\n                //     let newSize = cardRef.current.clientHeight\n                //     props.onResize(newSize)\n                // })\n                const resizeObserver = new ResizeObserver(() => {\n                    let newSize = cardRef.current.clientHeight\n                    props.onResize(newSize)\n                });\n                resizeObserver.observe(cardRef.current);\n                return () => resizeObserver.disconnect(); // clean up \n            }\n        }\n        return () => {\n\n        }\n        // eslint-disable-next-line\n    }, [cardRef]);\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\n            ref={cardRef}\n            className={classes.feed}\n            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 mapDispatchToProps = dispatch =>\n    bindActionCreators(reduxActions, dispatch)\n\nexport default connect(null, 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 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    const [endLinks, setEndLinks] = 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 (!endLinks) {\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 (!endLinks) {\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                                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                } else if (response && response.data && response.data.length === 0) {\n                    setEndLinks(true)\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\n        console.log(scrollDiv.scrollHeight - scrollDiv.scrollTop)\n\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                    {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 => {\n                                return (<NewCard db=\"cards\" key={card} data={db.cards[card]} noShadow />)\n                            })}\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                                    props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\n                                        ...reduxStore.getState().control,\n                                        addCard: {\n                                            _parent: sol._id,\n                                            rows: 0\n                                        },\n                                    })\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                </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\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\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        // if (a)\n        //     console.log(a)\n        return (\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    )\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                                    zIndex: 10\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                                <Checklist\n                                    noChecklist\n                                    noDelete\n                                    showCard\n                                    myDay\n                                    db={\"cards\"}\n                                />\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                <GridContainer>\n                    {\n                        session.GlobalData.strategicStatement ?\n                            <GridItem\n                                md={6}\n                            >\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                            </GridItem>\n                            : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.message ?\n                        <GridItem\n                            md={6}\n                        >\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                        </GridItem>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.vocation ?\n                        <GridItem\n                            md={6}\n                        >\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                        </GridItem>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.history ?\n                        <GridItem\n                            md={6}\n                        >\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                        </GridItem>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.values ?\n                        <GridItem\n                            md={6}\n                        >\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                        </GridItem>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {session.GlobalData.legacy ?\n                        <GridItem\n                            md={6}\n                        >\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                        </GridItem>\n                        : <React.Fragment></React.Fragment>\n                    }\n                    {/* </Carousel> */}\n                </GridContainer>\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'\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  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\nconst mapDispatchToProps = dispatch =>\n  bindActionCreators(reduxActions, dispatch)\n\n//EXPORT\nexport default connect(null, 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, { useRef, memo } from 'react';\nimport styled from 'styled-components';\nimport { Droppable, Draggable } from 'react-beautiful-dnd';\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 IconButton from \"components/CustomButtons/IconButton\";\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\nfunction Column(props) {\n    const { search, session, db } = reduxStore.getState()\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\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\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    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        // if (card.name === \"SDsd\")\n        // console.log('AS5555555555555555555555555555')\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        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                                clone=\"CL\"\n                            />\n                        </div>\n                    )}\n                </Draggable>\n            </React.Fragment>\n        )\n    }\n\n    function Item({ provided, index, snapshot, clone }) {\n        let card = filtered[index]\n        // if (card.name === \"Fluxo 1\")\n        // console.log('XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII', index, clone)\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                                    clone={true}\n                                />\n                            )\n                        }}\n                    >\n                        {(provided) => (\n                            <div\n                                ref={provided.innerRef}\n                                style={{\n                                    width: \"100%\",\n                                    height: props.inLineAdd ? \"calc(100% - 60px)\" : \"calc(100% - 10px)\"\n                                }}\n                            >\n                                {/* {console.log('88888888888888888888888********************************************')} */}\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                                            itemData={filtered}\n                                            style={{\n                                                height: \"100%\"\n                                            }}\n                                        >\n                                            {Row}\n                                        </List>\n                                    )}\n                                </AutoSizer>\n                            </div>\n                        )}\n                    </Droppable>\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                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\n                                    ...reduxStore.getState().control,\n                                    addCard: {\n                                        _parent: props.selectedParent ? props.selectedParent : hashs[0] ? hashs[0] : null,\n                                        // _planId: hashs[0] && hashs[0].length === 36 ? hashs[0] : null,\n                                        rows: filtered.length,\n                                        initialData: {\n                                            type: props.typeAdd ? props.typeAdd : props.columnId.length < 36 ? props.columnId : null,\n                                        }\n                                    },\n                                })\n                            }}\n                        />\n                    </div>\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    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      <div\n        style={{\n          display: \"flex\",\n          justifyContent: \"center\"\n        }}\n      >\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 || \"Cristofer Odair\"}\n                    // value={name}\n\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 || \"cristofer.odair@outlook.com.br\"}\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      </div>\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 AutoNumeric from \"autonumeric\"\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, discount } = 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: `calc(100% - ${discount + 47}px)`,\r\n                        overflowY: \"auto\",\r\n                        position: \"relative\",\r\n                    }}\r\n                    >\r\n                        {({ height, width }) => {\r\n                            return (\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                                        height: \"100%\"\r\n                                    }}\r\n                                    outerRef={provided.innerRef}\r\n                                >\r\n                                    {Row}\r\n                                </VariableSizeList>\r\n                            )\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    const [hideDescription, setHideDescription] = React.useState(false)\r\n    const [hideValue, setHideValue] = React.useState(false)\r\n    const [discountHeight, setDiscountHeight] = React.useState(false)\r\n\r\n    React.useEffect(() => {\r\n        const resizeObserver = new ResizeObserver(() => {\r\n            setDiscountHeight(columnHeaderRef.current.clientHeight)\r\n        });\r\n        resizeObserver.observe(columnHeaderRef.current);\r\n        return () => resizeObserver.disconnect();\r\n    }, [columnHeaderRef])\r\n\r\n    const ColumnData = reduxStore.getState().db.cards[column.id]\r\n    const columnHeaderRef = React.useRef()\r\n\r\n    let sumValues = 0\r\n    if (ColumnData.showSumValues && column.items && column.items.length > 0 && column.items.filter(a => a.value).length > 0) {\r\n        column.items.filter(a => a.value).map(a => {\r\n            sumValues = sumValues + parseFloat(a.value)\r\n        })\r\n    }\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\r\n                        ref={columnHeaderRef}\r\n                        {...provided.dragHandleProps}>\r\n                        <HeaderWithIcon\r\n                            title={`${column.name} (${column.items.length})`}\r\n                            icon={column.icon || null}\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                        {ColumnData && ColumnData.description && !hideDescription ?\r\n                            <div style={{\r\n                                position: \"relative\",\r\n                                width: \"100%\",\r\n                                color: \"gray\",\r\n                                fontSize: 10,\r\n                                padding: \"0px 15px\",\r\n                                paddingBottom: 15\r\n                            }}>{ColumnData.description}</div>\r\n                            : <React.Fragment></React.Fragment>}\r\n                        {/* {console.log(column)} */}\r\n                        {ColumnData.showSumValues && sumValues > 0 && !hideValue ?\r\n                            <div style={{\r\n                                position: \"relative\",\r\n                                width: \"100%\",\r\n                                color: \"black\",\r\n                                fontWeight: \"bold\",\r\n                                fontSize: 12,\r\n                                padding: \"0px 15px\",\r\n                                paddingBottom: 15\r\n                            }}>R$ {sumValues}</div>\r\n                            : <React.Fragment></React.Fragment>\r\n                        }\r\n                        <div style={{ clear: \"both\" }}></div>\r\n                    </div>\r\n                    <ItemList column={column} index={index} {...props} discount={discountHeight || 0} />\r\n                    <div style={{ position: 'relative', float: 'left', width: '100%', padding: '15px 7px' }}>\r\n                        <IconButton\r\n                            text={translate(\"$__add\", '*')}\r\n                            icon=\"add_box\"\r\n                            iconColor={customApp('medium')}\r\n                            onClick={() => {\r\n                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                    ...reduxStore.getState().control,\r\n                                    addCard: {\r\n                                        _parent: column.id,\r\n                                        rows: column.items.length\r\n                                    },\r\n                                })\r\n                            }}\r\n                        />\r\n                    </div>\r\n                </div>\r\n            )}\r\n        </Draggable>\r\n    )\r\n})\r\n\r\nfunction AgileKanban(props) {\r\n    const [state, setState] = useState(getKanbanData(props.nodeId, { deleted: false }))\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            deleted: false\r\n        }))\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                    overflowY: \"auto\",\r\n                    height: \"-webkit-fill-available\",\r\n                }}\r\n            >\r\n                <Droppable\r\n                    droppableId=\"all-droppables\"\r\n                    direction=\"horizontal\"\r\n                    type=\"column\"\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                                }}\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)(AgileKanban)","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                                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\n                                                    ...reduxStore.getState().control,\n                                                    addCard: {\n                                                        _parent: props.selectedParent ? props.selectedParent : hashs[0] ? hashs[0] : null,\n                                                        rows: filtered.length,\n                                                        initialData: {\n                                                            type: props.typeAdd ? props.typeAdd : props.columnId.length < 36 ? props.columnId : null,\n                                                        }\n                                                    },\n                                                })\n                                            }}\n                                        />\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={{\n            // width: 'calc(100% + 30px)', \n            // paddingBottom: '30px', \n            marginLeft: \"-15px\"\n        }}>\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    React.useEffect(() => {\n\n    }, [])\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 StrategyAndPlans(props) {\r\n    const { session } = reduxStore.getState()\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    if (hashs[0].length === 36 && reduxStore.getState().db.cards[hashs[0].replace(\"#\", \"\")] && hashs[1] && hashs[1] === \"board\")\r\n        return (<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\r\n    return (\r\n        <div style={{\r\n            height: \"-webkit-fill-available\"\r\n        }}>\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/S/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(StrategyAndPlans))","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\nimport ErrorBoundary from \"components/ErrorBoundary\"\r\nimport GridContainer from \"components/Grid/GridContainer\"\r\nimport GridItem from \"components/Grid/GridItem\"\r\nimport Autocomplete from \"components/AutoComplete\"\r\nimport TextField from \"components/TextField\"\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport Switch from \"components/Switch\"\r\nimport Icon from \"components/Icon\"\r\nimport ProgressLinear from \"components/Progress/linear\"\r\n\r\n//@MATERIAL\r\nimport { withStyles } from \"@material-ui/core/styles\"\r\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\r\n\r\n\r\n//FUNCTIONS\r\nimport { getAppAccess, translate, appAlert } from \"functions/\"\r\n\r\nimport { customApp } from \"functions\"\r\n\r\nimport apims from \"apims\"\r\nimport api from \"api\"\r\n\r\nfunction App(props) {\r\n    const {\r\n        session,\r\n        functions,\r\n        db\r\n    } = reduxStore.getState()\r\n    const [data, setData] = React.useState({})\r\n    const [iniData, setIniData] = React.useState(session.GlobalData ? session.GlobalData : {})\r\n    const [secretView, setSecretView] = React.useState(false)\r\n    const [loading, setLoading] = React.useState(true)\r\n\r\n    React.useEffect(() => {\r\n        reqIntegrationToken()\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    const reqIntegrationToken = async (n = false) => {\r\n        let ntk = n\r\n        let result = await apims.post(\"/ReqIntegrationToken\")\r\n        if (!ntk && result && result.data?.token) {\r\n            setData({\r\n                secretKey: `Bearer ${result.data.token}`\r\n            })\r\n        } else {\r\n            let result = await api.post(\"/api/token\")\r\n            if (result)\r\n                setData({\r\n                    secretKey: `Bearer ${result.data.token}`\r\n                })\r\n        }\r\n        setLoading(false)\r\n    }\r\n\r\n    const saveData = async () => {\r\n        let newData = {}\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\r\n        if (!newData.requireExpirePassword && newData.expiresIn)\r\n            newData.expiresIn = null\r\n\r\n        try {\r\n            const { socket } = reduxStore.getState().functions\r\n\r\n            console.log(newData)\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        } catch (e) {\r\n            console.log(e)\r\n        }\r\n    }\r\n\r\n\r\n    return (\r\n        <GridContainer>\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            >\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                    Integrações\r\n                    <ErrorBoundary>\r\n                        {loading ?\r\n                            <ProgressLinear />\r\n                            :\r\n                            <div>\r\n                                <fieldset style={{\r\n                                    wordBreak: \"break-word\",\r\n                                    marginTop: 50\r\n                                }}>\r\n                                    <legend>\r\n                                        {translate(\"$__authorizationToken\")}\r\n                                    </legend>\r\n                                    <div style={{\r\n                                        position: \"relative\",\r\n                                        width: \"100%\",\r\n                                        display: \"flex\",\r\n                                        alignItems: \"center\"\r\n                                    }}>\r\n                                        <TextField\r\n                                            label={translate('$__authorizationToken', 1)}\r\n                                            variant={customApp('fieldVariant')}\r\n                                            name={'secretKey'}\r\n                                            InputLabelProps={{\r\n                                                shrink: true,\r\n                                            }}\r\n                                            InputProps={{\r\n                                                multiline: true,\r\n                                                minRows: 3,\r\n                                                autoComplete: 'new-password',\r\n                                                type: secretView ? \"text\" : \"password\",\r\n                                                endAdornment: (\r\n                                                    <InputAdornment position=\"end\">\r\n                                                        <div style={{\r\n                                                            cursor: \"pointer\",\r\n                                                            marginRight: 7\r\n                                                        }}\r\n                                                            onClick={() => {\r\n                                                                navigator.clipboard.writeText(data.secretKey);\r\n                                                            }}\r\n                                                        >\r\n                                                            <Icon icon='content_copy' />\r\n                                                        </div>\r\n                                                        <Icon icon={secretView ? 'visibility_off' : 'visibility'} onClick={() => {\r\n                                                            setSecretView(prev => !prev)\r\n                                                        }} />\r\n                                                    </InputAdornment>\r\n                                                ),\r\n                                            }}\r\n                                            value={`${data && data.secretKey ? data.secretKey : ''}`}\r\n                                            placeholder={translate('$__secretKey', 1)}\r\n                                            autoFocus\r\n                                            disabled={true}\r\n                                        />\r\n                                    </div>\r\n                                    <i>{translate(\"$__secretKeyDescription\")}</i>\r\n                                </fieldset>\r\n                                <div style={{\r\n                                    display: \"none\",\r\n                                    justifyContent: \"flex-end\",\r\n                                }}>\r\n                                    <CustomButton\r\n                                        // shadow\r\n                                        title={translate(\"$__newToken\")}\r\n                                        text={translate(\"$__newToken\")}\r\n                                        color=\"green\"\r\n                                        // tr\r\n                                        icon={\"refresh\"}\r\n                                        size={\"25px\"}\r\n                                        onClick={() => {\r\n                                            appAlert({\r\n                                                message: translate(\"$__confirmApiTokenRevokeAndRecreate\", 1),\r\n                                                variant: \"warning\",\r\n                                                persist: false,\r\n                                                horizontal: \"right\",\r\n                                                confirm: () => {\r\n\r\n                                                }\r\n                                            })\r\n                                        }}\r\n                                    />\r\n                                </div>\r\n                            </div >\r\n                        }\r\n                    </ErrorBoundary>\r\n                </div>\r\n            </GridItem>\r\n        </GridContainer>\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                    <div\n                        style={{\n                            backgroundImage: `url(\"${customApp(\"customLogo\")}\")`,\n                            width: \"calc(100% - 70px)\",\n                            height: \"auto\",\n                            marginLeft: \"15px\",\n                            minHeight: \"min-content\",\n                            cursor: \"pointer\",\n                            paddingTop: \"33%\",\n                            backgroundPosition: \"center center\",\n                            backgroundSize: \"contain\",\n                            backgroundRepeat: \"no-repeat\"\n                        }}\n                        onClick={() => {\n                            openModule(\"/d#tab/resume\", \"dashboard\")\n                        }}\n                    ></div>\n                    {/* <img src={customApp(\"customLogo\")} alt=\"logo\"\n                        style={{\n\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\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            // if (db.cards[a]._requireApproval)\n            //     console.log(db.cards[a])\n            if (\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            ) return true\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\n// import 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 { loadCardsV2 } from \"functions/loadData\"\r\nimport session from \"store/controls\"\r\n\r\n\r\nconst ModalComponent = (props) => {\r\n    const { db, session } = reduxStore.getState()\r\n\r\n    React.useEffect(() => {\r\n        ini()\r\n    }, [props.board])\r\n\r\n    const ini = async () => {\r\n        loadCardsV2(props, {\r\n            cardLoad: 'childrens',\r\n            idRel: props.board,\r\n        })\r\n    }\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    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            \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                    height: \"83vh\",\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                            height: \"calc(100% - 50px)\"\r\n                        }}\r\n                    >\r\n                        <ErrorBoundary>\r\n                            <KanbanBoard\r\n                                nodeId={props.board}\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 * as reduxActions from \"store/actions\"\r\nimport history from \"store/history\"\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 CustomButton from \"components/Buttons/custom\"\r\nimport HeaderWithIcon from \"components/Header/card\"\r\nimport Icon from \"components/Icon\"\r\nimport IconButton from \"components/CustomButtons/IconButton\"\r\nimport Navigation from \"components/Navigation\"\r\nimport ProgressLinear from \"components/Progress/linear\"\r\nimport QuickUsers_List from \"components/User/avatarList\"\r\nimport TextField from \"components/TextField\"\r\nimport Timer from \"components/Timer/timer\"\r\n\r\n//@MATERIAL\r\nimport Avatar from \"@material-ui/core/Avatar\"\r\nimport ClickAwayListener from \"@material-ui/core/ClickAwayListener\"\r\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\r\nimport Modal from '@material-ui/core/Modal'\r\nimport Tooltip from \"@material-ui/core/Tooltip\"\r\n\r\n//@MATERIAL\r\nimport { makeStyles } from \"@material-ui/core/styles\"\r\n\r\n//STYLES\r\nimport styles from \"assets/jss/material-dashboard-pro-react/components/Card.js\"\r\n\r\n\r\n//FUNCTIONS\r\nimport apims from \"apims\"\r\n\r\nimport {\r\n    copyCards,\r\n    saveCard,\r\n} from \"functions/cards\"\r\n\r\nimport {\r\n    customApp,\r\n    translate,\r\n} from \"functions/\"\r\n\r\nfunction Card(props) {\r\n    const [data, setData] = React.useState({})\r\n    const [move, setMove] = React.useState(false)\r\n    const [copyName, setCopyName] = React.useState(data?.name || \"\")\r\n    const [copyModel, setCopyModel] = React.useState(false)\r\n    const [copyRel, setCopyRel] = React.useState({})\r\n    const [selectTarget, setSelectTarget] = React.useState(false)\r\n    const [duplicateLoader, setDuplicateLoader] = React.useState(false)\r\n\r\n    React.useEffect(() => {\r\n        if (props.toCopyMove && reduxStore.getState().db.cards[props.toCopyMove]) {\r\n            setData(reduxStore.getState().db.cards[props.toCopyMove])\r\n            setCopyName(`${reduxStore.getState().db.cards[props.toCopyMove].name} (${translate(\"$__copy\", '*')})` || \"\")\r\n        } else {\r\n            setData({})\r\n            setCopyName(\"\")\r\n        }\r\n        return () => {\r\n            setData({})\r\n            setCopyName(\"\")\r\n        }\r\n    }, [props.toCopyMove])\r\n\r\n    if (JSON.stringify(data) === \"{}\" || !data)\r\n        return (<React.Fragment></React.Fragment>)\r\n\r\n    const duplicateCard = async () => {\r\n        setDuplicateLoader(true)\r\n        let newData = {}\r\n        Object.keys(data).map(x => {\r\n            if (x.indexOf(\"_\") === -1 && x !== \"created_at\" && x !== \"updated_at\")\r\n                newData = {\r\n                    ...newData,\r\n                    [x]: data[x]\r\n                }\r\n        })\r\n\r\n        newData = {\r\n            ...newData,\r\n            idRel: copyRel && copyRel._id ? copyRel._id : data._parent ? data._parent : null,\r\n            name: copyName,\r\n            ...copyModel ? { isModel: true } : {},\r\n            status: \"notStarted\"\r\n        }\r\n\r\n        try {\r\n            const request = await saveCard(props, true, newData, newData.idRel);\r\n            if (request && request._id) {\r\n                let copyResult = await copyCards(props, data._id, request._id);\r\n                if (copyResult) {\r\n                    setSelectTarget(false)\r\n                    setDuplicateLoader(false)\r\n                    props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                        ...reduxStore.getState().control,\r\n                        toCopyMove: null,\r\n                    })\r\n                }\r\n            }\r\n        } catch (e) {\r\n            console.log(\"ERROR\", e)\r\n        }\r\n    }\r\n\r\n    const moveCard = async () => {\r\n        let newData = {}\r\n        Object.keys(data).map(x => {\r\n            if (x.indexOf(\"_\") === -1 && x !== \"created_at\" && x !== \"updated_at\")\r\n                newData = {\r\n                    ...newData,\r\n                    [x]: data[x]\r\n                }\r\n        })\r\n\r\n        newData = {\r\n            ...newData,\r\n            idRel: copyRel && copyRel._id ? copyRel._id : data._parent ? data._parent : null,\r\n            name: copyName,\r\n            ...copyModel ? { isModel: true } : {},\r\n            status: \"notStarted\"\r\n        }\r\n    }\r\n\r\n    const planningTypes = [\"guideline\", \"guidelineD\", \"guidelineR\", \"guidelineC\", \"guidelineE\", \"objective\", \"goal\"]\r\n    return (\r\n        <Modal\r\n            open={true}\r\n            onClose={() => {\r\n                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                    ...reduxStore.getState().control,\r\n                    toCopyMove: null,\r\n                })\r\n            }\r\n            }\r\n            aria-labelledby=\"simple-modal-title\"\r\n            aria-describedby=\"simple-modal-description\"\r\n        >\r\n            <ClickAwayListener\r\n                onClickAway={() => {\r\n                    props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                        ...reduxStore.getState().control,\r\n                        toCopyMove: null,\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: '400px',\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: '400px',\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                                }}\r\n                            >{translate(\"$__duplicate\")}</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_duplicate`}\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                                            toCopyMove: 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                            {selectTarget ?\r\n                                <div\r\n                                    style={{\r\n                                        position: 'relative',\r\n                                        float: 'left',\r\n                                        width: \"370px\",\r\n                                        marginBottom: \"15px\"\r\n                                    }}\r\n                                >\r\n                                    <Navigation\r\n                                        onSelect={(e) => {\r\n                                            setCopyRel(e)\r\n                                        }}\r\n                                        ignoreTypes={['chatGroup']}\r\n                                    />\r\n                                </div>\r\n                                :\r\n                                <div\r\n                                    style={{\r\n                                        width: \"100%\",\r\n                                        display: \"flex\",\r\n                                        justifyContent: \"flex-end\"\r\n                                    }}\r\n                                >\r\n                                    <CustomButton\r\n                                        title={translate(`$__selectTarget`, 1)}\r\n                                        text={translate(`$__selectTarget`, 1)}\r\n                                        color={customApp(\"menu\")}\r\n                                        icon={\"assistant_navigation\"}\r\n                                        onClick={() => {\r\n                                            setSelectTarget(true)\r\n                                        }}\r\n                                        size={\"14px\"}\r\n                                        textSize={\"14px\"}\r\n                                    />\r\n                                </div>\r\n                            }\r\n\r\n                            <div\r\n                                style={{\r\n                                    position: \"relative\",\r\n                                    width: \"100%\",\r\n                                    display: \"grid\"\r\n                                }}\r\n                            >\r\n                                {!move ?\r\n                                    <React.Fragment>\r\n                                        {(\r\n                                            copyRel\r\n                                            && copyRel.type\r\n                                            && planningTypes.indexOf(copyRel.type) > -1\r\n                                            && (\r\n                                                copyRel.type.indexOf(data.type) > -1\r\n                                                ||\r\n                                                data.type.indexOf(copyRel.type) > -1\r\n                                            )\r\n                                        ) ?\r\n                                            <div style={{\r\n                                                color: \"red\",\r\n                                                fontSize: 12,\r\n                                                marginBottom: 15,\r\n                                                textTransform: \"uppercase\",\r\n                                                textAlign: \"center\"\r\n                                            }}>\r\n                                                {translate(`$__youAreDuplicating`)}: {translate(`$__${copyRel.type}`)} {translate(`$__for`)}: {translate(`$__${copyRel.type}`)}.\r\n                                                {translate(`$__thisWillBeTurnedIntoAnActivity`)}\r\n                                            </div>\r\n                                            : <React.Fragment></React.Fragment>\r\n                                        }\r\n                                        <TextField\r\n                                            label={translate(\"$__copyAs\", 1)}\r\n                                            variant={customApp(\"fieldVariant\")}\r\n                                            name={\"copyAs\"}\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=\"clear\" onClick={() => {\r\n                                                            setCopyName(data.name)\r\n                                                        }} />\r\n                                                    </InputAdornment>\r\n                                                ),\r\n                                                onChange: (d) => {\r\n                                                    setCopyName(d.target.value)\r\n                                                },\r\n                                            }}\r\n                                            value={copyName}\r\n                                            placeholder={translate(\"$__copyAs_placeholder\", 1)}\r\n                                        />\r\n                                    </React.Fragment>\r\n                                    : <React.Fragment>\r\n                                        {(\r\n                                            copyRel\r\n                                            && copyRel.type\r\n                                            && planningTypes.indexOf(copyRel.type) > -1\r\n                                            && (\r\n                                                copyRel.type.indexOf(data.type) > -1\r\n                                                ||\r\n                                                data.type.indexOf(copyRel.type) > -1\r\n                                            )\r\n                                        ) ?\r\n                                            <div style={{\r\n                                                color: \"red\",\r\n                                                fontSize: 12,\r\n                                                marginBottom: 15,\r\n                                                textTransform: \"uppercase\",\r\n                                                textAlign: \"center\"\r\n                                            }}>\r\n                                                {translate(`$__youAreMove`)}: {translate(`$__${copyRel.type}`)} {translate(`$__for`)}: {translate(`$__${copyRel.type}`)}.\r\n                                                {translate(`$__thisWillBeTurnedIntoAnActivity`)}\r\n                                            </div>\r\n                                            : <React.Fragment></React.Fragment>\r\n                                        }\r\n\r\n                                    </React.Fragment>\r\n                                }\r\n\r\n                                {!duplicateLoader ?\r\n\r\n                                    <div\r\n                                        style={{\r\n                                            display: \"flex\",\r\n                                            justifyContent: \"space-between\",\r\n                                            alignItems: \"center\",\r\n                                            marginTop: 40\r\n                                        }}\r\n                                    >\r\n                                        <CustomButton\r\n                                            title={translate(`$__cancel`, 1)}\r\n                                            text={translate(`$__cancel`, 1)}\r\n                                            color={\"lightgray\"}\r\n                                            icon={\"cancel\"}\r\n                                            onClick={() => {\r\n                                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                                    ...reduxStore.getState().control,\r\n                                                    toCopyMove: null,\r\n                                                })\r\n                                            }}\r\n                                            size={\"12px\"}\r\n                                            textSize={\"12px\"}\r\n                                        />\r\n                                        <CustomButton\r\n                                            title={translate(`$__duplicateAllLinkedItems`, 1)}\r\n                                            text={translate(`$__duplicateAllLinkedItems`, 1)}\r\n                                            color={customApp(\"menu\")}\r\n                                            icon={\"dynamic_feed\"}\r\n                                            onClick={() => {\r\n                                                duplicateCard(true)\r\n                                            }}\r\n                                            size={\"12px\"}\r\n                                            textSize={\"12px\"}\r\n                                            transparent\r\n                                        />\r\n\r\n                                        {/* <CustomButton\r\n                                            title={translate(`$__confirmMoveCard`, 1)}\r\n                                            text={translate(`$__confirmMoveCard`, 1)}\r\n                                            color={customApp(\"menu\")}\r\n                                            icon={\"dynamic_feed\"}\r\n                                            onClick={() => {\r\n                                                moveCard(true)\r\n                                            }}\r\n                                            size={\"12px\"}\r\n                                            textSize={\"12px\"}\r\n                                            transparent\r\n                                        /> */}\r\n                                    </div>\r\n                                    :\r\n                                    <div\r\n                                        style={{\r\n                                            display: \"flex\",\r\n                                            justifyContent: \"space-between\",\r\n                                            alignItems: \"center\",\r\n                                            marginTop: 40\r\n                                        }}\r\n                                    >\r\n                                        <ProgressLinear />\r\n                                    </div>\r\n                                }\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </ClickAwayListener>\r\n        </Modal>\r\n    )\r\n}\r\n\r\n//REACT\r\nconst mapStateToProps = (store) => ({\r\n    toCopyMove: store.controls.toCopyMove\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)(Card)","// \r\nimport React from \"react\"\r\nimport moment from \"moment-timezone\"\r\n\r\n//COMPONENTS\r\nimport CurrencyTextField from 'components/TextField/currency'\r\nimport CustomButton from \"components/Buttons/custom\"\r\nimport Icon from \"components/Icon\"\r\nimport Navigation from \"components/Navigation\"\r\nimport ProgressLinear from \"components/Progress/linear\"\r\nimport SelectUsers from \"components/User/select\"\r\nimport TextField from \"components/TextField\"\r\nimport TextareaAutosize from 'react-textarea-autosize';\r\n\r\n\r\n//@MATERIAL\r\nimport InputAdornment from \"@material-ui/core/InputAdornment\"\r\nimport Modal from '@material-ui/core/Modal'\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    let refUsers = []\r\n    const [parentCard, setParentCard] = React.useState({})\r\n    const [addValue, setAddValue] = React.useState(false);\r\n    const [addDescription, setAddDescription] = React.useState(false);\r\n    const [selectTarget, setSelectTarget] = React.useState(false)\r\n    const [loader, setLoader] = React.useState(false)\r\n\r\n    React.useEffect(() => {\r\n        if (JSON.stringify(props.addCard) !== \"{}\" && props.addCard._parent && reduxStore.getState().db.cards[props.addCard._parent]) {\r\n            setParentCard(reduxStore.getState().db.cards[props.addCard._parent])\r\n        } else {\r\n            setParentCard({})\r\n            setLoader(false)\r\n            setSelectTarget(false)\r\n        }\r\n        return () => {\r\n            setParentCard({})\r\n            setLoader(false)\r\n            setSelectTarget(false)\r\n        }\r\n    }, [props.addCard])\r\n\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\r\n    const inputRef = React.createRef()\r\n    const descriptionRef = React.createRef()\r\n    const valueRef = React.createRef()\r\n    const saveRef = React.createRef({})\r\n\r\n    const createCards = async (list) => {\r\n        setLoader(true)\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\r\n            let newData = {\r\n                name: inputRef.current.value,\r\n                _parent: parentCard._id,\r\n                myDay: props.myDay ? true : false,\r\n                type: props.addCard?.initialData?.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                ...descriptionRef && descriptionRef.current && descriptionRef.current.value ? { description: descriptionRef.current.value } : {},\r\n                ...valueRef && valueRef.current && valueRef.current.getValue() ? { value: valueRef.current.getValue() } : {},\r\n                ...props.initialData ? props.initialData : {},\r\n            }\r\n\r\n            console.log(newData)\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.addCard?.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                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                    ...reduxStore.getState().control,\r\n                    addCard: {},\r\n                })\r\n            }\r\n        }\r\n\r\n\r\n        saveRef.current = ({\r\n            ...saveRef.current, loading: false\r\n        })\r\n    }\r\n\r\n    if (JSON.stringify(parentCard) === \"{}\")\r\n        return (<React.Fragment></React.Fragment>)\r\n\r\n    return (\r\n        <Modal\r\n            open={true}\r\n            onClose={() => {\r\n                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                    ...reduxStore.getState().control,\r\n                    addCard: {},\r\n                })\r\n            }\r\n            }\r\n            aria-labelledby=\"simple-modal-title\"\r\n            aria-describedby=\"simple-modal-description\"\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: '400px',\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: '400px',\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                            }}\r\n                        >\r\n                            {parentCard.shortCutTitle ? parentCard.shortCutTitle : translate(\"$__new\")}\r\n                        </div>\r\n                        <div style={{\r\n                            position: \"absolute\",\r\n                            right: 5,\r\n                            top: 5,\r\n                            display: \"flex\",\r\n                            alignItems: \"center\"\r\n                        }}>\r\n                            <CustomButton\r\n                                id={`assistant_navigation`}\r\n                                title={translate(`$__selectTarget`, \"*\")}\r\n                                color={customApp(\"color\")}\r\n                                icon={\"assistant_navigation\"}\r\n                                onClick={() => {\r\n                                    setSelectTarget(prev => !prev)\r\n                                }}\r\n                                size={\"20px\"}\r\n                                transparent\r\n                            />\r\n                            <CustomButton\r\n                                id={`close_addCard`}\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                                        addCard: {\r\n\r\n                                        },\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                        {selectTarget ?\r\n                            <div\r\n                                style={{\r\n                                    position: 'relative',\r\n                                    float: 'left',\r\n                                    width: \"370px\",\r\n                                    marginBottom: \"15px\"\r\n                                }}\r\n                            >\r\n                                <Navigation\r\n                                    onSelect={(e) => {\r\n                                        // console.log(e)\r\n                                        setParentCard(reduxStore.getState().db.cards[e._id])\r\n                                    }}\r\n                                    ignoreTypes={['chatGroup']}\r\n                                />\r\n                            </div>\r\n                            :\r\n                            <React.Fragment></React.Fragment>\r\n                        }\r\n\r\n                        <div\r\n                            style={{\r\n                                position: \"relative\",\r\n                                width: \"100%\",\r\n                                display: \"grid\"\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                            //     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                            >\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                                    >{parentCard.shortCutTitle ? parentCard.shortCutTitle : 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.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                                    ...reduxStore.getState().control,\r\n                                                    addCard: {\r\n\r\n                                                    },\r\n                                                })\r\n                                                return\r\n                                            }\r\n                                        }}\r\n                                        autoFocus={true}\r\n                                    />\r\n                                    {(\r\n                                        parentCard.requireDescription\r\n                                        || addDescription\r\n                                    ) &&\r\n                                        <TextField\r\n                                            inputRef={descriptionRef}\r\n                                            label={translate(\"$__description\", 1)}\r\n                                            variant={customApp(\"fieldVariant\")}\r\n                                            name=\"description\"\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=\"description\" color={\"lightgray\"} />\r\n                                                    </InputAdornment>\r\n                                                ),\r\n                                            }}\r\n                                            placeholder={translate(\"$__description\", 1)}\r\n                                        />\r\n                                    }\r\n                                    {(\r\n                                        parentCard.requireValue\r\n                                        || addValue\r\n                                    ) &&\r\n                                        <CurrencyTextField\r\n                                            label={translate(\"$__value\", 1)}\r\n                                            variant=\"standard\"\r\n                                            currencySymbol=\"$\"\r\n                                            outputFormat=\"string\"\r\n                                            inputRef={valueRef}\r\n                                            ref={valueRef}\r\n                                        />\r\n                                    }\r\n                                    {!parentCard.showInPanel &&\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                                    }\r\n                                </div>\r\n                                {!loader ?\r\n                                    <div style={{\r\n                                        display: 'flex',\r\n                                        alignItems: 'center',\r\n                                        justifyContent: \"space-between\",\r\n                                        marginTop: 33\r\n                                    }}>\r\n                                        <CustomButton\r\n                                            id={`addModal_cancelButton`}\r\n                                            title={translate(`$__cancel`, 1)}\r\n                                            text={props.placeHolder || translate(`$__cancel`, 1)}\r\n                                            color={customApp(\"medium\")}\r\n                                            icon={\"cancel\"}\r\n                                            onClick={() => {\r\n                                                props.reduxFunction(\"ASYNC\", \"SET_CONTROL\", {\r\n                                                    ...reduxStore.getState().control,\r\n                                                    addCard: {\r\n\r\n                                                    },\r\n                                                })\r\n                                            }}\r\n                                            size={\"25px\"}\r\n                                        />\r\n                                        <CustomButton\r\n                                            id={`sideModule_saveButton`}\r\n                                            title={parentCard.shortCutButtonToAdd ? parentCard.shortCutButtonToAdd : props.placeHolder || translate(`$__save`, 1)}\r\n                                            text={parentCard.shortCutButtonToAdd ? parentCard.shortCutButtonToAdd : 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\r\n                                    </div>\r\n                                    :\r\n                                    <div\r\n                                        style={{\r\n                                            display: \"flex\",\r\n                                            justifyContent: \"space-between\",\r\n                                            alignItems: \"center\",\r\n                                            marginTop: 40\r\n                                        }}\r\n                                    >\r\n                                        <ProgressLinear />\r\n                                    </div>\r\n                                }\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </Modal>\r\n    )\r\n}\r\n\r\n//REACT\r\nconst mapStateToProps = (store) => ({\r\n    addCard: store.controls.addCard\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)(QuickCardAdd)","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    maxHeight: \"calc(100vh - 72px)\",\r\n    padding: 15\r\n  },\r\n  content: {\r\n    marginTop: \"0px\",\r\n    padding: \"15px\",\r\n  },\r\n  container: {\r\n    ...containerFluid,\r\n    height: \"-webkit-fill-available\",\r\n    overflowY: \"auto\"\r\n  },\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\"\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\"\nimport CopyMove from \"components/Quick/copy_move\"\nimport CardAdd from \"components/Quick/addCard\"\n\n//ROUTES\nimport routes from \"routes\"\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\"\n\nimport {\n  chatReaded,\n  interact,\n  loadTimeline,\n  timelineComment,\n} from \"functions/chat\"\n\nimport {\n  dbUpdateUser\n} from \"functions/users\"\n\nimport {\n  dbUpdateFeed\n} from \"functions/feeds\"\n\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\"\n\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 \"./adminStyle\"\nimport stylesLogin from \"./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 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    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        console.log(\"XXXXXXXXXXXXXXXXXXX\")\n        await loadCardsV2(props, {\n          cardLoad: 'myDay',\n        })\n        await loadCardsV2({ ...props }, {\n          cardLoad: 'plans'\n        })\n        await loadCardsV2({ ...props }, {\n          cardLoad: 'chat',\n          ignoreLoader: true\n        })\n        loadCardsV2({ ...props }, {\n          cardLoad: 'steps',\n          ignoreLoader: true\n        })\n        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(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.container}>\n                <Switch>\n                  {appRoutes}\n                  <Redirect from=\"/\" to=\"/d#tab/resume\" />\n                </Switch>\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            <CardAdd />\n          </ErrorBoundary>\n          <ErrorBoundary>\n            <CopyMove />\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 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/IPdXfWq6vvqd796wlrLZnHrrWmAI8CfA+8FaoDZdAe7FEKIotb6TlSP/72U8qWtrMkKWLG6bwkHHzy06S6cLV4yAL5ARgZAYYvtdyeEQCD3R434Rc93P+a4znPG3J/7TG7x9/8JeH83BnLfISxYS1gLv6K1/piUW12azmCrVz3WlVHsEgghAEFUi5/VWv/Q/SBlq1e8P7dNDyEkWGsIa+ELWutP9JqUrV7tba/AN4QFIQVYCGvhl1OdfLyXpLzj7/jtYomUqBo/k6bJJ3tFyh4h60BIAQKievxFrfWHe0HKHiEbIFP0ENWjl7TWj3ablD1CNgEhBNb0xiTeI2STWKbon9Wp7ppO2SNkC2iRUg+/qLV+rBuk7BGyRSzbKU91w0/ZI2QbWO6naK076qfsEbJNLCPlGa31I50iZY+QHWAZKc9prT8u1c6Xc4+QHULIzE8Ja+EzOt25SbxHSAew5DyG9cazWuuP7ISUPUI6BCGasa96+FWt9Q9LKWEbicc9QjoIIQXWWsJ642mt9ceEWp3S3QhbTeG+o6FTjdEWscPb1BpLvVJ/1st7j7ie89WttN0jBMBahBDkB3JYY1s6YUddGosQ8nnXcx8DvrzZdnuEAEtVJoVSsdMdY6z9EO9EQpRSHelHa33v79K0I9e4C1ti+W1DSJIkHennPhQubMnW2vWESCkxxnDpyjRRGOM429spaaoJAo/jx8Zafe5G7HpCltRrmqYkSYK121vINNUoR67oczeio4RYa1FK4XkuG5VjCiGI4wSt9bpWzVIvjlQopXAchzTVJEmyoTVkrcV1XRxHYW3Wx/I+12vnOArX7dw8NouOEqKUIo4S5mYrG8pqYyzFYg7Xc7YkPtJUE+R89g0NoDdop6SkWm8QNqJN9w/gKEUYxszObGYehkIhh++7G45nU9fecQ/L4LkO83NVzl68hue59xQN1lqSVHPm1BEKhYAwijd9jThJGB4uc+L4OGG4frtc4HPh4nUqlSqus/mpep7D7TsLnL90jcD31v1tFCc8cOIQxVIOvcF4NoPOiiwsUgo8z8Nzs66tWbblRbNgwIIQaevuW2+rCyFWfC+EwGhDHMUk8fqWlxICY8yq9nf3ucZVm6LXw3XdbB7WtmWdaI/Z2qblts2C+bvRFaUuaCtOi2VJDAvaExGAlAKpBFLee3Gy78SqSn/LJnTBXb+xIutPyeUjXPuaUmT116152LYDefc8lq7VCXTNyrLWYozl4PgwhYKPEJLKYp3JqVsoKXEcxeSN29y8NYtZR3EKkS2GTjVKSdJ1HLv1oJREp5qLl6Zafd4LUgriOMX1nPY8xoYpFnNYDLVaxLWpW8gOKPG70UVCMlIKhRzlchGEQGuDMRYls21erzXQ2mzKOnFdt5UM2g6EFBhjWViobmLsmbXoupnBYaylUMwxUM6cbiFqWGOxOxjPvdADP8S2RJi4S0ysKXYsuG5m4q4yOXciF2y22zzPbX0khEBrTZykK26KtS9jWfGLLjkzXSNEiOyuXFxsYIxFIKhUay19oY2hr1jAdRXG2OyudBS+57JQqdEII1SXwxxpqsnlfEaGh4iiuLlbs90bxQmNRpT9LwSVxTqmaaDU6iFSCLogsbpJSKY8J6dutfwMqTLdYU3meY8d2MfgUB9hGBH4LtYKpqdn0WllRV9JkqKUQu2kiEBkvo9ONa7bnnaqNfmcz5HDI1gLURyTy/ncmJptmb3KEVyfut2eR1MHdgPdFVk2U6YrFnKZxaW1IUlSPNelVo+4dPkGs3MVfM/FcTMnUxtDeaBEkmriaPsBRmMsvusiA5+FhSpKSXzPJYlT3jz/FjfvzHHsyBi5IPtMLzeX15pHl9BRQoTIFGcYxRhr13cMkzTzcnM+t24tcO7CVcIoppAP0FpTrTXoKxU4eGCYUl+Ocxcm0UY3Fa7MHLYNdErgeygpsdZmoY3A58TxcaqLDSZv3KZSqZELPPK5gNnZCvV6yKnjE4yMDKK13pTDGkUJxhg6pd87SkiSpOTzASePTawbcrBkDuPAQJHpm3O8cfYKFsgXAqIwRkjJ4YOjjI6UyecCavWQVGsEAs91qVTrXLh4Ha03CJ0oSaVax2vGpJZyISMjZUqlHNM357gxfYdUmyxiEMa8fvYKCNi/rx/b3BnrQRtDIZ8jTjqTS+koIWmq8XyH8dK+DYNyhVzA1PQM337jMq6r8F2Xej0in/c5cXSC/r48UZxQqzUw1iKb+81xFI16xMJCdVPBRa8ZXEySFEnmuddqDaSSHDk8wkB/kQuXJqnXQ/K5gDhO+NZ3LvG9Z05w6sQ41Xq4rkG1FFxM010YXBTNUEUjvHcwz1pLPhcwfXuWN869hes6eK5DrR5SLpc4eXwc13WoNUIgCxBiLanWpGnbKdxsbGpJPKapbjmVQojs/1TT15fnzINHuHDxOguVKvlcADG8fvYyiCOUSnnqjXDDxe4EGdDjfIi1Ft/3CKOY8xcmAVpkDJb7OH3qIEDT3GzGippt/WaQz9lmKjfVutXH8r1bb4QEvseDpw9z9tw1ZucqFPIBjSjm3IVrfM+Zo/i+RxTFHVv09dBTQpRSCODS5Rs0wphCIaBRDykPlHjg1EGMtcTxyjzHkql59Mhox8axPNwvhCCMYjzP5YFTB3nz7FXmF6rk8z71WsjFyzd44NRBlFI9yTL2LMFsrSUXeExPzzIzu0AhnynwXD7g1IkJBKwiYzmUlB35WwtLekAAp05OkM/5RGFMPh8wM7vA9PQsge9tqBc7gZ4R4nkui9U6U9MzWTJHayxw/OgYrusQbiAStDEd+bsXlnaK6zgcPTyKbV7T91ymb85Qb0Qrwi7dQs8IcR2HG9OzNMII13GI4oSD48P09xVohFFP5PNGEELQCCMGB/sYG91HoxHheg6NMGb65sy29ddW0BNCPNdhfr7K7GyFXM4njhP6igVGRwaJ4q7UQu0IUZxw4MAg/aUCcZQQ+B63b8+zuFhvJd66hZ4Q4jiKmdkKcZKgpCRJNSPDZVzXIe1OcdqOkCQpge8xMjJE0szDxEnK7Nxi12JYS+g6IUopqrUGC5UqvucRxwn9/UUGyqUN9cb9Qia6YsrlIgP9ReI4wfccZmYXqNYaHauiXAtdJ8RzFbVaRL0RoZxsd+wr9xE0FftuhdaawHMZLPdlu8RRhFFMrRbhuW9jQqyFarWBEGC0xfddisX8qqTQboMQgjhJKRXz+L6L0ZnJu1itr5v+3Sm6SohSkkYjZqFZhpMkCeX+EoViQNKhYFw3kaQphWLAQH+JJElwHYdKpUa9EXYtFN9lQrKCszhOkEpiLeTzQVeKA7oFKQT5XIBplvvEcUIUpl3TI10lRApBmqZZVYnNMoaeu7VKxfsNYwy+56DUUh2WJU11126qruuQOEmx1mKtwXVUx0ouewVtDH7gNnMqWQVK3KFHI9ZCVwmx1hI1qwuNsbie26zl7X5MqFMwxjRTBC66Oe4oSroW1+oaIUKAaW5vIQSmWVG+lFJ9u8DaLLCZ6cDs+cNU66ySpgtiq4s7JDv0a6m0hmaO/W2kz9fEUnLLbPM5lY3QNUKWihEcR9FoxNTDCNd11i6A29XI5iGloNGIsuCo62SBxi7Mo6uRMm0MY6NDLQJGhsvbrs29X7A2m8f4gf1Z5aWAsdEhtDEdK7Bejq4SkiQpvu9y8sQ4INCpJtnlHvpaSJKUINechwCdmq7No6uELCnAJTN3SSm+3bCkN7To/jx6klN/e+mMe+MdlcLdw+awR8guwx4huwx7hOwybEmpF0alUb7o3BOO3wWwW3RXtkTI1Wesnyzu/ICv7xZYC8pHPfSpzbfZEiGvflYXZ79pkd7bPybVdVgwBnIjwusaIX5Z2GAYhEvHHlB5p8JasAZyQ6J7IktIrFQg1N4O2QjCNl9ruMVM75422GXYI2SX4b4cYCYVJA1oTGviyGDInspVCJy8IDcscQMBUpBUDNUbGtFMPxTHFE5eYNeoIpKuIJzV1G9pEOAWJKUxhTaZCLl7DGkI9ZuauNG2TZUQ+GVJfl92r/Y6DNdzQpQnmL+UIgQc/tcB+9/tURxVxDVD5ZJm5s2E2mSKTiBpGMonHQ5/PEdUMWDhzmsxOgR518itgHjekN+vOPxoDmNANyy3X4szv0m2fyeVYO5cgvIFBz8aMHTGpXRIoWPL/HnN9D9EXH81orRPkR9WmKR3rPSUEOkKZs8l9B9x+DdP7Gff9679vMXLv13hb39pHicQ+P2SR/9osPXdcz8xy3f+uEr/sZVDl8DsVMrDvzbEu/5LdibJ5acbPPXvGhTHmifJicwYuf1GzKEPBXz0DwfZ99DaY3j9f9b4x99bpDapcYu9s2B6qkPCGU1p3OFHnh5eQUZtWlO53JZBV58PcYuC/Iji6vMh1/+m/RDpwEmHRNtVI49rlvIRlyMfz7U+m/q7iCQ0iKaloxTMnU059XieT//NSIsMa2DubMLiZDubeebHCjzwH/PUb+qeRiZ6ukOqNzUf+Vw/Ayeyyy5cTHnx5+a4/Y2YNIHxD3l4fZKb34gpHlAYC4264frXQsb/pQ/A2Ad9cgWJTWgtNEA0ZzjwQZ/SRPZhGloufykkP5T9LwRUJzUj3+/x2Bf2tdqdf7LOK79VYe5iiuMLJn7I59E/GuKtZxu88psVSgdVT0/N7BkhJrUE/ZKR728fmff0j97hzb9vMH7AQ3lw5a9CjLb0HXWwBrAQBILpV9onKox90Gfoe1zmzqfkhprbREJYN4z+i3bft16JmT2bUBxviisLcdXy/v/eh/KzFb74lw2e+NQtfCHpO6SwCbz+ZzVuvhITVwxCgrqHAdEt9O6hzwT8kiS/P1ugylTKzMWEg2MeblHgBILihKLvsAOmbd0UDjhcez7k5ssZKcKBvqMO8UK7DMfElnxJcuzxtri6+kJIEpqWY9aYyQg79lj7N3/9i/PkHcngaQflCZyCYP9pl2jBID1BUJY9JQN6SIj0BOGcoTqVyem+MYfh0x5TUzFW33sk0oP6ouH637X1yIEP+Cv0SLRgGTjtMvr+TKzZFC78RZ1cWbXM3WjWMPZhv7U7Lj3VYO5sku3GZYtuNPj9EicQmPtQINMzQoSCpGa59kLY+uyxJ/bxnh8pMnMpYf5citWZf7ACBlwluP1PbbF17BMBfWMOad0iRKY/yiecVtvpVyLmzqYE5ZXT6z/altDX/zYitauNg/uNng6ndETx8q8vcPEvGgDkhxWf/PP9fPq5EQ59NGDuUsLCWxrprtSihTHFlWcazF/IbuWBUy6DJx2ihcypNNZy9F+1RdHkixFx3azUkAL8vvZ067c0jhRgMnM8DS23zyfcOZ8w0/y7eT6memP1eLqJnlpZbiDwBiRPffo2P/gbZd73cyUADj0ScOiRgMmvRTz3X2eYfT1h8IzbcsicvODO2ZRrL4QMnMh8jPIpl6svhfhFSfm4y6FHAyDTPeefrBP0y7Z3bgEBKrdsYXXbSgtnNP0nXR7+5X50YjMRaiE3KLnxDzFn/08tI7MHvPSUEKMhGJJIV/CVn5/h4l/W+cCv9nP4kWwxJz7s86PfOMCTj97izmsxhQlFtgXAQXD7m22xdejRgNc+v0g4bzhwxqdwIFvdmy/HzL6RkB9ZJvuaC7nc47aSln8RzRlKE4p3/cTqN0vkhhWvfX4RryR7EuHu/bsbUvAKgtHTHtOvxPzvR6d54pFb3PlW9tiCWxB89PfLSF9gwvYC5kcVV54JM0cNOPSRgMEHPSp1zfiH/NbvJl8KiWpm9a1mIK60+wv6JDq1WJHdJJUrKS//ZoUXf3qON/9Xrd0stT11DO+LSrMW0NB3SDF80uPSVxv86ftuMPtGRsr+93gc/VhAdbpt5vh9gtmLCVe/mhkFwZCkNKGwWA59pE3IuSfr+H1yVTDRYLOgYxNDD7loMofRLyuq1zUv/uIcX/rcDN/50xr3C/fVxljyNUbOeNQSw9d/rX34ZfmMSxq1V3UpIry0kwAGH3BxkZRPZyGQW/8YM/d60nYYl8HLS6b/f9t0PvqJHP2jinjBoFOLEwj2nXSZUB59Y90/QuNe6Ckh0hXUbmjmL6Yk9eax3c3HpTUWv9QW0rrRPkUOsvB5blDx1lca6DhrO/x9Lsc+HJAfzhZw8msRjUWDWMMqKowqJl+IuPH3GSnFCcXRT+S4OZ0gaWdArQW98zP1t42eKXUrMmvm+ON5nJzgyrMN5s6npBg0MHHM5/2/1AdAUre89VxIsG/l/RIMSGbOptx6NebAwz7jPxisiPqe/791guJqcQVZHUAaWV77gyoHHs5E3CN/MEhtSvPtZ+oUkSBh2iScXvYsjnTEOzOWZSOLTuB9P1ti+Ps8alOaq8+HzF9JKYwoTv2HfMuR+84fV5l+JWLwlLsiQZQ5l4apr2eEDBx3WoTc+WbCnW/Hq0hswUD/EYdv/kmV0Q94vPsnS0hX8G+fHubI7y1y7f+FODnBD5xxeeg/t62txcmUTNl0a2VWoneEaHByoh2jGlM8+GOFVb/71uer/PUvzNM3sfbQgpLkwpN13vczpeZrI7LPr30tJFqw5IfXWTkF5YMOL3xmjsYdw8O/3I8Q8N7PlHjvZ0qrxvuN36nw8m9XKIypnhV19IwQJy+Ia5YvPn6bh368wNgP+HglifLBJBDOGV7/kyqvP1FnYNzBKa0dZc3tV8yeTTj7Z3VGP+ATLRiUC+e+UMfvy15rcc/CG5OZ3GJC8dKvzHH5qQbv/qkS/cccvD6BNZlPMn8h5bU/rHL11ZChcRen0LuIb+92iAWvTxJXDF//7AJKCty8yHLlOguNO75g3yk3e53EPRZAuOAPSJ7/bzNY0zQKEkswoChOOBumW40GxxeMnPaZOZfw5R+/g5+TOH72HlsdQhQZCgOKA6f97Fz6HkZ8t0SIjjLDZ7u716YWNy8YOuliTZapW6pfyo82xc9Gb2ppkhCUZRambw5GuWLTue/MD7IUhhWF/dlZ9NkLAyRCQql5bIbV9z6de0M0Xwlh0611sbVCOQeZVMEfInMMdgAhadUIb2fS0umQUBeZsaC28WbndbsVoBNIo61Nb0t+yLt+Sv6T8qB+Y6stv8sgIV6EcAaOf0pMb6XplnbIkcfl/6hdx3n1s/pzNsEIyRb5/+6ATXAxBA/9pPzd9/yC+tWttP1naNHfLnAaa+QAAAAASUVORK5CYII=\"","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","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    // if (cardLoad !== \"myDay\")\r\n    //     return {}\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                // if (cardLoad === 'approval') console.log(cards.data)\r\n\r\n                let mount = await mountCards(props, reqData, cardLoad)\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 {\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\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                // if (cardLoad === 'approval') console.log(cards)\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 = [], cardLoad) => {\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\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        ) {\r\n            ndata.filter(d => filterCards(d)).map((d, i) => {\r\n                // console.log(d)\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                    }\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\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()\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            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}","//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: \"$__flowOrProcess\", //fluxos / processos\r\n            value: \"operational\",\r\n            overview: false,\r\n            swot: false,\r\n            kanban: true,\r\n            description: \"$__flowOrProcesPlanDescription\"\r\n        },\r\n        {\r\n            label: \"$__tacticAndOrOperational\",\r\n            value: \"flow\",\r\n            swot: false,\r\n            kanban: false,\r\n            overview: true,\r\n            description: \"$__operationalPlanDescription\"\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', 'settings'],\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;","//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\";","//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}","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    toCopyMove: null,\r\n    addCard: {},\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;","//\"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\";","module.exports = __webpack_public_path__ + \"static/media/fundoLogin.a16e608c.jpg\";"],"sourceRoot":""}