{"version":3,"sources":["utils.js","detector.js","node.js","advance-ajax-table.js","anchor.js","bottom-bar.js","bulk-select.js","chat.js","choices.js","cookie-notice.js","copy-link.js","countup.js","datatables.js","draggable.js","dropdown-menu.js","dropdown-on-hover.js","dropzone.js","form-validation.js","fullcalendar.js","glightbox.js","googleMap.js","hide-on-collapse.js","icons.js","inputmask.js","kanban.js","leaflet-active-user.js","list.js","lottie.js","navbar-combo.js","navbar-darken-on-scroll.js","navbar-top.js","navbar-vertical.js","nouislider.js","picmo.js","plyr.js","popover.js","progress.js","quantity.js","rater.js","scroll.js","scrollbar.js","search.js","select2.js","swiper.js","theme-control.js","tinymce.js","toast.js","tooltip.js","treeview.js","typed.js","unresolved-tickets-tab.js","wizard.js","calendar/events.js","calendar/index.js","calendar/management-calendar.js","calendar/management-events.js","calendar/template.js","charts/d3/d3-packed-bubble.js","charts/d3/trending-keywords.js","charts/chartjs/chart-bar.js","charts/chartjs/chart-bubble.js","charts/chartjs/chart-combo.js","charts/chartjs/chart-doughnut.js","charts/chartjs/chart-half-doughnut.js","charts/chartjs/chart-line.js","charts/chartjs/chart-pie.js","charts/chartjs/chart-polar.js","charts/chartjs/chart-radar.js","charts/chartjs/chart-scatter.js","charts/chartjs/chartjs-utils.js","charts/chartjs/product-share-doughnut.js","charts/echarts/active-users-report.js","charts/echarts/assignment-scores.js","charts/echarts/audience.js","charts/echarts/average-enrollment-rate.js","charts/echarts/bandwidth-saved.js","charts/echarts/basic-echarts.js","charts/echarts/bounce-rate.js","charts/echarts/browsed-courses.js","charts/echarts/candle-chart.js","charts/echarts/closed-vs-goal.js","charts/echarts/course-enrollments.js","charts/echarts/course-status.js","charts/echarts/crm-revenue.js","charts/echarts/customer-satisfaction.js","charts/echarts/deal-storage-funnel.js","charts/echarts/distribution-of-performance.js","charts/echarts/echarts-utils.js","charts/echarts/echarts.js","charts/echarts/gross-revenue.js","charts/echarts/lead-conversion.js","charts/echarts/line-payment.js","charts/echarts/location-by-session-crm.js","charts/echarts/market-share-ecommerce.js","charts/echarts/market-share.js","charts/echarts/marketing-expenses.js","charts/echarts/most-leads.js","charts/echarts/number-of-tickets.js","charts/echarts/real-time-users.js","charts/echarts/received-tickets.js","charts/echarts/report-for-this-week.js","charts/echarts/returning-customer-rate.js","charts/echarts/sales-by-pos-location.js","charts/echarts/satisfaction-survey.js","charts/echarts/session-by-browser.js","charts/echarts/session-by-country-map.js","charts/echarts/session-by-country.js","charts/echarts/ticket-priority.js","charts/echarts/ticket-volume.js","charts/echarts/top-customers.js","charts/echarts/top-products.js","charts/echarts/total-order.js","charts/echarts/total-sales-ecommerce.js","charts/echarts/total-sales.js","charts/echarts/traffic-channels.js","charts/echarts/unresolved-tickets.js","charts/echarts/user-by-location-lms.js","charts/echarts/users-by-time.js","charts/echarts/weekly-goals-lms.js","charts/echarts/weekly-sales.js","theme.js"],"names":["docReady","fn","document","readyState","addEventListener","setTimeout","resize","window","isIterableArray","array","Array","isArray","length","camelize","str","text","replace","_","c","toUpperCase","concat","substr","toLowerCase","getData","el","data","JSON","parse","dataset","e","hexToRgb","hexValue","hex","indexOf","substring","result","exec","m","r","g","b","parseInt","rgbaColor","color","arguments","undefined","alpha","getColor","name","dom","documentElement","getComputedStyle","getPropertyValue","trim","getColors","primary","secondary","success","info","warning","danger","light","dark","getSubtleColors","getGrays","white","100","200","300","400","500","600","700","800","900","1000","1100","black","hasClass","className","classList","value","includes","addClass","add","removeClass","remove","getOffset","rect","getBoundingClientRect","scrollLeft","pageXOffset","scrollTop","pageYOffset","top","left","isScrolledIntoView","windowHeight","innerHeight","clientHeight","windowWidth","innerWidth","clientWidth","vertInView","height","horInView","width","breakpoints","xs","sm","md","lg","xl","xxl","getBreakpoint","breakpoint","classes","split","filter","cls","pop","setCookie","expire","expires","Date","setTime","getTime","cookie","toUTCString","getCookie","keyValue","match","settings","tinymce","theme","chart","borderColor","newChart","config","ctx","getContext","Chart","getItemFromStore","key","defaultValue","store","localStorage","getItem","_unused","setItemToStore","payload","setItem","getStoreSpace","parseFloat","escape","encodeURIComponent","stringify","toFixed","getDates","startDate","endDate","interval","from","v","i","valueOf","getPastDates","duration","days","date","setDate","getDate","getRandomNumber","min","max","Math","floor","random","utils","detectorInit","is","html","querySelector","opera","mobile","firefox","safari","ios","iphone","ipad","ie","edge","chrome","mac","windows","navigator","userAgent","DomNode","node","_classCallCheck","this","_createClass","isValidNode","toggle","contains","setAttribute","removeAttribute","event","cb","orders","id","dropdownId","orderId","mailLink","email","address","shippingType","status","badge","type","icon","amount","advanceAjaxTableInit","togglePaginationButtonDisable","button","disabled","options","paginationButtonNext","paginationButtonPrev","viewAll","viewLess","listInfo","listFilter","orderList","totalItem","itemsPerPage","btnDropdownClose","pageQuantity","numberOfcurrentItems","pageCount","updateListControls","toggleViewBtn","table","getElementById","page","pagination","item","values","List","on","fallback","matchingItems","items","listContainer","ceil","visibleItems","fuzzySearch","innerHTML","preventDefault","nextInitialIndex","size","show","prevItem","target","Number","innerText","anchors","AnchorJS","bottomBarInit","isElementInViewport","offsetTop","bottom","right","bottomBars","querySelectorAll","navbarButtons","forEach","bar","barOptions","_window$_$merge","merge","breakPoint","targetEl","matchMedia","matches","btn","elementMap","Map","BulkSelect","element","option","_objectSpread","displayNoneClassName","set","attachNodes","clickBulkCheckbox","clickRowCheckbox","bulkSelectRows","row","checked","map","_utils$getData","body","actions","replacedElement","elms","_this","indeterminate","removeBulkCheck","rowCheck","setProp","toggleDisplay","_this2","_toConsumableArray","every","toggleClass","has","get","bulkSelectInit","bulkSelects","init","chatInit","setScrollbarPosition","$chatArea","scrollHeight","Events","Selector","ClassName","DATA_KEY","$chatSidebar","$chatContact","$chatEmojiarea","$btnSend","$currentChatArea","$this","currentTarget","style","TargetChatArea","textContent","dataIndex","choicesInit","Choices","userOptions","choices","itemSelectText","validationItem","selectFormValidation","choicesItem","singleSelect","multipleSelect","_singleSelect$querySe","getAttribute","getElementsByTagName","cookieNoticeInit","DataKeys","ClassNames","notices","showNotice","btnNoticeToggle","notice","bootstrap","Toast","autoShow","autoShowDelay","showOnce","cookieExpireTime","hasNotice","toastOptions","_ref","_element","hide","copyLink","copyLinkModal","copyButtons","select","tooltip","Tooltip","stopPropagation","update","inputID","execCommand","countupInit","countUp","_utils$getData2","endValue","_objectWithoutProperties","_excluded","CountUp","error","console","start","dataTablesInit","$","dataTables","customDataTable","jQuery","elem","find","each","index","extend","$wrpper","DataTable","closest","draggableInit","Selectors","columns","columnContainers","container","sortable","Draggable","Sortable","draggable","delay","mirror","appendTo","constrainDimensions","scrollable","scrollableElements","column","_ref2","source","columnContainer","form","nextElementSibling","appendChild","dropdownMenuInit","Event","t","scrollWidth","paddingBottom","dropdownOnHover","navbarArea","dropdownInstance","Dropdown","_menu","parentNode","dropzoneInit","Dropzone","autoDiscover","dropzones","url","addRemoveLinks","previewsContainer","previewTemplate","thumbnailWidth","thumbnailHeight","maxFilesize","autoProcessQueue","filesizeBase","thisDropzone","mockFile","addedfile","call","thumbnail","maxFiles","files","removeFile","file","message","previewElement","_step","_iterator","_createForOfIteratorHelper","s","n","done","err","f","dropzone","formValidationInit","forms","prototype","slice","checkValidity","renderCalendar","initialView","editable","direction","headerToolbar","center","buttonText","month","week","day","calendar","FullCalendar","Calendar","render","_document$querySelect","updateSize","fullCalendarInit","fullCalendar","glightboxInit","GLightbox","selector","initMap","mapStyles","themeController","$googlemaps","google","Default","featureType","elementType","stylers","lightness","weight","visibility","saturation","Gray","Midnight","Hopper","hue","Beard","AssassianCreed","SubtleGray","Tripitty","Cobalt","invert_lightness","gamma","itm","mapOptions","infowindow","marker","latLng","markerPopup","zoom","mapElement","mapStyle","pov","position","lat","lng","gestureHandling","scrollwheel","maps","StreetViewPanorama","LatLng","styles","InfoWindow","content","Marker","addListener","open","_ref3","_ref3$detail","detail","control","hideOnCollapseInit","previewMailForm","previewFooter","iconCopiedInit","iconList","iconCopiedToast","iconCopiedToastInstance","tagName","setSelectionRange","inputmaskInit","Inputmask","maskOptions","showMaskOnFocus","showMaskOnHover","jitMasking","mask","kanbanInit","addCardButtons","formHideButtons","addListForm","collapseDismissButtons","_ref4","focus","scrollTo","_ref5","_ref6","nextElement","_ref7","_ref8","collapseElement","collapse","Collapse","getInstance","leafletActiveUserInit","tiles","mcg","L","mapContainer","tileLayer","colorFilter","attribution","transparent","layers","minZoom","zoomSnap","dragging","Browser","tap","markerClusterGroup","chunkedLoading","spiderfyOnMaxZoom","long","street","location","point","iconUrl","popupContent","popup","minWidth","setContent","bindPopup","addLayer","_ref9","_ref9$detail","updateFilter","listInit","lists","list","bulkSelect","attachRowNodes","elm","lottieInit","lotties","bodymovin","loadAnimation","path","renderer","loop","autoplay","navbarComboInit","moveNavContent","moveableContainer","navbarNav","navbarVerticalBreakpoint","navbarVertical","navbarTopBreakpoint","navbarTopCombo","navbarTopContent","navbarCollapse","targetID","targetElement","insertAdjacentHTML","navbarDarkenOnScroll","navbar","removeNavbarBgClass","toggleThemeClass","defaultColorName","colorRgb","backgroundImage","transition","getBgClassName","parent","allColors","colorName","Object","keys","bgClassName","_ref10","_ref10$detail","backgroundColor","navbarTopDropShadow","setDropShadow","$elem","navDropShadowFlag","$navbar","$navbarVertical","$navbarVerticalContent","$navbarVerticalCollapse","outerWidth","handleNavbarVerticalCollapsed","navbarVerticalToggle","navbarVerticalCollapse","blur","isNavbarVerticalCollapsed","CustomEvent","dispatchEvent","nouisliderInit","noUiSlider","sliderValue","connect","step","range","tooltips","create","handle","picmoInit","picmoBtns","inputTarget","referenceElement","triggerElement","showCloseButton","picker","picmoPopup","createPopup","showPreview","input","selection","emoji","plyrInit","Plyr","plyr","captions","active","popoverInit","popoverTriggerEl","Popover","progressAnimationToggle","progress","progressID","quantityInit","Attributes","DataKey","quantity","numberInput","ratingInit","rater","reverse","starSize","rateCallback","rating","setRating","raterJs","scrollInit","dropdownElements","dropdownElement","instanceEl","scrollbarInit","SimpleBar","autoHide","searchInit","hideSearchSuggestion","searchArea","SEARCH_TOGGLE","dropdownMenu","DROPDOWN_MENU","Attribute","ARIA_EXPANDED","SHOW","hideAllSearchAreas","searchAreas","SEARCH_DISMISS","DROPDOWN_TOGGLE","SEARCH_BOX","SEARCH_INPUT","_ref11","dropdown","select2Init","select2","swiperInit","swipers","swiper","slides","thumbs","thumbsOptions","thumb","swiperNav","thumbImages","img","src","createElement","thumbsInit","Swiper","newSwiper","navigation","nextEl","prevEl","initialDomSetup","dataUrlDom","hasDataUrl","inputDataAttributeValue","localStorageValue","changeTheme","themeControl","CONFIG","hasOwnProperty","clickControl","reload","pageUrl","selectedOptions","href","tinymceInit","menubar","skin","content_style","toolbar","statusbar","plugins","directionality","theme_advanced_toolbar_align","setup","editor","triggerSave","_ref12","tinyMCE","editors","addStyle","toastInit","toastEl","liveToast","liveToastBtn","tooltipInit","tooltipTriggerEl","trigger","treeviewInit","makeStriped","treeview","tag","parentElement","treeviews","striped","collapseElementList","wholeRow","prepend","collapseId","childs","parents","unshift","collapseEl","typedTextInit","typedTexts","Typed","typedText","strings","typeSpeed","backDelay","unresolvedTicketsTabInit","dropdownToggle","layout","wizardInit","dividedProgressbar","wizards","tabPillEl","tabProgressBar","wizard","validatePattern","pattern","RegExp","test","String","tabToggleButtonEl","inputEmail","emailPattern","inputPassword","inputConfirmPassword","nextButton","prevButton","cardFooter","count","Tab","tab","j","_window3","dayjs","currentDay","format","currentMonth","prevMonth","subtract","nextMonth","currentYear","events","title","end","description","organizer","allDay","schedules","appCalendarInit","updateTitle","eventList","reduce","acc","val","appCalendar","addEventForm","addEventModal","eventDetailsModal","dayMaxEvents","stickyHeaderDates","views","eventLimit","eventTimeFormat","hour","minute","omitZeroMinute","meridiem","eventClick","jsEvent","template","getTemplate","Modal","dateClick","_flatpickr","dateStr","currentData","viewTitle","prev","next","today","link","changeView","_e$target","label","addEvent","reset","_ref13","managementCalendarInit","calendarData","managementCalendarEvents","managementEventList","managementCalendar","selectTitle","managementEvents","push","display","classNames","startTime","endTime","eventManagementInfo","li","currentDate","getDay","selectDay","thisDay","plus2Day","thisMonthNumber","thisMonthName","upcomingMonthNumber","upcomingMonthName","thisYear","extendedProps","getStackIcon","transform","join","schedule","D3PackedBubbleInit","tooltipDot","tooltipName","tooltipValue","tooltipStyles","labelStyles","circle","svg","d3","tooltipNameColor","tooltipValueColor","attr","bubbleData","root","pack","padding","hierarchy","children","sum","d","selectAll","enter","append","clientY","clientX","x","y","ease","easeExpInOut","diagram","trendingKeywordsInit","barChartInit","barChartElement","chartJsInit","labels","datasets","borderWidth","chartJsDefaultTooltip","scales","grid","drawBorder","chartBubble","pie","getBubbleDataset","hoverBackgroundColor","legend","chartCombo","combo","fill","maintainAspectRatio","chartDoughnut","doughnut","chartHalfDoughnutInit","$chartHalfDoughnut","rotation","circumference","cutout","hover","mode","enabled","mergedDatasets","chartLine","line","tension","chartPie","chartPolar","polar","chartRadar","radar","chartScatter","scatter","pointBackgroundColor","borderRadius","animation","chartEl","_ref14","destroy","titleColor","callbacks","labelTextColor","rmin","rmax","productShareDoughnutInit","marketShareDoughnutElement","activeUsersChartReportInit","tooltipFormatter","$echartsActiveUsersChart","echarts","params","axisValue","echartSetOption","textStyle","transitionDuration","pos","getPosition","formatter","xAxis","boundaryGap","silent","axisPointer","lineStyle","splitLine","axisLine","axisTick","axisLabel","align","fontSize","yAxis","round","series","showSymbol","symbol","itemStyle","symbolSize","assignmentScoresInit","$echartAssignmentScores","radius","avoidLabelOverlap","hoverAnimation","normal","fontWeight","emphasis","labelLine","audienceChartInit","percentage","perTemp","abs","prevDate","getDefaultOptions","data1","data2","dates","showMaxLabel","areaStyle","x2","y2","colorStops","offset","initChart","users","sessions","rate","triggerEl","$echartAudience","avgEnrollmentRateInit","onSaleCourseRate","regularPaidCourseRate","$echartsLineAvgEnrollmentLms","optionOne","optionTwo","_ref15","seriesName","margin","showMinLabel","splitNumber","dispatchAction","bandwidthSavedInit","$echartsBandwidthSaved","startAngle","endAngle","pointer","overlap","roundCap","clip","offsetCenter","fontFamily","valueAnimation","animationDuration","removeEventListener","basicEchartsInit","$echartBasicChart","bounceRateChartInit","$echartsBounceRateChart","selectMenu","setOption","browsedCoursesInit","newCourseBrowsedEl","paidCourseBrowsedEl","$echartsBrowsedCourses","months","isValid","_ref16","getMonth","barWidth","z","barBorderRadius","barGap","candleChartInit","$echartsZoomIn","$echartsZoomOut","zoomStart","zoomEnd","dispatchZoomAction","categoryData","$echartsCandleChart","actionTarget","splice","scale","toLocaleString","dataZoom","color0","borderColor0","batch","closedVsGoalInit","$echartsLineTotalSales","itemWidth","itemHeight","inactiveColor","itemGap","nameGap","nameLocation","nameTextStyle","smooth","courseEnrollmentsInit","$echartBarCourseEnrollments","componentIndex","courseStatusInit","$echartsCourseStatus","revenueChartInit","revenue","deals","profit","echartsCustomerSatisfactionInit","$echartCustomerSatisfaction","inactiveBorderColor","dealStorageFunnelInit","dataAxis1","dataAxis2","$echartDealStorageFunnel","inside","inverse","showBackground","backgroundStyle","echartsDistributionOfPerformanceInit","xAxisData","emphasisStyle","$distributionOfPerformance","shadowColor","splitArea","stack","containLabel","contentSize","_ref17","tooltipItem","_typeof","resizeEcharts","$echarts","echartTabs","grossRevenueChartInit","hash","bsTarget","LEGEND_MONTH_TARGET","LEGEND_PREV_MONTH","$legendCurrentMonth","$legendPrevMonth","monthsnumber","monthSelect","currentMonthData","prevMonthData","$echartsGrossRevenue","SELECT_MONTH","LEGEND_CURRENT_MONTH","selectedIndex","leadConversionInit","$leadConversion","linePaymentChartInit","$echartsLinePaymentChart","all","successful","failed","locationBySessionInit","zoomLevel","$locationBySessionMap","_params$data2","_params$data","visualMap","inRange","roam","scaleLimit","areaColor","_document$querySelect2","_document$querySelect3","_document$querySelect4","marketShareEcommerceInit","$echartProductShare","percent","marketShareInit","$echartMarketShare","marketingExpensesInit","marketingExpenses","detailedExpenses","$echartsMarketingExp","rich","per","selectedMode","lineHeight","mostLeadsInit","$echartMostLeads","echartsNumberOfTicketsInit","data3","data4","$numberOfTickets","numberOfTicketsLegend","realTimeUsersChartInit","axisData","userCounterDom","$echartsRealTimeUsers","barCategoryGap","setInterval","rndData","shift","echartsReceivedTicketsInit","$receivedTickets","reportForThisWeekInit","legendThisWeek","legendLastWeek","$echartBarReportForThisWeek","selectChart","option1","option2","returningCustomerRateInit","LEGEND_NEW_MONTH","LEGEND_RETURNING_MONTH","$legendNewMonth","$legendReturningMonth","monthNumbers","$echartsLineReturningCustomerRate","dataNewMonth","dataReturningMonth","salesByPosLocationInit","$echartsRadarSalesByPosLocation","getformatter","indicator","echartsSatisfactionSurveyInit","emphasisStyle1","emphasisStyle2","$satisfactionSurvey","sessionByBrowserChartInit","$sessionByBroswser","year","sessionByCountryMapInit","$sessionByCountryMap","_params$data4","_params$data3","toolbox","feature","restore","_document$querySelect5","sessionByCountryChartInit","$sessionByCountry","alignWithLabel","echartTicketPriority","$paginationBtnNext","$paginationBtnPrev","$paginationContainer","ticketVolumeChartInit","$ticketVolume","ticketVolumeLegend","topCustomersChartInit","hours","monday","tuesday","wednesday","thursday","friday","saturday","sunday","$echartTopCustomers","topProductsInit","$echartBarTopProducts","totalOrderInit","$echartLineTotalOrder","triggerOn","smoothMonotone","totalSalesEcommerce","totalSalesLastMonth","totalSalesPreviousYear","$echartsLineTotalSalesEcomm","TOTAL_SALES_LAST_MONTH","TOTAL_SALES_PREVIOUS_YEAR","_ref18","totalSalesInit","_params$","_params$2","trafficChannelChartInit","$trafficChannels","echartsUnresolvedTicketsInit","$unresolvedTickets","unresolvedTicketsLegend","userByLocationInit","$userByLocationMap","_params$data6","_params$data5","_document$querySelect6","_document$querySelect7","usersByTimeChartInit","$echartUsersByTimeChart","gradientColor","orient","itemSymbol","textGap","shadowBlur","weeklyGoalsInit","weeklySalesInit","$echartBarWeeklySales","apply"],"mappings":"y5HAGA,IAAAA,SAAA,SAAAC,GAEA,YAAAC,SAAAC,WACAD,SAAAE,iBAAA,mBAAAH,CAAA,EAEAI,WAAAJ,EAAA,CAAA,CAEA,EAEAK,OAAA,SAAAL,GAAA,OAAAM,OAAAH,iBAAA,SAAAH,CAAA,CAAA,EAEAO,gBAAA,SAAAC,GAAA,OAAAC,MAAAC,QAAAF,CAAA,GAAA,CAAA,CAAAA,EAAAG,MAAA,EAEAC,SAAA,SAAAC,GACAC,EAAAD,EAAAE,QAAA,gBAAA,SAAAC,EAAAC,GAAA,OACAA,EAAAA,EAAAC,YAAA,EAAA,EAAA,CACA,EACA,MAAA,GAAAC,OAAAL,EAAAM,OAAA,EAAA,CAAA,EAAAC,YAAA,CAAA,EAAAF,OAAAL,EAAAM,OAAA,CAAA,CAAA,CACA,EAEAE,QAAA,SAAAC,EAAAC,GACA,IACA,OAAAC,KAAAC,MAAAH,EAAAI,QAAAf,SAAAY,CAAA,EAAA,CAGA,CAFA,MAAAI,GACA,OAAAL,EAAAI,QAAAf,SAAAY,CAAA,EACA,CACA,EAIAK,SAAA,SAAAC,GAGAC,EADA,IAAAD,EAAAE,QAAA,GAAA,EACAF,EAAAG,UAAA,CAAA,EACAH,EAGAI,EAAA,4CAAAC,KACAJ,EAAAhB,QAFA,mCAEA,SAAAqB,EAAAC,EAAAC,EAAAC,GAAA,OAAAF,EAAAA,EAAAC,EAAAA,EAAAC,EAAAA,CAAA,CAAA,CACA,EACA,OAAAL,EACA,CACAM,SAAAN,EAAA,GAAA,EAAA,EACAM,SAAAN,EAAA,GAAA,EAAA,EACAM,SAAAN,EAAA,GAAA,EAAA,GAEA,IACA,EAEAO,UAAA,WAAA,IAAAC,EAAA,EAAAC,UAAAhC,QAAAiC,KAAAA,IAAAD,UAAA,GAAAA,UAAA,GAAA,OAAAE,EAAA,EAAAF,UAAAhC,QAAAiC,KAAAA,IAAAD,UAAA,GAAAA,UAAA,GAAA,GAAA,MAAA,QAAAxB,OACAU,SAAAa,CAAA,EAAA,IAAA,EAAAvB,OAAA0B,EAAA,GAAA,CAAA,EAIAC,SAAA,SAAAC,GAAA,IAAAC,EAAA,EAAAL,UAAAhC,QAAAiC,KAAAA,IAAAD,UAAA,GAAAA,UAAA,GAAA1C,SAAAgD,gBAAA,OACAC,iBAAAF,CAAA,EAAAG,iBAAA,YAAAhC,OAAA4B,CAAA,CAAA,EAAAK,KAAA,CAAA,EAEAC,UAAA,SAAAL,GAAA,MAAA,CACAM,QAAAR,SAAA,UAAAE,CAAA,EACAO,UAAAT,SAAA,YAAAE,CAAA,EACAQ,QAAAV,SAAA,UAAAE,CAAA,EACAS,KAAAX,SAAA,OAAAE,CAAA,EACAU,QAAAZ,SAAA,UAAAE,CAAA,EACAW,OAAAb,SAAA,SAAAE,CAAA,EACAY,MAAAd,SAAA,QAAAE,CAAA,EACAa,KAAAf,SAAA,OAAAE,CAAA,CACA,CAAA,EAEAc,gBAAA,SAAAd,GAAA,MAAA,CACAM,QAAAR,SAAA,oBAAAE,CAAA,EACAO,UAAAT,SAAA,sBAAAE,CAAA,EACAQ,QAAAV,SAAA,oBAAAE,CAAA,EACAS,KAAAX,SAAA,iBAAAE,CAAA,EACAU,QAAAZ,SAAA,oBAAAE,CAAA,EACAW,OAAAb,SAAA,mBAAAE,CAAA,EACAY,MAAAd,SAAA,kBAAAE,CAAA,EACAa,KAAAf,SAAA,iBAAAE,CAAA,CACA,CAAA,EAEAe,SAAA,SAAAf,GAAA,MAAA,CACAgB,MAAAlB,SAAA,aAAAE,CAAA,EACAiB,IAAAnB,SAAA,WAAAE,CAAA,EACAkB,IAAApB,SAAA,WAAAE,CAAA,EACAmB,IAAArB,SAAA,WAAAE,CAAA,EACAoB,IAAAtB,SAAA,WAAAE,CAAA,EACAqB,IAAAvB,SAAA,WAAAE,CAAA,EACAsB,IAAAxB,SAAA,WAAAE,CAAA,EACAuB,IAAAzB,SAAA,WAAAE,CAAA,EACAwB,IAAA1B,SAAA,WAAAE,CAAA,EACAyB,IAAA3B,SAAA,WAAAE,CAAA,EACA0B,IAAA5B,SAAA,YAAAE,CAAA,EACA2B,KAAA7B,SAAA,YAAAE,CAAA,EACA4B,MAAA9B,SAAA,aAAAE,CAAA,CACA,CAAA,EAEA6B,SAAA,SAAAtD,EAAAuD,GAEA,OAAAvD,EAAAwD,UAAAC,MAAAC,SAAAH,CAAA,CACA,EAEAI,SAAA,SAAA3D,EAAAuD,GACAvD,EAAAwD,UAAAI,IAAAL,CAAA,CACA,EAEAM,YAAA,SAAA7D,EAAAuD,GACAvD,EAAAwD,UAAAM,OAAAP,CAAA,CACA,EAEAQ,UAAA,SAAA/D,GACA,IAAAgE,EAAAhE,EAAAiE,sBAAA,EACAC,EAAAnF,OAAAoF,aAAAzF,SAAAgD,gBAAAwC,WACAE,EAAArF,OAAAsF,aAAA3F,SAAAgD,gBAAA0C,UACA,MAAA,CAAAE,IAAAN,EAAAM,IAAAF,EAAAG,KAAAP,EAAAO,KAAAL,CAAA,CACA,EAEA,SAAAM,mBAAAxE,GACA,IAAAgE,EAAAhE,EAAAiE,sBAAA,EACAQ,EAAA1F,OAAA2F,aAAAhG,SAAAgD,gBAAAiD,aACAC,EAAA7F,OAAA8F,YAAAnG,SAAAgD,gBAAAoD,YAEAC,EAAAf,EAAAM,KAAAG,GAAA,GAAAT,EAAAM,IAAAN,EAAAgB,OACAC,EAAAjB,EAAAO,MAAAK,GAAA,GAAAZ,EAAAO,KAAAP,EAAAkB,MAEA,OAAAH,GAAAE,CACA,CAEA,IAAAE,YAAA,CACAC,GAAA,EACAC,GAAA,IACAC,GAAA,IACAC,GAAA,IACAC,GAAA,KACAC,IAAA,IACA,EAEAC,cAAA,SAAA1F,GACA,IACA2F,EADAC,EAAA5F,GAAAA,EAAAwD,UAAAC,MAYA,OATAkC,EADAC,EACAT,YACAS,EACAC,MAAA,GAAA,EACAC,OAAA,SAAAC,GAAA,OAAAA,EAAArC,SAAA,gBAAA,CAAA,CAAA,EACAsC,IAAA,EACAH,MAAA,GAAA,EACAG,IAAA,GAGAL,CACA,EAIAM,UAAA,SAAAzE,EAAAiC,EAAAyC,GACA,IAAAC,EAAA,IAAAC,KACAD,EAAAE,QAAAF,EAAAG,QAAA,EAAAJ,CAAA,EACAxH,SAAA6H,OAAA,GAAA3G,OAAA4B,EAAA,GAAA,EAAA5B,OAAA6D,EAAA,WAAA,EAAA7D,OAAAuG,EAAAK,YAAA,CAAA,CACA,EAEAC,UAAA,SAAAjF,GACAkF,EAAAhI,SAAA6H,OAAAI,MAAA,UAAA/G,OAAA4B,EAAA,eAAA,CAAA,EACA,OAAAkF,GAAAA,EAAA,EACA,EAEAE,SAAA,CACAC,QAAA,CACAC,MAAA,OACA,EACAC,MAAA,CACAC,YAAA,0BACA,CACA,EAIAC,SAAA,SAAAF,EAAAG,GACAC,EAAAJ,EAAAK,WAAA,IAAA,EACA,OAAA,IAAArI,OAAAsI,MAAAF,EAAAD,CAAA,CACA,EAIAI,iBAAA,SAAAC,EAAAC,GAAA,IAAAC,EAAA,EAAArG,UAAAhC,QAAAiC,KAAAA,IAAAD,UAAA,GAAAA,UAAA,GAAAsG,aACA,IACA,OAAAxH,KAAAC,MAAAsH,EAAAE,QAAAJ,CAAA,CAAA,GAAAC,CAGA,CAFA,MAAAI,GACA,OAAAH,EAAAE,QAAAJ,CAAA,GAAAC,CACA,CACA,EAEAK,eAAA,SAAAN,EAAAO,GAAA,OAAA,EAAA1G,UAAAhC,QAAAiC,KAAAA,IAAAD,UAAA,GAAAA,UAAA,GAAAsG,cACAK,QAAAR,EAAAO,CAAA,CAAA,EACAE,cAAA,WAAA,IAAAP,EAAA,EAAArG,UAAAhC,QAAAiC,KAAAA,IAAAD,UAAA,GAAAA,UAAA,GAAAsG,aAAA,OACAO,YAEAC,OAAAC,mBAAAjI,KAAAkI,UAAAX,CAAA,CAAA,CAAA,EAAArI,OAAA,SAEAiJ,QAAA,CAAA,CACA,CAAA,EAIAC,SAAA,SAAAC,EAAAC,GAAA,IAAAC,EAAA,EAAArH,UAAAhC,QAAAiC,KAAAA,IAAAD,UAAA,GAAAA,UAAA,GAAA,MAGA,OAAAlC,MAAAwJ,KACA,CAAAtJ,OAAA,GAHAoJ,EAAAD,GACAE,CAEA,EACA,SAAAE,EAAAC,GAAA,OAAA,IAAAxC,KAAAmC,EAAAM,QAAA,EAAAJ,EAAAG,CAAA,CAAA,CACA,CACA,EAEAE,aAAA,SAAAC,GACA,IAAAC,EAEA,OAAAD,GACA,IAAA,OACAC,EAAA,EACA,MACA,IAAA,QACAA,EAAA,GACA,MACA,IAAA,OACAA,EAAA,IACA,MAEA,QACAA,EAAAD,CACA,CAEA,IAAAE,EAAA,IAAA7C,KACAoC,EAAAS,EACAV,EAAA,IAAAnC,MAAA,IAAAA,MAAA8C,QAAAD,EAAAE,QAAA,GAAAH,EAAA,EAAA,CAAA,EACA,OAAAV,SAAAC,EAAAC,CAAA,CACA,EAGAY,gBAAA,SAAAC,EAAAC,GAAA,OACAC,KAAAC,MAAAD,KAAAE,OAAA,GAAAH,EAAAD,GAAAA,CAAA,CAAA,EAEAK,MAAA,CACAlL,SAAAA,SACA2G,YAAAA,YACArG,OAAAA,OACAE,gBAAAA,gBACAK,SAAAA,SACAU,QAAAA,QACAuD,SAAAA,SACAK,SAAAA,SACArD,SAAAA,SACAY,UAAAA,UACAK,SAAAA,SACAO,UAAAA,UACAS,gBAAAA,gBACAC,SAAAA,SACAuB,UAAAA,UACAS,mBAAAA,mBACAkB,cAAAA,cACAO,UAAAA,UACAQ,UAAAA,UACAQ,SAAAA,SACAL,SAAAA,SACAU,iBAAAA,iBACAO,eAAAA,eACAG,cAAAA,cACAM,SAAAA,SACAQ,aAAAA,aACAM,gBAAAA,gBACAvF,YAAAA,WACA,EC1QA8F,aAAA,WACA,IAAAC,EAAA7K,OAAA6K,GACAC,EAAAnL,SAAAoL,cAAA,MAAA,EAEAF,EAAAG,MAAA,GAAApG,SAAAkG,EAAA,OAAA,EACAD,EAAAI,OAAA,GAAArG,SAAAkG,EAAA,QAAA,EACAD,EAAAK,QAAA,GAAAtG,SAAAkG,EAAA,SAAA,EACAD,EAAAM,OAAA,GAAAvG,SAAAkG,EAAA,QAAA,EACAD,EAAAO,IAAA,GAAAxG,SAAAkG,EAAA,KAAA,EACAD,EAAAQ,OAAA,GAAAzG,SAAAkG,EAAA,QAAA,EACAD,EAAAS,KAAA,GAAA1G,SAAAkG,EAAA,MAAA,EACAD,EAAAU,GAAA,GAAA3G,SAAAkG,EAAA,IAAA,EACAD,EAAAW,KAAA,GAAA5G,SAAAkG,EAAA,MAAA,EACAD,EAAAY,OAAA,GAAA7G,SAAAkG,EAAA,QAAA,EACAD,EAAAa,IAAA,GAAA9G,SAAAkG,EAAA,KAAA,EACAD,EAAAc,QAAA,GAAA/G,SAAAkG,EAAA,SAAA,EACAc,UAAAC,UAAAjE,MAAA,OAAA,GAAAhD,SAAAkG,EAAA,QAAA,CACA,ECnBAgB,QAAA,WACA,SAAAA,EAAAC,GAAAC,gBAAAC,KAAAH,CAAA,EACAG,KAAAF,KAAAA,CACA,CAyDA,OAzDAG,aAAAJ,EAAA,CAAA,CAAAtD,IAAA,WAAA9D,MAEA,SAAAF,GACAyH,KAAAE,YAAA,GAAAF,KAAAF,KAAAtH,UAAAI,IAAAL,CAAA,CACA,CAAA,EAAA,CAAAgE,IAAA,cAAA9D,MAEA,SAAAF,GACAyH,KAAAE,YAAA,GAAAF,KAAAF,KAAAtH,UAAAM,OAAAP,CAAA,CACA,CAAA,EAAA,CAAAgE,IAAA,cAAA9D,MAEA,SAAAF,GACAyH,KAAAE,YAAA,GAAAF,KAAAF,KAAAtH,UAAA2H,OAAA5H,CAAA,CACA,CAAA,EAAA,CAAAgE,IAAA,WAAA9D,MAEA,SAAAF,GACAyH,KAAAE,YAAA,GAAAF,KAAAF,KAAAtH,UAAA4H,SAAA7H,CAAA,CACA,CAAA,EAAA,CAAAgE,IAAA,OAAA9D,MAEA,SAAA8D,GACA,GAAAyD,KAAAE,YAAA,EACA,IACA,OAAAhL,KAAAC,MAAA6K,KAAAF,KAAA1K,QAAA4K,KAAA3L,SAAAkI,CAAA,EAAA,CAGA,CAFA,MAAAlH,GACA,OAAA2K,KAAAF,KAAA1K,QAAA4K,KAAA3L,SAAAkI,CAAA,EACA,CAEA,OAAA,IACA,CAAA,EAAA,CAAAA,IAAA,OAAA9D,MAEA,SAAAjC,GACA,OAAAwJ,KAAAE,YAAA,GAAAF,KAAAF,KAAAtJ,EACA,CAAA,EAAA,CAAA+F,IAAA,eAAA9D,MAEA,SAAAjC,EAAAiC,GACAuH,KAAAE,YAAA,GAAAF,KAAAF,KAAAO,aAAA7J,EAAAiC,CAAA,CACA,CAAA,EAAA,CAAA8D,IAAA,kBAAA9D,MAEA,SAAAjC,GACAwJ,KAAAE,YAAA,GAAAF,KAAAF,KAAAQ,gBAAA9J,CAAA,CACA,CAAA,EAAA,CAAA+F,IAAA,UAAA9D,MAEA,SAAAjC,EAAAiC,GACAuH,KAAAE,YAAA,IAAAF,KAAAF,KAAAtJ,GAAAiC,EACA,CAAA,EAAA,CAAA8D,IAAA,KAAA9D,MAEA,SAAA8H,EAAAC,GACAR,KAAAE,YAAA,GAAAF,KAAAF,KAAAlM,iBAAA2M,EAAAC,CAAA,CACA,CAAA,EAAA,CAAAjE,IAAA,cAAA9D,MAEA,WACA,MAAA,CAAA,CAAAuH,KAAAF,IACA,CAEA,EAAA,CAAAvD,IAAA,WAAA9D,MACA,SAAAnE,GACAC,EAAAD,EAAAE,QAAA,gBAAA,SAAAC,EAAAC,GAAA,OAAAA,EAAAA,EAAAC,YAAA,EAAA,EAAA,CAAA,EACA,MAAA,GAAAC,OAAAL,EAAAM,OAAA,EAAA,CAAA,EAAAC,YAAA,CAAA,EAAAF,OAAAL,EAAAM,OAAA,CAAA,CAAA,CACA,CAAA,EAAA,EAAAgL,CAAA,EAAA,EC9DAY,OAAA,CACA,CACAC,GAAA,EACAC,WAAA,mBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,eACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,8DACAC,aAAA,gBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,EACAC,WAAA,mBACAC,QAAA,OACAC,SAAA,yBACArK,KAAA,aACAsK,MAAA,kBACA7C,KAAA,aACA8C,QAAA,+DACAC,aAAA,oBACAC,OAAA,aACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,aAAA,EACAC,OAAA,MACA,EACA,CACAX,GAAA,EACAC,WAAA,mBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,cACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,4DACAC,aAAA,gBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,EACAC,WAAA,mBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,eACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,6DACAC,aAAA,oBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,eAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,EACAC,WAAA,mBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,cACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,4DACAC,aAAA,gBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,MACA,EACA,CACAX,GAAA,EACAC,WAAA,mBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,aACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,2DACAC,aAAA,oBACAC,OAAA,aACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,aAAA,EACAC,OAAA,MACA,EACA,CACAX,GAAA,EACAC,WAAA,mBACAC,QAAA,OACAC,SAAA,+BACArK,KAAA,mBACAsK,MAAA,wBACA7C,KAAA,aACA8C,QAAA,iEACAC,aAAA,gBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,EACAC,WAAA,mBACAC,QAAA,OACAC,SAAA,yBACArK,KAAA,YACAsK,MAAA,kBACA7C,KAAA,aACA8C,QAAA,0DACAC,aAAA,gBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,EACAC,WAAA,mBACAC,QAAA,OACAC,SAAA,gCACArK,KAAA,oBACAsK,MAAA,yBACA7C,KAAA,aACA8C,QAAA,gDACAC,aAAA,gBACAC,OAAA,aACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,aAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,+BACArK,KAAA,aACAsK,MAAA,wBACA7C,KAAA,aACA8C,QAAA,2CACAC,aAAA,gBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,eACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,iDACAC,aAAA,gBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,8BACArK,KAAA,mBACAsK,MAAA,uBACA7C,KAAA,aACA8C,QAAA,qDACAC,aAAA,gBACAC,OAAA,aACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,aAAA,EACAC,OAAA,MACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,6BACArK,KAAA,oBACAsK,MAAA,sBACA7C,KAAA,aACA8C,QAAA,6DACAC,aAAA,gBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,4BACArK,KAAA,gBACAsK,MAAA,qBACA7C,KAAA,aACA8C,QACA,0EACAC,aAAA,oBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,MACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,cACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,wDACAC,aAAA,oBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,eAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,4BACArK,KAAA,gBACAsK,MAAA,qBACA7C,KAAA,aACA8C,QACA,sEACAC,aAAA,gBACAC,OAAA,aACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,aAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,6BACArK,KAAA,oBACAsK,MAAA,sBACA7C,KAAA,aACA8C,QACA,yEACAC,aAAA,gBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,eAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,gBACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,gEACAC,aAAA,oBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,4BACArK,KAAA,gBACAsK,MAAA,qBACA7C,KAAA,aACA8C,QAAA,0DACAC,aAAA,oBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,0BACArK,KAAA,cACAsK,MAAA,mBACA7C,KAAA,aACA8C,QACA,oEACAC,aAAA,oBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,cACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,mEACAC,aAAA,gBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,6BACArK,KAAA,iBACAsK,MAAA,sBACA7C,KAAA,aACA8C,QAAA,iEACAC,aAAA,oBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,iBACAsK,MAAA,oBACA7C,KAAA,aACA8C,QACA,2EACAC,aAAA,oBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,mBACAsK,MAAA,oBACA7C,KAAA,aACA8C,QAAA,4DACAC,aAAA,oBACAC,OAAA,YACAC,MAAA,CAAAC,KAAA,UAAAC,KAAA,cAAA,EACAC,OAAA,MACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,4BACArK,KAAA,iBACAsK,MAAA,qBACA7C,KAAA,aACA8C,QAAA,0DACAC,aAAA,oBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,yBACArK,KAAA,cACAsK,MAAA,kBACA7C,KAAA,aACA8C,QAAA,2DACAC,aAAA,gBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,2BACArK,KAAA,iBACAsK,MAAA,oBACA7C,KAAA,aACA8C,QACA,sEACAC,aAAA,gBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,0BACArK,KAAA,eACAsK,MAAA,mBACA7C,KAAA,aACA8C,QAAA,8DACAC,aAAA,gBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,4BACArK,KAAA,iBACAsK,MAAA,qBACA7C,KAAA,aACA8C,QACA,0EACAC,aAAA,gBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,KACA,EACA,CACAX,GAAA,GACAC,WAAA,oBACAC,QAAA,OACAC,SAAA,6BACArK,KAAA,gBACAsK,MAAA,sBACA7C,KAAA,aACA8C,QAAA,mEACAC,aAAA,gBACAC,OAAA,UACAC,MAAA,CAAAC,KAAA,YAAAC,KAAA,YAAA,EACAC,OAAA,MACA,GAGAC,qBAAA,WACA,SAAAC,EAAAC,EAAAC,GACAD,EAAAC,SAAAA,EACAD,EAAAhJ,UAAAiJ,EAAA,MAAA,UAAA,UAAA,CACA,CAHA,IAQAC,EAgEAC,EAGAC,EAGAC,EACAC,EACAC,EACAC,EAEAC,EAiBAC,EACAC,EACAC,EAEAC,EACAC,EACAC,EAOAC,EA2CAC,EAkCAlG,EAzLAmG,EAAAhP,SAAAiP,eAAA,kBAAA,EAEAD,IACAhB,EAAA,CACAkB,KAAA,GACAC,WAAA,CACAC,KAAA,uDACA,EACAA,KAAA,SAAAC,GACA,IACAnC,EAUAmC,EAVAnC,QACAF,EASAqC,EATArC,GACAlK,EAQAuM,EARAvM,KACAsK,EAOAiC,EAPAjC,MACA7C,EAMA8E,EANA9E,KACA8C,EAKAgC,EALAhC,QACAC,EAIA+B,EAJA/B,aACAC,EAGA8B,EAHA9B,OACAC,EAEA6B,EAFA7B,MACAG,EACA0B,EADA1B,OAEA,MAAA,uPAAAzM,OAIAgM,EAAA,yEAAA,EAAAhM,OAGA4B,EAAA,iEAAA,EAAA5B,OAEAkM,EAAA,IAAA,EAAAlM,OAAAkM,EAAA,qFAAA,EAAAlM,OAGAqJ,EAAA,oGAAA,EAAArJ,OAGAmM,EAAA,2CAAA,EAAAnM,OACAoM,EAAA,8KAAA,EAAApM,OAGAsM,EAAAC,KAAA,sBAAA,EAAAvM,OACAqM,EAAA,sCAAA,EAAArM,OACAsM,EAAAE,KAAA,sKAAA,EAAAxM,OAIAyM,EAAA,gTAAA,EAAAzM,OAIA8L,EAAA,kUAAA,EAAA9L,OAGA8L,EAAA,ofAAA,CAYA,CACA,EACAiB,EAAAe,EAAA5D,cACA,+BACA,EACA8C,EAAAc,EAAA5D,cACA,+BACA,EACA+C,EAAAa,EAAA5D,cAAA,sBAAA,EACAgD,EAAAY,EAAA5D,cAAA,yBAAA,EACAiD,EAAAW,EAAA5D,cAAA,kBAAA,EACAkD,EAAAtO,SAAAoL,cAAA,oBAAA,GAEAmD,EAAA,IAAAlO,OAAAiP,KAAAN,EAAAhB,EAAAjB,MAAA,GAGAwC,GAAA,UAAA,SAAAH,GACA,IAAAI,EACAR,EAAA5D,cAAA,WAAA,GACApL,SAAAiP,eAAAjB,EAAAwB,QAAA,EAEAA,IACA,IAAAJ,EAAAK,cAAA/O,OACA8O,EAAA1K,UAAAM,OAAA,QAAA,EAEAoK,EAAA1K,UAAAI,IAAA,QAAA,EAGA,CAAA,EAEAsJ,EAAAD,EAAAmB,MAAAhP,OACA+N,EAAAF,EAAAW,KACAR,EACAH,EAAAoB,cAAAvE,cAAA,YAAA,EACAuD,EAAA9D,KAAA+E,KAAApB,EAAAC,CAAA,EACAG,EAAAL,EAAAsB,aAAAnP,OACAmO,EAAA,EAEAH,GACAA,EAAAxO,iBAAA,eAAA,WAAA,OACAqO,EAAAuB,YAAA,EAAA,CAAA,CACA,GAEAhB,EAAA,WACAT,IACAA,EAAA0B,UAAA,GAAA7O,OAAAqN,EAAArE,EAAA,MAAA,EAAAhJ,OAAA0N,EAAA,MAAA,EAAA1N,OAAAsN,CAAA,GACAN,GACAL,EAAAK,EAAA,IAAAW,CAAA,EACAZ,GACAJ,EACAI,EACAY,IAAAF,CACA,EAEA,EAAAE,GAAAA,EAAAF,IACAd,EAAAI,EAAA,CAAA,CAAA,EACAJ,EAAAK,EAAA,CAAA,CAAA,EAEA,GACA,EAEAD,GACAA,EAAA/N,iBAAA,QAAA,SAAAyB,GACAA,EAAAqO,eAAA,EACAnB,GAAA,EAEAoB,EAAA1B,EAAArE,EAAAuE,EACAwB,GAAA1B,EAAA2B,KAAA,GACA3B,EAAA4B,KAAAF,EAAAxB,CAAA,EACAG,GAAAL,EAAAsB,aAAAnP,OACAoO,EAAA,CACA,CAAA,EAGAZ,GACAA,EAAAhO,iBAAA,QAAA,SAAAyB,GACAA,EAAAqO,eAAA,EACAnB,EAAAA,EAEAD,GAAAL,EAAAsB,aAAAnP,OACA0P,EAAA7B,EAAArE,EAAAuE,EACA,EAAA2B,GAAA7B,EAAA4B,KAAAC,EAAA3B,CAAA,EACAK,EAAA,CACA,CAAA,EAGAC,EAAA,WACAX,EAAAtJ,UAAA2H,OAAA,QAAA,EACA0B,EAAArJ,UAAA2H,OAAA,QAAA,CACA,EAEA0B,GACAA,EAAAjO,iBAAA,QAAA,WACAqO,EAAA4B,KAAA,EAAA3B,CAAA,EAEAK,EADAF,EAAA,EAEAC,EAAAJ,EACAM,EAAA,EACAC,EAAA,CACA,CAAA,EAEAX,GACAA,EAAAlO,iBAAA,QAAA,WACAqO,EAAA4B,KAAA,EAAA1B,CAAA,EACAE,EAAA9D,KAAA+E,KAAApB,EAAAC,CAAA,EACAI,EAAA,EACAD,EAAAL,EAAAsB,aAAAnP,OACAoO,EAAA,EACAC,EAAA,CACA,CAAA,EAEAf,EAAAmB,YACAH,EAAA5D,cAAA,aAAA,EAAAlL,iBAAA,QAAA,SAAAyB,GACA,SAAAA,EAAA0O,OAAAvL,UAAA,KACA+J,EAAAyB,OAAA3O,EAAA0O,OAAAE,SAAA,EACAzB,EAAA,EAEA,CAAA,EAEAd,EAAA5G,UACAyB,EAAAmF,EAAA5G,OAAAyB,IACAyF,EAAApO,iBAAA,SAAA,SAAAyB,GACA4M,EAAAnH,OAAA,SAAAgI,GACA,MAAA,KAAAzN,EAAA0O,OAAAtL,OAGAqK,EACAC,OAAA,EACAxG,GAAAzH,YAAA,EACA4D,SAAArD,EAAA0O,OAAAtL,MAAA3D,YAAA,CAAA,CACA,CAAA,CACA,CAAA,EAGA,ECxnBAoP,QAAA,IAAAnQ,OAAAoQ,SCCAC,eDAAF,QAAAxC,QAAA,CACAN,KAAA,GACA,EACA8C,QAAAtL,IAAA,eAAA,ECHA,WAOA,SAAAyL,EAAArP,GAAA,IAAAsP,EAAA,EAAAlO,UAAAhC,QAAAiC,KAAAA,IAAAD,UAAA,GAAAA,UAAA,GAAA,EACA4C,EAAAhE,EAAAiE,sBAAA,EAEA,OACA,EAAAD,EAAAuL,QACAvL,EAAAM,IAAAgL,GACA,EAAAtL,EAAAwL,OACAxL,EAAAO,MAAAxF,OAAA8F,YAAAnG,SAAAgD,gBAAAoD,cACAd,EAAAM,KAAAvF,OAAA2F,aAAAhG,SAAAgD,gBAAAiD,aAEA,CAhBA,IAAA8K,EAAA/Q,SAAAgR,iBAAA,mBAAA,EACAC,EAAA,CACAjR,SAAAoL,cAAA,4CAAA,EACApL,SAAAoL,cAAA,oCAAA,GAeA2F,EAAArQ,QACAqQ,EAAAG,QAAA,SAAAC,GAEA,IAAAC,EAAApG,MAAA3J,QAAA8P,EAAA,YAAA,EAMAE,EAAAhR,OAAAU,EAAAuQ,MALA,CACAjB,OAAA,qBACAO,UAAA,EACAW,WAAA,IACA,EAGAH,CACA,EAHAf,EAAAgB,EAAAhB,OAAAO,EAAAS,EAAAT,UAAAW,EAAAF,EAAAE,WAMAC,EAAAxR,SAAAiP,eAAAoB,CAAA,EAgBAhQ,OAAAH,iBAAA,SAbA,WAEAG,OAAAoR,WAAA,eAAAvQ,OAAA8J,MAAAvE,YAAA8K,GAAA,KAAA,CAAA,EACAG,UAEAf,EAAAa,EAAAZ,CAAA,EAGA5F,MAAA/F,SAAAkM,EAAA,MAAA,EAFAnG,MAAA7F,YAAAgM,EAAA,MAAA,EAKA,CAEA,EAUAF,EAAAC,QACA,SAAAS,GAAA,OACAA,GACAA,EAAAzR,iBAAA,QAAA,WAVA8K,MAAApG,SAWA+M,EAXA,WAAA,EAEAhB,EAAAa,EAAAZ,CAAA,GACA5F,MAAA7F,YAAAgM,EAAA,MAAA,EAFAnG,MAAA/F,SAAAkM,EAAA,MAAA,CAUA,CACA,CAAA,CACA,CACA,CAAA,CAEA,GCnEAS,WAAA,IAAAC,IAEAC,WAAA,WACA,SAAAA,EAAAC,EAAAC,GAAA3F,gBAAAC,KAAAwF,CAAA,EACAxF,KAAAyF,QAAAA,EACAzF,KAAA0F,OAAAC,cAAA,CACAC,qBAAA,QAAA,EACAF,CAAA,EAEAJ,WAAAO,IAAA7F,KAAAyF,QAAAzF,IAAA,CACA,CAQA,OANAC,aAAAuF,EAAA,CAAA,CAAAjJ,IAAA,OAAA9D,MAQA,WACAuH,KAAA8F,YAAA,EACA9F,KAAA+F,kBAAA,EACA/F,KAAAgG,iBAAA,CACA,CAAA,EAAA,CAAAzJ,IAAA,kBAAA9D,MAEA,WACA,OAAAvE,MAAAwJ,KAAAsC,KAAAiG,cAAA,EACAnL,OAAA,SAAAoL,GAAA,OAAAA,EAAAC,OAAA,CAAA,EACAC,IAAA,SAAAF,GAAA,OAAAxH,MAAA3J,QAAAmR,EAAA,iBAAA,CAAA,CAAA,CACA,CAAA,EAAA,CAAA3J,IAAA,cAAA9D,MAEA,WACA,IAAA4N,EAAA3H,MAAA3J,QACAiL,KAAAyF,QACA,aACA,EAHAa,EAAAD,EAAAC,KAAAC,EAAAF,EAAAE,QAAAC,EAAAH,EAAAG,gBAIAxG,KAAAuG,QAAA,IAAA1G,QAAAnM,SAAAiP,eAAA4D,CAAA,CAAA,EACAvG,KAAAwG,gBAAA,IAAA3G,QACAnM,SAAAiP,eAAA6D,CAAA,CACA,EACAxG,KAAAiG,eAAAvS,SACAiP,eAAA2D,CAAA,EACA5B,iBAAA,wBAAA,CACA,CAAA,EAAA,CAAAnI,IAAA,iBAAA9D,MAEA,SAAAgO,GACAzG,KAAAiG,eAAAQ,CACA,CAAA,EAAA,CAAAlK,IAAA,oBAAA9D,MAEA,WAAA,IAAAiO,EAAA1G,KAEAA,KAAAyF,QAAA7R,iBAAA,QAAA,WACA,kBAAA8S,EAAAjB,QAAAkB,eACAD,EAAAH,QAAA5N,SAAA+N,EAAAhB,OAAAE,oBAAA,EACAc,EAAAF,gBAAA3N,YAAA6N,EAAAhB,OAAAE,oBAAA,EAEAc,EAAAE,gBAAA,EAEAF,EAAAT,eAAArB,QAAA,SAAA5P,GACA6R,EAAA,IAAAhH,QAAA7K,CAAA,EACA6R,EAAAC,QAAA,UAAA,CAAA,CAAA,EACAD,EAAAxG,aAAA,UAAA,CAAA,CAAA,CACA,CAAA,IAIAqG,EAAAK,cAAA,EACAL,EAAAT,eAAArB,QAAA,SAAA5P,GAEAA,EAAAmR,QAAAO,EAAAjB,QAAAU,OACA,CAAA,EACA,CAAA,CACA,CAAA,EAAA,CAAA5J,IAAA,mBAAA9D,MAEA,WAAA,IAAAuO,EAAAhH,KAEAA,KAAAiG,eAAArB,QAAA,SAAA5P,GACA,IAAA6K,QAAA7K,CAAA,EACAiO,GAAA,QAAA,WACA,kBAAA+D,EAAAvB,QAAAkB,gBACAK,EAAAvB,QAAAkB,cAAA,CAAA,EACAK,EAAAvB,QAAApF,aAAA,gBAAA,eAAA,EACA2G,EAAAvB,QAAAU,QAAA,CAAA,EACAa,EAAAvB,QAAApF,aAAA,UAAA,CAAA,CAAA,EAEA2G,EAAAT,QAAA1N,YAAAmO,EAAAtB,OAAAE,oBAAA,EACAoB,EAAAR,gBAAA7N,SAAAqO,EAAAtB,OAAAE,oBAAA,GAGAqB,mBAAAD,EAAAf,cAAA,EAAAiB,MAAA,SAAAzB,GAAA,OAAAA,EAAAU,OAAA,CAAA,IACAa,EAAAvB,QAAAkB,cAAA,CAAA,EACAK,EAAAvB,QAAApF,aAAA,gBAAA,CAAA,CAAA,GAGA4G,mBAAAD,EAAAf,cAAA,EAAAiB,MAAA,SAAAzB,GAAA,MAAA,CAAAA,EAAAU,OAAA,CAAA,IACAa,EAAAJ,gBAAA,EACAI,EAAAD,cAAA,EAEA,CAAA,CACA,CAAA,CACA,CAAA,EAAA,CAAAxK,IAAA,kBAAA9D,MAEA,WACAuH,KAAAyF,QAAAkB,cAAA,CAAA,EACA3G,KAAAyF,QAAAnF,gBAAA,eAAA,EACAN,KAAAyF,QAAAU,QAAA,CAAA,EACAnG,KAAAyF,QAAApF,aAAA,UAAA,CAAA,CAAA,CACA,CAAA,EAAA,CAAA9D,IAAA,gBAAA9D,MAEA,WACAuH,KAAAuG,QAAAY,YAAAnH,KAAA0F,OAAAE,oBAAA,EACA5F,KAAAwG,gBAAAW,YAAAnH,KAAA0F,OAAAE,oBAAA,CACA,CAAA,GAAA,CAAA,CAAArJ,IAAA,cAAA9D,MApGA,SAAAgN,GACA,OAAAH,WAAA8B,IAAA3B,CAAA,EACAH,WAAA+B,IAAA5B,CAAA,EAEA,IACA,CAAA,EAAA,EAAAD,CAAA,EAAA,EAkGA,SAAA8B,iBACA,IAAAC,EAAA7T,SAAAgR,iBAAA,mBAAA,EAEA6C,EAAAnT,QACAmT,EAAA3C,QAAA,SAAA5P,GACA,IAAAwQ,WAAAxQ,CAAA,EACAwS,KAAA,CACA,CAAA,CAEA,CAIAzT,OAAAyR,WAAAA,WCnIA,IAAAiC,SAAA,WAyCA,SAAAC,EAAAC,GACAA,IACAA,EACAvO,UAAAuO,EAAAC,aAEA,CA7CA,IAAAC,EACA,QADAA,EAEA,eAFAA,EAGA,QAIAC,EACA,gBADAA,EAEA,gBAFAA,EAGA,4BAHAA,EAKA,mDALAA,EAMA,sCANAA,EAOA,YAPAA,EASA,iBATAA,EAUA,qBAVAA,EAWA,sBAGAC,EACA,iBADAA,EAEA,eAFAA,EAGA,OAGAC,EACA,QAGAC,EAAAvU,SAAAoL,cAAAgJ,CAAA,EACAI,EAAAxU,SAAAgR,iBAAAoD,CAAA,EACAK,EAAAzU,SAAAoL,cAAAgJ,CAAA,EACAM,EAAA1U,SAAAoL,cAAAgJ,CAAA,EACAO,EAAA3U,SAAAoL,cACAgJ,CACA,EAUAjU,WAAA,WACA6T,EAAAW,CAAA,CACA,EAAA,GAAA,EAEA3U,SAAAgR,iBAAAoD,CAAA,EAAAlD,QAAA,SAAA5P,GACAA,EAAApB,iBAAAiU,EAAA,SAAAxS,GACA,IAAAiT,EAAAjT,EAAAkT,cACAD,EAAA9P,UAAAI,IAAA,QAAA,EAEA7E,OAAA8F,WAAA,KACA,CAAAxE,EAAA0O,OAAAvL,UAAA4H,SAAA,eAAA,IACA6H,EAAAO,MAAAjP,KAAA,SAGA+O,EAAA9P,UAAA4H,SAAA2H,CAAA,GACAO,EAAA9P,UAAAM,OAAAiP,CAAA,CACA,CAAA,CACA,CAAA,EAEAG,EAAAtD,QAAA,SAAA5P,GACAA,EAAApB,iBAAAiU,EAAA,WACAM,EAAA1E,UAAA,GACA2E,EAAA5P,UAAAM,OAAAiP,CAAA,EACA,IAAAU,EAAA/U,SAAAoL,cACAgJ,CACA,EACAJ,EAAAe,CAAA,CACA,CAAA,CACA,CAAA,EAIAN,IACAA,EAAA9H,aAAA,cAAA,mBAAA,EACA8H,EAAAvU,iBAAAiU,EAAA,SAAAxS,GACAA,EAAA0O,OAAA2E,YAAAtU,QAAA,GACAgU,EAAA5P,UAAAM,OAAAiP,CAAA,EACA,SAAA1S,EAAA0O,OAAAN,YACApO,EAAA0O,OAAAN,UAAA,KAGA2E,EAAA5P,UAAAI,IAAAmP,CAAA,EAGAU,EAAA/U,SAAAoL,cACAgJ,CACA,EACAJ,EAAAe,CAAA,CACA,CAAA,GAGAN,GACAzU,SAAAgR,iBAAAoD,CAAA,EAAAlD,QAAA,SAAA5P,GACAA,EAAApB,iBAAAiU,EAAA,SAAAxS,GACAiT,EAAAjT,EAAAkT,cACAI,EAAAjK,MAAA3J,QAAAuT,EAAAN,CAAA,EACAtU,SAAAoL,cAAA,GAAAlK,OACAkT,EAAA,QAAA,EAAAlT,OAAAoT,EAAA,IAAA,EAAApT,OAAA+T,EAAA,IAAA,CACA,EACAnQ,UAAA2H,OAAA4H,CAAA,CACA,CAAA,CACA,CAAA,EAGArU,SAAAgR,iBAAAoD,CAAA,EAAAlD,QAAA,SAAA5P,GACAA,EAAApB,iBAAAiU,EAAA,WACAI,EAAAO,MAAAjP,KAAA,CACA,CAAA,CACA,CAAA,EAGAmF,MAAA5K,OAAA,WACA,IAAA2U,EAAA/U,SAAAoL,cACAgJ,CACA,EACAJ,EAAAe,CAAA,CACA,CAAA,CACA,EC7HAG,YAAA,WACA7U,OAAA8U,SACAnV,SAAAgR,iBAAA,YAAA,EACAE,QAAA,SAAA9B,GACA,IAAAgG,EAAApK,MAAA3J,QAAA+N,EAAA,SAAA,EACAiG,EAAA,IAAAhV,OAAA8U,QAAA/F,EAAA6C,cAAA,CACAqD,eAAA,EAAA,EACAF,CAAA,CACA,EAqDA,OAnDApV,SAAAgR,iBAAA,mBAAA,EAEAE,QAAA,SAAAqE,GACA,SAAAC,IACAD,EAAAvE,iBAAA,UAAA,EAAAE,QAAA,SAAAuE,GACA,IAAAC,EAAAD,EAAArK,cACA,wBACA,EACAuK,EAAAF,EAAArK,cACA,0BACA,EAEAqK,EAAArK,cAAA,YAAA,IACAsK,IAIA,MAFA,OAAAE,EAAAF,EACAtK,cAAA,4BAAA,GAAA,KAAA,EADAwK,EAEAC,aAAA,YAAA,IAEAJ,EAAA3Q,UAAAM,OAAA,SAAA,EACAqQ,EAAA3Q,UAAAI,IAAA,OAAA,IAEAuQ,EAAA3Q,UAAAM,OAAA,OAAA,EACAqQ,EAAA3Q,UAAAI,IAAA,SAAA,IAIAyQ,KACAF,EAAAK,qBAAA,QAAA,EAAApV,QACA+U,EAAA3Q,UAAAM,OAAA,SAAA,EACAqQ,EAAA3Q,UAAAI,IAAA,OAAA,IAEAuQ,EAAA3Q,UAAAM,OAAA,OAAA,EACAqQ,EAAA3Q,UAAAI,IAAA,SAAA,GAMA,CAAA,CACA,CAEAqQ,EAAArV,iBAAA,SAAA,WACAsV,EAAA,CACA,CAAA,EAEApG,EAAAlP,iBAAA,SAAA,WACAsV,EAAA,CACA,CAAA,CACA,CAAA,EAEAH,CACA,CAAA,CAEA,EChEAU,iBAAA,WACA,IAAA3B,EACA,UADAA,EAEA,4BAGAD,EACA,QADAA,EAEA,kBAGA6B,EACA,UAGAC,EACA,OAGAC,EAAAlW,SAAAgR,iBAAAoD,CAAA,EACA+B,EAAA,CAAA,EAmCAC,GAlCAF,EAAAhF,QAAA,SAAA9B,GACA,IAAAiH,EAAA,IAAAhW,OAAAiW,UAAAC,MAAAnH,CAAA,EACApB,EAAAiE,cAAA,CACAuE,SAAA,CAAA,EACAC,cAAA,EACAC,SAAA,CAAA,EACAC,iBAAA,IAAA,EACA3L,MAAA3J,QAAA+N,EAAA4G,CAAA,CAAA,EAEAU,EAAA1I,EAAA0I,SAAAF,EAAAxI,EAAAwI,SAAAC,EAAAzI,EAAAyI,cAEAC,IACAE,EAAA5L,MAAAjD,UAAA,QAAA,EACAoO,EAAA,OAAAS,GAGAJ,GAAAL,GACAhW,WAAA,WACAkW,EAAAlG,KAAA,CACA,EAAAsG,CAAA,EAGArH,EAAAlP,iBAAAiU,EAAA,SAAAxS,GACAL,EAAAK,EAAAkT,cACAgC,EAAA5E,cAAA,CACA0E,iBAAA,KACAD,SAAA,CAAA,CAAA,EACA1L,MAAA3J,QAAAC,EAAA0U,CAAA,CAAA,EAEAa,EAAAH,UACA1L,MAAAzD,UAAA,SAAA,CAAA,EAAAsP,EAAAF,gBAAA,CACA,CAAA,CACA,CAAA,EAEA3W,SAAAoL,cAAAgJ,CAAA,GACAgC,GACAA,EAAAlW,iBAAAiU,EAAA,SAAA2C,GAAA,IACA9J,EADA8J,EAAAjC,cACAgB,aAAA,MAAA,EACAQ,EAAA,IAAAhW,OAAAiW,UAAAC,MAAAvW,SAAAoL,cAAA4B,CAAA,CAAA,EAGA1L,EAAA+U,EAAAU,SACA/L,MAAApG,SAAAtD,EAAA2U,CAAA,EAAAI,EAAAlG,KAAA,EAAAkG,EAAAW,KAAA,CACA,CAAA,CACA,EChEAC,SAAA,WACA,IAAAC,EAAAlX,SAAAiP,eAAA,eAAA,EAOAkI,GANAD,GACAA,EAAAhX,iBAAA,iBAAA,WACAF,SAAAoL,cAAA,kBAAA,EACAgM,OAAA,CACA,CAAA,EAEApX,SAAAgR,iBAAA,aAAA,GACAmG,GACAA,EAAAjG,QAAA,SAAApD,GACA,IAAAuJ,EAAA,IAAAhX,OAAAiW,UAAAgB,QAAAxJ,CAAA,EAEAA,EAAA5N,iBAAA,YAAA,WAAA,OAAAmX,EAAAlH,KAAA,CAAA,CAAA,EACArC,EAAA5N,iBAAA,aAAA,WAAA,OAAAmX,EAAAL,KAAA,CAAA,CAAA,EAEAlJ,EAAA5N,iBAAA,QAAA,SAAAyB,GACAA,EAAA4V,gBAAA,EACAjW,EAAAK,EAAA0O,OACA/O,EAAAqL,aAAA,sBAAA,QAAA,EACA0K,EAAAlH,KAAA,EACA7O,EAAAqL,aAAA,sBAAA,mBAAA,EACA0K,EAAAG,OAAA,EACAC,EAAAzM,MAAA3J,QAAAC,EAAA,MAAA,EACAtB,SAAAoL,cAAAqM,CAAA,EACAL,OAAA,EACApX,SAAA0X,YAAA,MAAA,CACA,CAAA,CACA,CAAA,CACA,EC7BAC,YAAA,WACAtX,OAAAuX,SACA5X,SAAAgR,iBAAA,gBAAA,EACAE,QAAA,SAAA9E,GACA,IAAAyL,EAAA7M,MAAA3J,QAAA+K,EAAA,SAAA,EAAA0L,EAAAD,EAAAC,SAAA9J,EAAA+J,yBAAAF,EAAAG,SAAA,EACAJ,EAAA,IAAAvX,OAAAuX,QAAAK,QAAA7L,EAAA0L,EAAA7F,cAAA,CACA5H,SAAA,CAAA,EACA2D,CAAA,CACA,EACA4J,EAAAM,MAGAC,QAAAD,MAAAN,EAAAM,KAAA,EAFAN,EAAAQ,MAAA,CAIA,CAAA,CAEA,ECnBAC,eAAA,WACA,IACAC,EAEAC,EACAC,EAJAnY,OAAAoY,SAGAF,GAFAD,EAAAjY,OAAAoY,QAEA,aAAA,EACAD,EAAA,SAAAE,GACAA,EAAAC,KAAA,aAAA,EAAA1T,SAAA,eAAA,CACA,EACAsT,EAAA7X,SACA6X,EAAAK,KAAA,SAAAC,EAAA9T,GACA,IAAA6P,EAAA0D,EAAAvT,CAAA,EACAiJ,EAAAsK,EAAAQ,OACA,CACA/V,IACA,yMAGA,EACA6R,EAAArT,KAAA,SAAA,CACA,EAEAwX,GADAnE,EAAAoE,UAAAhL,CAAA,EACA4G,EAAAqE,QAAA,qBAAA,GACAT,EAAAO,CAAA,EACAnE,EAAArF,GAAA,UAAA,WAAA,OAAAiJ,EAAAO,CAAA,CAAA,CAAA,CACA,CAAA,CAEA,ECvBAG,cAAA,WACA,IAAAC,EACA,OADAA,EAEA,oBAFAA,EAGA,iBAHAA,EAIA,0BAJAA,EAKA,eALAA,EAMA,iBAGAhF,EACA,aADAA,EAEA,YAGA8B,EACA,aAGAmD,EAAApZ,SAAAgR,iBAAAmI,CAAA,EACAE,EAAArZ,SAAAgR,iBACAmI,CACA,EACAG,EAAAtZ,SAAAoL,cAAA+N,CAAA,EAEAE,EAAA3Y,UAEA6Y,EAAA,IAAAlZ,OAAAmZ,UAAAC,SAAAJ,EAAA,CACAK,UAAAP,EACAQ,MAAA,IACAC,OAAA,CACAC,SAAAV,EACAW,oBAAA,CAAA,CACA,EACAC,WAAA,CACAL,UAAAP,EACAa,mBAAA,GAAA9Y,OAAAqS,mBAAA8F,CAAA,EAAA,CAAAC,EAAA,CACA,CACA,CAAA,GAGA/J,GAAA4E,EAAA,WACAiF,EAAAlI,QAAA,SAAA+I,GACAjP,MAAApG,SAAAqV,EAAAhE,CAAA,GACAgE,EAAAnV,UAAAM,OAAA6Q,CAAA,CACA,CAAA,CACA,CAAA,EAGAsD,EAAAhK,GAAA4E,EAAA,SAAA+F,GAAA,IAAA5Y,EAAA4Y,EAAA3Y,KAAA4Y,OACAC,EAAA9Y,EAAA2X,QAAAE,CAAA,EACAkB,EAAAD,EAAAhP,cAAA+N,CAAA,EAEA7X,EAAAgZ,oBAAAF,EAAAG,YAAAF,CAAA,CACA,CAAA,EAEA,EC3DAG,iBAAA,WAEA,IACAC,EAAAA,EADApa,OAAA6K,GAAAO,IAAA,IACAgP,EACA,oBADAA,EAEA,qBAMAza,SAAAgR,iBAHA,mBAGA,EAAAE,QAAA,SAAAlC,GACAA,EAAA9O,iBAAAua,EAAA,SAAA9Y,GACA,IAAA+Y,EAAA/Y,EAAAkT,cACA6F,EAAAC,YAAAD,EAAAtU,cACAsU,EAAA5F,MAAA8F,cAAA,GAAA1Z,OAAAS,EAAA0O,OAAAiK,mBAAArU,aAAA,IAAA,EAEA,CAAA,EACA+I,EAAA9O,iBAAAua,EAAA,SAAA9Y,GACAA,EAAAkT,cAAAC,MAAA8F,cAAA,EACA,CAAA,CACA,CAAA,EAEA,ECtBAC,gBAAA,WACA,IAAAC,EAAA9a,SAAAoL,cAAA,0BAAA,EAEA0P,GACAA,EAAA5a,iBAAA,YAAA,SAAAyB,GACA,IAIAoZ,EAHApZ,EAAA0O,OAAAxL,UAAAG,SAAA,iBAAA,GACA,IAAA3E,OAAA8F,cAEA4U,EAAA,IAAA1a,OAAAiW,UAAA0E,SAAArZ,EAAA0O,MAAA,GAGA0G,SAAAjS,UAAAI,IAAA,MAAA,EACA6V,EAAAE,MAAAnW,UAAAI,IAAA,MAAA,EACA6V,EAAAE,MAAAtO,aAAA,iBAAA,MAAA,EAEAhL,EAAA0O,OAAA6K,WAAAhb,iBAAA,aAAA,WACA6a,EAAA/D,KAAA,CACA,CAAA,EAEA,CAAA,CAEA,ECjBAmE,cAFA9a,OAAA+a,WAAA/a,OAAA+a,SAAAC,aAAA,CAAA,GAEA,WACA,IAAA/J,EAAAjR,OAAAU,EAAAuQ,MAEA8C,EACA,kBADAA,EAGA,cAHAA,EAKA,gCAGAC,EACA,qBADAA,EAEA,mBAFAA,EAIA,gBAGAC,EACA,UAGAH,EACA,YADAA,EAEA,cAFAA,EAGA,WAGAmH,EAAAtb,SAAAgR,iBAAAoD,CAAA,EAEAkH,EAAA5a,QACA4a,EAAApK,QAAA,SAAA9B,GACA,IAAAgG,EAAApK,MAAA3J,QAAA+N,EAAAkF,CAAA,EAEA/S,GAAA6T,EADAA,GAAA,IACA7T,MAAA,GACAyM,EAAAsD,EACA,CACAiK,IAAA,eACAC,eAAA,CAAA,EACAC,kBAAArM,EAAAhE,cAAAgJ,CAAA,EACAsH,gBAAAtM,EAAAhE,cAAAgJ,CAAA,EAAArE,UACA4L,eAAA,KACAC,gBAAA,KACAC,YAAA,GACAC,iBAAA,CAAA,EACAC,aAAA,IACAjI,KAAA,WACA,IAAAkI,EAAA1P,KAEA/K,EAAAb,QACAa,EAAA2P,QAAA,SAAAjH,GACA,IAAAgS,EAAA,CAAAnZ,KAAAmH,EAAAnH,KAAAoN,KAAAjG,EAAAiG,IAAA,EACA8L,EAAAhO,QAAAkO,UAAAC,KAAAH,EAAAC,CAAA,EACAD,EAAAhO,QAAAoO,UAAAD,KAAAH,EAAAC,EAAA,GAAA/a,OAAA+I,EAAAsR,IAAA,GAAA,EAAAra,OAAA+I,EAAAnH,IAAA,CAAA,CACA,CAAA,EAGAkZ,EAAAzM,GAAA4E,EAAA,WACA,aAAAiB,IAEA,IAAAA,EAAAiH,UACA,EAAAjN,EAAA4B,iBAAAoD,CAAA,EAAA1T,QAEA0O,EAAAhE,cAAAgJ,CAAA,EAAAhP,OAAA,EAEA,IAAAgQ,EAAAiH,WAAA,EAAA/P,KAAAgQ,MAAA5b,QACA4L,KAAAiQ,WAAAjQ,KAAAgQ,MAAA,EAAA,CAGA,CAAA,CACA,EACApE,MAAA,SAAAsE,EAAAC,GACA,GAAAD,EAAAE,eAAA,CACAF,EAAAE,eAAA5X,UAAAI,IAAA,UAAA,EACA,UAAA,OAAAuX,GAAAA,EAAAvE,QACAuE,EAAAA,EAAAvE,OACA,IACAyE,EADAC,EAAAC,2BACAL,EAAAE,eAAA1L,iBAAA,wBAAA,CAAA,EAAA,IAAA,IAAA4L,EAAAE,EAAA,EAAA,EAAAH,EAAAC,EAAAG,EAAA,GAAAC,MAAAL,EAAA5X,MACAiQ,YAAAyH,CACA,CAAA,MAAAQ,GAAAL,EAAAjb,EAAAsb,CAAA,CAAA,CAAA,QAAAL,EAAAM,EAAA,CAAA,CACA,CACA,CACA,EACA9H,CACA,EAIA+H,GAFA/N,EAAAhE,cAAAgJ,CAAA,EAAArE,UAAA,GAEA,IAAA1P,OAAA+a,SAAAhM,EAAApB,CAAA,GAEAmP,EAAA5N,GAAA4E,EAAA,WACA/E,EAAAhE,cAAAgJ,CAAA,GACAhF,EACAhE,cAAAgJ,CAAA,EACAtP,UAAAM,OAAAiP,CAAA,EAEAjF,EAAAtK,UAAAI,IAAAmP,CAAA,CACA,CAAA,EACA8I,EAAA5N,GAAA4E,EAAA,WACA/E,EAAAhE,cAAAgJ,CAAA,GACAhF,EAAAhE,cAAAgJ,CAAA,EAAAtP,UAAAM,OAAAiP,CAAA,EAEAjF,EAAAtK,UAAAI,IAAAmP,CAAA,CACA,CAAA,EACA8I,EAAA5N,GAAA4E,EAAA,WACA/E,EAAAhE,cAAAgJ,CAAA,GACAhF,EAAAhE,cAAAgJ,CAAA,EAAAtP,UAAAM,OAAAiP,CAAA,EAGAjF,EAAAtK,UAAAI,IAAAmP,CAAA,CACA,CAAA,CACA,CAAA,CACA,GCrHA+I,mBAAA,WAIA,IAAAC,EAAArd,SAAAgR,iBAAA,mBAAA,EAGAxQ,MAAA8c,UAAAC,MAAApB,KAAAkB,CAAA,EAAAnM,QAAA,SAAAmJ,GACAA,EAAAna,iBACA,SACA,SAAA2M,GACAwN,EAAAmD,cAAA,IACA3Q,EAAAmD,eAAA,EACAnD,EAAA0K,gBAAA,GAGA8C,EAAAvV,UAAAI,IAAA,eAAA,CACA,EACA,CAAA,CACA,CACA,CAAA,CACA,ECnBAoM,MAAAjR,OAAAU,EAAAuQ,MAEAmM,eAAA,SAAAnc,EAAA0Q,GAAA,IACAhE,EAAAsD,MACA,CACAoM,YAAA,eACAC,SAAA,CAAA,EACAC,UAAA5d,SAAAoL,cAAA,MAAA,EAAAyK,aAAA,KAAA,EACAgI,cAAA,CACAhY,KAAA,kBACAiY,OAAA,QACAhN,MAAA,uCACA,EACAiN,WAAA,CACAC,MAAA,QACAC,KAAA,OACAC,IAAA,KACA,CACA,EACAlM,CACA,EACAmM,EAAA,IAAA9d,OAAA+d,aAAAC,SAAA/c,EAAA0M,CAAA,EAKA,OAJAmQ,EAAAG,OAAA,EACA,OAAAC,EAAAve,SACAoL,cAAA,yBAAA,IADAmT,EAEAre,iBAAA,yBAAA,WAAA,OAAAie,EAAAK,WAAA,CAAA,CAAA,EACAL,CACA,EAEAM,iBAAA,WACAze,SAAAgR,iBAAA,iBAAA,EACAE,QAAA,SAAA9B,GACA,IAAApB,EAAAhD,MAAA3J,QAAA+N,EAAA,UAAA,EACAqO,eAAArO,EAAApB,CAAA,CACA,CAAA,CACA,EAEA0Q,aAAA,CACAjB,eAAAA,eACAgB,iBAAAA,gBACA,EC1CAE,cAAA,WACAte,OAAAue,WACAve,OAAAue,UAAA,CACAC,SAAA,gBACA,CAAA,CAEA,ECLA,SAAAC,UACA,IAKAC,EALAC,EAAAhf,SAAA4S,KACAqM,EAAAjf,SAAAgR,iBAAA,YAAA,EAEAiO,EAAAve,QAAAL,OAAA6e,SAEAH,EAAA,CACAI,QAAA,CACA,CACAC,YAAA,QACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,YACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,eACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,eACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EAAA,CAAAC,OAAA,EAAA,EACA,EACA,CACAJ,YAAA,gBACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,aACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,MACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,WACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAF,YAAA,qBACAC,QAAA,CACA,CAAAG,WAAA,IAAA,EACA,CAAAhd,MAAA,SAAA,EACA,CAAA8c,UAAA,EAAA,EAEA,EACA,CACAF,YAAA,mBACAC,QAAA,CACA,CAAAI,WAAA,EAAA,EACA,CAAAjd,MAAA,SAAA,EACA,CAAA8c,UAAA,EAAA,EAEA,EACA,CAAAF,YAAA,cAAAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EAAA,EACA,CACAL,YAAA,UACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,iBACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,iBACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EAAA,CAAAC,OAAA,GAAA,EACA,GAEAG,KAAA,CACA,CACAP,YAAA,MACAC,YAAA,mBACAC,QAAA,CACA,CAAAI,WAAA,EAAA,EACA,CAAAjd,MAAA,SAAA,EACA,CAAA8c,UAAA,EAAA,EAEA,EACA,CACAH,YAAA,MACAC,YAAA,qBACAC,QAAA,CACA,CAAAG,WAAA,IAAA,EACA,CAAAhd,MAAA,SAAA,EACA,CAAA8c,UAAA,EAAA,EAEA,EACA,CACAH,YAAA,MACAC,YAAA,cACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,iBACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,iBACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EAAA,CAAAC,OAAA,GAAA,EACA,EACA,CACAJ,YAAA,YACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,MACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,eACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,eACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EAAA,CAAAC,OAAA,EAAA,EACA,EACA,CACAJ,YAAA,gBACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,aACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,UACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,QACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,GAEAK,SAAA,CACA,CACAR,YAAA,MACAC,YAAA,mBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,MACAC,YAAA,qBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,iBACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,iBACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EAAA,CAAAC,OAAA,GAAA,EACA,EACA,CACAJ,YAAA,YACAC,YAAA,MACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,MACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,CAAA,EACA,EACA,CACAH,YAAA,eACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,eACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,gBACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,gBACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,aACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,UACAC,YAAA,MACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,QACAC,YAAA,MACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,GAEAod,OAAA,CACA,CACAT,YAAA,QACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,EAAA,EACA,CAAAH,UAAA,CAAA,EAAA,EACA,CAAAE,WAAA,IAAA,EAEA,EACA,CACAL,YAAA,YACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EAAA,EACA,CAAAH,UAAA,CAAA,EAAA,EACA,CAAAE,WAAA,IAAA,EAEA,EACA,CACAL,YAAA,qBACAC,YAAA,MACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,CAAA,EACA,CAAAH,UAAA,CAAA,CAAA,EACA,CAAAE,WAAA,IAAA,EAEA,EACA,CACAL,YAAA,OACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EAAA,EACA,CAAAH,UAAA,CAAA,EAAA,EACA,CAAAE,WAAA,IAAA,EAEA,EACA,CACAL,YAAA,eACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EAAA,EACA,CAAAH,UAAA,EAAA,EACA,CAAAE,WAAA,YAAA,EAEA,EACA,CACAL,YAAA,gBACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EAAA,EACA,CAAAH,UAAA,CAAA,CAAA,EACA,CAAAE,WAAA,YAAA,EAEA,EACA,CACAL,YAAA,aACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EAAA,EACA,CAAAH,UAAA,CAAA,EAAA,EACA,CAAAE,WAAA,IAAA,EAEA,EACA,CACAL,YAAA,MACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,EAAA,EACA,CAAAH,UAAA,CAAA,EAAA,EACA,CAAAE,WAAA,IAAA,EAEA,EACA,CACAL,YAAA,WACAC,YAAA,MACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EAAA,EACA,CAAAH,UAAA,CAAA,EAAA,EACA,CAAAE,WAAA,IAAA,EAEA,EACA,CACAL,YAAA,UACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,EAAA,EACA,CAAAH,UAAA,CAAA,EAAA,EACA,CAAAE,WAAA,YAAA,EAEA,EACA,CACAL,YAAA,0BACAC,YAAA,MACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EACA,CAAAH,UAAA,GAAA,EACA,CAAAE,WAAA,YAAA,EAEA,EACA,CACAL,YAAA,8BACAC,YAAA,MACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EACA,CAAAH,UAAA,GAAA,EACA,CAAAE,WAAA,KAAA,EAEA,EACA,CACAL,YAAA,0BACAC,YAAA,SACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EACA,CAAAH,UAAA,GAAA,EACA,CAAAE,WAAA,KAAA,EAEA,EACA,CACAL,YAAA,6BACAC,YAAA,MACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EACA,CAAAH,UAAA,GAAA,EACA,CAAAE,WAAA,KAAA,EAEA,EACA,CACAL,YAAA,iBACAC,YAAA,MACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,CAAA,EACA,CAAAH,UAAA,CAAA,EAAA,EACA,CAAAE,WAAA,KAAA,EAEA,EACA,CACAL,YAAA,cACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAJ,WAAA,EAAA,EACA,CAAAH,UAAA,CAAA,EAAA,EACA,CAAAE,WAAA,IAAA,EAEA,GAEAM,MAAA,CACA,CACAX,YAAA,eACAC,YAAA,cACAC,QAAA,CAAA,CAAAG,WAAA,IAAA,EAAA,CAAAhd,MAAA,SAAA,EACA,GAEAud,eAAA,CACA,CACAZ,YAAA,MACAC,YAAA,MACAC,QAAA,CAAA,CAAAG,WAAA,IAAA,EACA,EACA,CACAL,YAAA,MACAC,YAAA,SACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EAAA,CAAAC,WAAA,MAAA,EACA,EACA,CACAN,YAAA,MACAC,YAAA,mBACAC,QAAA,CACA,CAAAI,WAAA,EAAA,EACA,CAAAjd,MAAA,SAAA,EACA,CAAA8c,UAAA,EAAA,EACA,CAAAE,WAAA,KAAA,EAEA,EACA,CACAL,YAAA,MACAC,YAAA,qBACAC,QAAA,CACA,CAAAG,WAAA,KAAA,EACA,CAAAhd,MAAA,SAAA,EACA,CAAA8c,UAAA,EAAA,EAEA,EACA,CACAH,YAAA,MACAC,YAAA,cACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,iBACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,iBACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EAAA,CAAAC,OAAA,GAAA,EACA,EACA,CACAJ,YAAA,YACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,YACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,YACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,oBACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,MACAC,YAAA,WACAC,QAAA,CAAA,CAAAC,UAAA,EAAA,EACA,EACA,CACAH,YAAA,MACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,MACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,OACAC,YAAA,WACAC,QAAA,CAAA,CAAAG,WAAA,IAAA,EAAA,CAAAhd,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,OACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,eACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,eACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EAAA,CAAAC,OAAA,EAAA,EACA,EACA,CACAJ,YAAA,gBACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,gBACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,gBACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,aACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,aACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,aACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,UACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,QACAC,YAAA,MACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAAgd,WAAA,IAAA,EACA,EACA,CACAL,YAAA,QACAC,YAAA,WACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAA8c,UAAA,EAAA,EACA,EACA,CACAH,YAAA,QACAC,YAAA,gBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,QACAC,YAAA,kBACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,QACAC,YAAA,SACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,QACAC,YAAA,cACAC,QAAA,CAAA,CAAAG,WAAA,MAAA,EACA,EACA,CACAL,YAAA,QACAC,YAAA,mBACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,QACAC,YAAA,qBACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,QACAC,YAAA,cACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,GAEAQ,WAAA,CACA,CACAb,YAAA,iBACAC,YAAA,MACAC,QAAA,CAAA,CAAAI,WAAA,MAAA,EACA,EACA,CACAN,YAAA,0BACAC,YAAA,MACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,YACAC,YAAA,MACAC,QAAA,CACA,CAAAI,WAAA,CAAA,GAAA,EACA,CAAAH,UAAA,EAAA,EACA,CAAAE,WAAA,IAAA,EAEA,EACA,CACAL,YAAA,MACAC,YAAA,MACAC,QAAA,CACA,CAAAI,WAAA,CAAA,GAAA,EACA,CAAAH,UAAA,IAAA,EACA,CAAAE,WAAA,YAAA,EAEA,EACA,CACAL,YAAA,OACAC,YAAA,MACAC,QAAA,CAAA,CAAAI,WAAA,CAAA,GAAA,EACA,EACA,CACAN,YAAA,eACAC,YAAA,MACAC,QAAA,CAAA,CAAAG,WAAA,YAAA,EACA,EACA,CACAL,YAAA,gBACAC,YAAA,MACAC,QAAA,CAAA,CAAAC,UAAA,IAAA,EACA,EACA,CACAH,YAAA,aACAC,YAAA,MACAC,QAAA,CAAA,CAAAC,UAAA,IAAA,EACA,EACA,CACAH,YAAA,UACAC,YAAA,MACAC,QAAA,CAAA,CAAAI,WAAA,CAAA,GAAA,EAAA,CAAAD,WAAA,YAAA,EACA,EACA,CACAL,YAAA,QACAC,YAAA,WACAC,QAAA,CACA,CAAAQ,IAAA,SAAA,EACA,CAAAP,UAAA,CAAA,EAAA,EACA,CAAAG,WAAA,CAAA,EAAA,EAEA,EACA,CACAN,YAAA,QACAC,YAAA,SACAC,QAAA,CAAA,CAAAC,UAAA,CAAA,EAAA,EAAA,CAAAG,WAAA,CAAA,GAAA,EACA,GAEAQ,SAAA,CACA,CACAd,YAAA,MACAC,YAAA,SACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,iBACAC,YAAA,MACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,YACAC,YAAA,MACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,MACAC,YAAA,MACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EACA,EACA,CACA2c,YAAA,OACAC,YAAA,MACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,UACAC,YAAA,MACAC,QAAA,CAAA,CAAAG,WAAA,KAAA,EACA,EACA,CACAL,YAAA,QACAC,YAAA,MACAC,QAAA,CAAA,CAAA7c,MAAA,SAAA,EAAA,CAAAgd,WAAA,IAAA,EACA,GAEAU,OAAA,CACA,CACAf,YAAA,MACAC,YAAA,MACAC,QAAA,CACA,CACAc,iBAAA,CAAA,CACA,EACA,CACAV,WAAA,EACA,EACA,CACAH,UAAA,EACA,EACA,CACAc,MAAA,EACA,EACA,CACAP,IAAA,SACA,EAEA,EAEA,EAEAb,EAAA/N,QAAA,SAAAoP,GACA,IAyBAC,EAUA7N,EACA8N,EAGAC,EAvCAC,EAAA1V,MAAA3J,QAAAif,EAAA,QAAA,EAAAnZ,MAAA,GAAA,EACAwZ,EAAAL,EAAAvQ,UACArC,EAAA1C,MAAA3J,QAAAif,EAAA,MAAA,EACAtV,MAAA3J,QAAAif,EAAA,MAAA,EACA,mEACAM,EAAA5V,MAAA3J,QAAAif,EAAA,MAAA,EACAO,EAAAP,EACAQ,EAAA9V,MAAA3J,QAAAif,EAAA,OAAA,EAEA,MAAA,eAAAtV,MAAA3J,QAAAif,EAAA,OAAA,GACAS,EAAA/V,MAAA3J,QAAAif,EAAA,KAAA,EACAC,EAAA,CACAS,SAAA,CAAAC,IAAA3Q,OAAAoQ,EAAA,EAAA,EAAAQ,IAAA5Q,OAAAoQ,EAAA,EAAA,CAAA,EACAK,IAAAA,EACAH,KAAAA,EACAO,gBAAA,OACAC,YAAA,CAAA,CACA,EAEA,IAAA/gB,OAAA6e,OAAAmC,KAAAC,mBACAT,EACAN,CACA,IAGAA,EAAA,CACAK,KAAAA,EACAQ,YAAApW,MAAA3J,QAAAif,EAAA,aAAA,EACAxC,OAAA,IAAAzd,OAAA6e,OAAAmC,KAAAE,OAAAb,EAAA,GAAAA,EAAA,EAAA,EACAc,OACA,SAAAxY,aAAAC,QAAA,OAAA,EACA8V,EAAAoB,OACApB,EAAA+B,EACA,EAEApO,EAAA,IAAArS,OAAA6e,OAAAmC,KAAAxP,IAAAgP,EAAAN,CAAA,EACAC,EAAA,IAAAngB,OAAA6e,OAAAmC,KAAAI,WAAA,CACAC,QAAAf,CACA,CAAA,GACAF,EAAA,IAAApgB,OAAA6e,OAAAmC,KAAAM,OAAA,CACAX,SAAA,IAAA3gB,OAAA6e,OAAAmC,KAAAE,OAAAb,EAAA,GAAAA,EAAA,EAAA,EACAhT,KAAAA,EACAgF,IAAAA,CACA,CAAA,GAEAkP,YAAA,QAAA,WACApB,EAAAqB,KAAAnP,EAAA+N,CAAA,CACA,CAAA,EAEAzB,GACAA,EAAA9e,iBACA,eACA,SAAA4hB,GAAA,IAAAC,EAAAD,EAAAE,OAAAC,EAAAF,EAAAE,QAAAld,EAAAgd,EAAAhd,MACA,UAAAkd,GACAvP,EAAAP,IACA,SACA,SAAApN,EAAAga,EAAAoB,OAAApB,EAAA+B,EACA,CAEA,CACA,EACA,KACA,CAAA,EAEA,CCtwBA,IAAAoB,mBAAA,WAEA,IAAAC,EAAAniB,SAAAoL,cAAA,kBAAA,EACAgX,EAAApiB,SAAAoL,cAAA,iBAAA,EACA+W,GACAA,EAAAjiB,iBAAA,mBAAA,WACAkiB,EAAAtd,UAAAI,IAAA,QAAA,CACA,CAAA,CAGA,ECNAmd,eAAA,WACA,IAAAC,EAAAtiB,SAAAiP,eAAA,WAAA,EACAsT,EAAAviB,SAAAiP,eAAA,mBAAA,EACAuT,EAAA,IAAAniB,OAAAiW,UAAAC,MAAAgM,CAAA,EAEAD,GACAA,EAAApiB,iBAAA,QAAA,SAAAyB,GACAL,EAAAK,EAAA0O,OACA,UAAA/O,EAAAmhB,UACAnhB,EAAA8V,OAAA,EACA9V,EAAAohB,kBAAA,EAAA,KAAA,EACA1iB,SAAA0X,YAAA,MAAA,EACA6K,EAAAnX,cACA,aACA,EAAA2E,UAAA,+CAAA7O,OAAAI,EAAAyD,MAAA,SAAA,EACAyd,EAAArS,KAAA,EAEA,CAAA,CAEA,EClBAwS,cAAA,WACAtiB,OAAAuiB,WACA5iB,SAAAgR,iBAAA,mBAAA,EACAE,QAAA,SAAA9B,GACA,IAAAgG,EAAApK,MAAA3J,QAAA+N,EAAA,YAAA,EAMAyT,EAAAxiB,OAAAU,EAAAuQ,MALA,CACAwR,gBAAA,CAAA,EACAC,gBAAA,CAAA,EACAC,WAAA,CAAA,CACA,EACA5N,CAAA,EAKA,OAJA,IAAA/U,OAAAuiB,UAAA3Q,cAAA,GACA4Q,CAAA,CACA,EAAAI,KAAA7T,CAAA,CAGA,CAAA,CAEA,ECjBA8T,WAAA,WACA,IAAA/J,EACA,iBADAA,EAEA,0BAFAA,EAGA,gBAHAA,EAIA,YAJAA,EAKA,eALAA,EAMA,4BANAA,EAOA,yBAPAA,EAQA,0BARAA,EASA,0BAGAlD,EACA,aADAA,EAEA,SAGA9B,EACA,QADAA,EAEA,mBAFAA,EAGA,oBAGAgP,EAAAnjB,SAAAgR,iBAAAmI,CAAA,EACAiK,EAAApjB,SAAAgR,iBAAAmI,CAAA,EACAkK,EAAArjB,SAAAoL,cAAA+N,CAAA,EACAmK,EAAAtjB,SAAAgR,iBACAmI,CACA,EAGAgK,GACAA,EAAAjS,QAAA,SAAApD,GACAA,EAAA5N,iBAAAiU,EAAA,SAAAoP,GAAA,IACAtJ,EADAsJ,EAAA1O,cACAoE,QAAAE,CAAA,EACAG,EAAAW,EAAA7O,cACA+N,CACA,EACAjF,EAAAoF,EAAApF,aAEA+F,EAAAnV,UAAAI,IAAA+Q,CAAA,EACAqD,EAAAlO,cAAA+N,CAAA,EAAAqK,MAAA,EACAlK,EAAAmK,SAAA,CAAA7d,IAAAsO,CAAA,CAAA,CACA,CAAA,CACA,CAAA,EAGAkP,EAAAlS,QAAA,SAAApD,GACAA,EAAA5N,iBAAAiU,EAAA,SAAAuP,GAAAA,EAAA7O,cACAoE,QAAAE,CAAA,EAAArU,UAAAM,OACA6Q,CACA,CACA,CAAA,CACA,CAAA,EAEAoN,IAEAA,EAAAnjB,iBACAiU,EACA,SAAAwP,GACAC,EADAD,EAAA9O,cACAyF,mBACAsJ,GAAAA,EAAA9e,UAAAI,IAAA+Q,CAAA,CACA,CACA,EAGAoN,EAAAnjB,iBACAiU,EACA,SAAA0P,GAAAA,EAAAhP,cACAzJ,cAAA+N,CAAA,EAAAqK,MAAA,CACA,CACA,GAIAF,EAAApS,QAAA,SAAApD,GACAA,EAAA5N,iBAAAiU,EAAA,SAAA2P,GAAA,IACAC,EADAD,EAAAjP,cACAoE,QAAAE,CAAA,EACA6K,EAAA3jB,OAAAiW,UAAA2N,SAAAC,YAAAH,CAAA,EAEA/Y,MAAApG,SAAAmf,EAAAzJ,mBAAArE,CAAA,GACA8N,EAAAzJ,mBAAAxV,UAAAM,OAAA6Q,CAAA,EACA+N,EAAAhN,KAAA,CACA,CAAA,CACA,CAAA,CACA,ECxFAmN,sBAAA,WACA,IAooCAC,EAgBAC,EAjCAC,EAAAjkB,OAAAikB,EACAC,EAAAvkB,SAAAiP,eAAA,KAAA,EACAqV,GAAAC,IAeAH,EAAAE,EAAAE,UAAAC,YAFA,iEAEA,CACAC,YAAA,KACAC,YAAA,CAAA,EACAvd,OAhBA,SAAA4B,aAAAC,QAAA,OAAA,EACA,CACA,aACA,gBACA,aACA,gBACA,aACA,kBAEA,CAAA,cAAA,gBAAA,YAAA,gBAQA,CAAA,EAEAyJ,EAAA4R,EAAA5R,IAAA,MAAA,CACAoL,OAAAwG,EAAA5D,OAAA,OAAA,CAAA,EACAE,KAAA,EACAgE,OAAA,CAAAR,GACAS,QAAA,IACAC,SAAA,GACAC,SAAA,CAAAT,EAAAU,QAAA1Z,OACA2Z,IAAA,CAAAX,EAAAU,QAAA1Z,MACA,CAAA,EAEA+Y,EAAAC,EAAAY,mBAAA,CACAC,eAAA,CAAA,EACAC,kBAAA,CAAA,CACA,CAAA,EAvpCA,CACA,CACAnE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,cACAwiB,OAAA,kBACAC,SAAA,gBACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,KACAviB,KAAA,gBACAwiB,OAAA,iBACAC,SAAA,YACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,KACAviB,KAAA,gBACAwiB,OAAA,iBACAC,SAAA,YACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,KACAviB,KAAA,gBACAwiB,OAAA,iBACAC,SAAA,YACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,KACAviB,KAAA,gBACAwiB,OAAA,iBACAC,SAAA,YACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,KACAviB,KAAA,gBACAwiB,OAAA,iBACAC,SAAA,YACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,KACAviB,KAAA,gBACAwiB,OAAA,iBACAC,SAAA,YACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,KACAviB,KAAA,gBACAwiB,OAAA,iBACAC,SAAA,YACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,KACAviB,KAAA,gBACAwiB,OAAA,iBACAC,SAAA,YACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,KACAviB,KAAA,gBACAwiB,OAAA,iBACAC,SAAA,YACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,eACAwiB,OAAA,iBACAC,SAAA,eACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,MACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,MACAoE,KAAA,CAAA,KACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,QACAviB,KAAA,oBACAwiB,OAAA,oBACAC,SAAA,QACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,kBACAwiB,OAAA,sBACA,EACA,CACArE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,OACAoE,KAAA,CAAA,OACAviB,KAAA,oBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,QACAoE,KAAA,OACAviB,KAAA,qBACAwiB,OAAA,qBACAC,SAAA,iBACA,EACA,CACAtE,IAAA,QACAoE,KAAA,QACAviB,KAAA,qBACAwiB,OAAA,qBACAC,SAAA,iBACA,EACA,CACAtE,IAAA,OACAoE,KAAA,QACAviB,KAAA,iBACAwiB,OAAA,kBACAC,SAAA,eACA,EACA,CACAtE,IAAA,OACAoE,KAAA,QACAviB,KAAA,iBACAwiB,OAAA,kBACAC,SAAA,eACA,EACA,CACAtE,IAAA,OACAoE,KAAA,QACAviB,KAAA,iBACAwiB,OAAA,kBACAC,SAAA,eACA,EACA,CACAtE,IAAA,OACAoE,KAAA,QACAviB,KAAA,iBACAwiB,OAAA,kBACAC,SAAA,eACA,EACA,CACAtE,IAAA,QACAoE,KAAA,QACAviB,KAAA,iBACAwiB,OAAA,uBACAC,SAAA,SACA,EACA,CACAtE,IAAA,QACAoE,KAAA,QACAviB,KAAA,iBACAwiB,OAAA,uBACAC,SAAA,SACA,EACA,CACAtE,IAAA,QACAoE,KAAA,QACAviB,KAAA,mBACAwiB,OAAA,8BACAC,SAAA,UACA,EACA,CACAtE,IAAA,QACAoE,KAAA,QACAviB,KAAA,mBACAwiB,OAAA,8BACAC,SAAA,UACA,EACA,CACAtE,IAAA,CAAA,cACAoE,KAAA,eACAviB,KAAA,mBACAwiB,OAAA,kBACAC,SAAA,WACA,EACA,CACAtE,IAAA,CAAA,cACAoE,KAAA,eACAviB,KAAA,mBACAwiB,OAAA,kBACAC,SAAA,WACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,gBACAwiB,OAAA,kBACAC,SAAA,QACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,iBACAwiB,OAAA,6BACAC,SAAA,OACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,UACAoE,KAAA,WACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,UACAoE,KAAA,WACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,UACAoE,KAAA,WACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,UACAoE,KAAA,QACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,UACAoE,KAAA,UACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,UACAoE,KAAA,UACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,UACAviB,KAAA,gBACAwiB,OAAA,uBACAC,SAAA,UACA,EACA,CACAtE,IAAA,CAAA,KACAoE,KAAA,QACAviB,KAAA,gBACAwiB,OAAA,sBACAC,SAAA,YACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,UACAviB,KAAA,gBACAwiB,OAAA,sBACAC,SAAA,YACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,UACAviB,KAAA,gBACAwiB,OAAA,sBACAC,SAAA,YACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,UACAviB,KAAA,gBACAwiB,OAAA,sBACAC,SAAA,YACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,UACAviB,KAAA,gBACAwiB,OAAA,sBACAC,SAAA,YACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,UACAviB,KAAA,gBACAwiB,OAAA,sBACAC,SAAA,YACA,EACA,CACAtE,IAAA,CAAA,UACAoE,KAAA,UACAviB,KAAA,gBACAwiB,OAAA,sBACAC,SAAA,YACA,EACA,CACAtE,IAAA,SACAoE,KAAA,CAAA,WACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,WACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,WACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,QACAoE,KAAA,CAAA,UACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,WACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,WACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,WACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,WACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,WACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,SACAoE,KAAA,CAAA,WACAviB,KAAA,kBACAwiB,OAAA,sBACAC,SAAA,eACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,SACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,KACAoE,KAAA,CAAA,UACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,MACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA,UACAviB,KAAA,0BACAwiB,OAAA,sBACAC,SAAA,aACA,EACA,CACAtE,IAAA,UACAoE,KAAA,CAAA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CACA8iB,QAAA,CACAzZ,QAAAmlB,sBAAA,CACA,EACAY,oBAAA,CAAA,EACAX,OAAA,CACAr6B,EAAA,CACAs6B,KAAA,CACAj6B,MAAAuI,MAAAxI,UAAAwI,MAAAlH,SAAA,EAAAa,MAAA,EAAA,CACA,CACA,CACA,CACA,CACA,CAAA,CAEA,CACA,ECtCA65B,aAAA,WACA,IAAAC,EAAAz+B,SAAAiP,eAAA,uBAAA,EAuIAmtB,YAAAqC,EArIA,WAAA,MAAA,CACAhxB,KAAA,UACAlM,KAAA,CACA+6B,SAAA,CACA,CACApE,MAAA,cACA32B,KAAA,CACA,CACAq6B,EAAA,CAAA,GACAC,EAAA,EACA,EACA,CACAD,EAAA,CAAA,GACAC,EAAA,CAAA,EACA,EACA,CACAD,EAAA,CAAA,GACAC,EAAA,CAAA,EACA,EACA,CACAD,EAAA,CAAA,GACAC,EAAA,EACA,EACA,CACAD,EAAA,CAAA,GACAC,EAAA,CACA,EACA,CACAD,EAAA,CAAA,EACAC,EAAA,CAAA,EACA,EACA,CACAD,EAAA,EACAC,EAAA,CACA,EACA,CACAD,EAAA,GACAC,EAAA,EACA,EACA,CACAD,EAAA,GACAC,EAAA,EACA,EACA,CACAD,EAAA,GACAC,EAAA,CAAA,CACA,EACA,CACAD,EAAA,GACAC,EAAA,EACA,GAEA6C,qBAAA1zB,MAAAnI,SAAA,SAAA,EACAyF,YAAA0C,MAAAnI,SAAA,SAAA,EACA05B,YAAA,CACA,EACA,CACArE,MAAA,cACA32B,KAAA,CACA,CACAq6B,EAAA,GACAC,EAAA,EACA,EACA,CACAD,EAAA,CAAA,GACAC,EAAA,EACA,EACA,CACAD,EAAA,CAAA,GACAC,EAAA,CAAA,EACA,EACA,CACAD,EAAA,CAAA,GACAC,EAAA,CAAA,EACA,EACA,CACAD,EAAA,GACAC,EAAA,EACA,EACA,CACAD,EAAA,CAAA,GACAC,EAAA,EACA,EACA,CACAD,EAAA,CAAA,GACAC,EAAA,CAAA,EACA,EACA,CACAD,EAAA,GACAC,EAAA,EACA,EACA,CACAD,EAAA,GACAC,EAAA,EACA,EACA,CACAD,EA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","file":"theme.min.js","sourcesContent":["/* -------------------------------------------------------------------------- */\r\n/* Utils */\r\n/* -------------------------------------------------------------------------- */\r\nconst docReady = (fn) => {\r\n // see if DOM is already available\r\n if (document.readyState === \"loading\") {\r\n document.addEventListener(\"DOMContentLoaded\", fn);\r\n } else {\r\n setTimeout(fn, 1);\r\n }\r\n};\r\n\r\nconst resize = (fn) => window.addEventListener(\"resize\", fn);\r\n\r\nconst isIterableArray = (array) => Array.isArray(array) && !!array.length;\r\n\r\nconst camelize = (str) => {\r\n const text = str.replace(/[-_\\s.]+(.)?/g, (_, c) =>\r\n c ? c.toUpperCase() : \"\"\r\n );\r\n return `${text.substr(0, 1).toLowerCase()}${text.substr(1)}`;\r\n};\r\n\r\nconst getData = (el, data) => {\r\n try {\r\n return JSON.parse(el.dataset[camelize(data)]);\r\n } catch (e) {\r\n return el.dataset[camelize(data)];\r\n }\r\n};\r\n\r\n/* ----------------------------- Colors function ---------------------------- */\r\n\r\nconst hexToRgb = (hexValue) => {\r\n let hex;\r\n hexValue.indexOf(\"#\") === 0\r\n ? (hex = hexValue.substring(1))\r\n : (hex = hexValue);\r\n // Expand shorthand form (e.g. \"03F\") to full form (e.g. \"0033FF\")\r\n const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\r\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(\r\n hex.replace(shorthandRegex, (m, r, g, b) => r + r + g + g + b + b)\r\n );\r\n return result\r\n ? [\r\n parseInt(result[1], 16),\r\n parseInt(result[2], 16),\r\n parseInt(result[3], 16),\r\n ]\r\n : null;\r\n};\r\n\r\nconst rgbaColor = (color = \"#fff\", alpha = 0.5) =>\r\n `rgba(${hexToRgb(color)}, ${alpha})`;\r\n\r\n/* --------------------------------- Colors --------------------------------- */\r\n\r\nconst getColor = (name, dom = document.documentElement) =>\r\n getComputedStyle(dom).getPropertyValue(`--falcon-${name}`).trim();\r\n\r\nconst getColors = (dom) => ({\r\n primary: getColor(\"primary\", dom),\r\n secondary: getColor(\"secondary\", dom),\r\n success: getColor(\"success\", dom),\r\n info: getColor(\"info\", dom),\r\n warning: getColor(\"warning\", dom),\r\n danger: getColor(\"danger\", dom),\r\n light: getColor(\"light\", dom),\r\n dark: getColor(\"dark\", dom),\r\n});\r\n\r\nconst getSubtleColors = (dom) => ({\r\n primary: getColor(\"primary-bg-subtle\", dom),\r\n secondary: getColor(\"secondary-bg-subtle\", dom),\r\n success: getColor(\"success-bg-subtle\", dom),\r\n info: getColor(\"info-bg-subtle\", dom),\r\n warning: getColor(\"warning-bg-subtle\", dom),\r\n danger: getColor(\"danger-bg-subtle\", dom),\r\n light: getColor(\"light-bg-subtle\", dom),\r\n dark: getColor(\"dark-bg-subtle\", dom),\r\n});\r\n\r\nconst getGrays = (dom) => ({\r\n white: getColor(\"gray-white\", dom),\r\n 100: getColor(\"gray-100\", dom),\r\n 200: getColor(\"gray-200\", dom),\r\n 300: getColor(\"gray-300\", dom),\r\n 400: getColor(\"gray-400\", dom),\r\n 500: getColor(\"gray-500\", dom),\r\n 600: getColor(\"gray-600\", dom),\r\n 700: getColor(\"gray-700\", dom),\r\n 800: getColor(\"gray-800\", dom),\r\n 900: getColor(\"gray-900\", dom),\r\n 1000: getColor(\"gray-1000\", dom),\r\n 1100: getColor(\"gray-1100\", dom),\r\n black: getColor(\"gray-black\", dom),\r\n});\r\n\r\nconst hasClass = (el, className) => {\r\n !el && false;\r\n return el.classList.value.includes(className);\r\n};\r\n\r\nconst addClass = (el, className) => {\r\n el.classList.add(className);\r\n};\r\n\r\nconst removeClass = (el, className) => {\r\n el.classList.remove(className);\r\n};\r\n\r\nconst getOffset = (el) => {\r\n const rect = el.getBoundingClientRect();\r\n const scrollLeft = window.pageXOffset || document.documentElement.scrollLeft;\r\n const scrollTop = window.pageYOffset || document.documentElement.scrollTop;\r\n return { top: rect.top + scrollTop, left: rect.left + scrollLeft };\r\n};\r\n\r\nfunction isScrolledIntoView(el) {\r\n const rect = el.getBoundingClientRect();\r\n const windowHeight =\r\n window.innerHeight || document.documentElement.clientHeight;\r\n const windowWidth = window.innerWidth || document.documentElement.clientWidth;\r\n\r\n const vertInView = rect.top <= windowHeight && rect.top + rect.height >= 0;\r\n const horInView = rect.left <= windowWidth && rect.left + rect.width >= 0;\r\n\r\n return vertInView && horInView;\r\n}\r\n\r\nconst breakpoints = {\r\n xs: 0,\r\n sm: 576,\r\n md: 768,\r\n lg: 992,\r\n xl: 1200,\r\n xxl: 1540,\r\n};\r\n\r\nconst getBreakpoint = (el) => {\r\n const classes = el && el.classList.value;\r\n let breakpoint;\r\n if (classes) {\r\n breakpoint =\r\n breakpoints[\r\n classes\r\n .split(\" \")\r\n .filter((cls) => cls.includes(\"navbar-expand-\"))\r\n .pop()\r\n .split(\"-\")\r\n .pop()\r\n ];\r\n }\r\n return breakpoint;\r\n};\r\n\r\n/* --------------------------------- Cookie --------------------------------- */\r\n\r\nconst setCookie = (name, value, expire) => {\r\n const expires = new Date();\r\n expires.setTime(expires.getTime() + expire);\r\n document.cookie = `${name}=${value};expires=${expires.toUTCString()}`;\r\n};\r\n\r\nconst getCookie = (name) => {\r\n const keyValue = document.cookie.match(`(^|;) ?${name}=([^;]*)(;|$)`);\r\n return keyValue ? keyValue[2] : keyValue;\r\n};\r\n\r\nconst settings = {\r\n tinymce: {\r\n theme: \"oxide\",\r\n },\r\n chart: {\r\n borderColor: \"rgba(255, 255, 255, 0.8)\",\r\n },\r\n};\r\n\r\n/* -------------------------- Chart Initialization -------------------------- */\r\n\r\nconst newChart = (chart, config) => {\r\n const ctx = chart.getContext(\"2d\");\r\n return new window.Chart(ctx, config);\r\n};\r\n\r\n/* ---------------------------------- Store --------------------------------- */\r\n\r\nconst getItemFromStore = (key, defaultValue, store = localStorage) => {\r\n try {\r\n return JSON.parse(store.getItem(key)) || defaultValue;\r\n } catch {\r\n return store.getItem(key) || defaultValue;\r\n }\r\n};\r\n\r\nconst setItemToStore = (key, payload, store = localStorage) =>\r\n store.setItem(key, payload);\r\nconst getStoreSpace = (store = localStorage) =>\r\n parseFloat(\r\n (\r\n escape(encodeURIComponent(JSON.stringify(store))).length /\r\n (1024 * 1024)\r\n ).toFixed(2)\r\n );\r\n\r\n/* get Dates between */\r\n\r\nconst getDates = (startDate, endDate, interval = 1000 * 60 * 60 * 24) => {\r\n const duration = endDate - startDate;\r\n const steps = duration / interval;\r\n return Array.from(\r\n { length: steps + 1 },\r\n (v, i) => new Date(startDate.valueOf() + interval * i)\r\n );\r\n};\r\n\r\nconst getPastDates = (duration) => {\r\n let days;\r\n\r\n switch (duration) {\r\n case \"week\":\r\n days = 7;\r\n break;\r\n case \"month\":\r\n days = 30;\r\n break;\r\n case \"year\":\r\n days = 365;\r\n break;\r\n\r\n default:\r\n days = duration;\r\n }\r\n\r\n const date = new Date();\r\n const endDate = date;\r\n const startDate = new Date(new Date().setDate(date.getDate() - (days - 1)));\r\n return getDates(startDate, endDate);\r\n};\r\n\r\n/* Get Random Number */\r\nconst getRandomNumber = (min, max) =>\r\n Math.floor(Math.random() * (max - min) + min);\r\n\r\nconst utils = {\r\n docReady,\r\n breakpoints,\r\n resize,\r\n isIterableArray,\r\n camelize,\r\n getData,\r\n hasClass,\r\n addClass,\r\n hexToRgb,\r\n rgbaColor,\r\n getColor,\r\n getColors,\r\n getSubtleColors,\r\n getGrays,\r\n getOffset,\r\n isScrolledIntoView,\r\n getBreakpoint,\r\n setCookie,\r\n getCookie,\r\n newChart,\r\n settings,\r\n getItemFromStore,\r\n setItemToStore,\r\n getStoreSpace,\r\n getDates,\r\n getPastDates,\r\n getRandomNumber,\r\n removeClass,\r\n};\r\n\r\nexport default utils;\r\n","import { addClass } from './utils';\r\n/* -------------------------------------------------------------------------- */\r\n/* Detector */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst detectorInit = () => {\r\n const { is } = window;\r\n const html = document.querySelector('html');\r\n\r\n is.opera() && addClass(html, 'opera');\r\n is.mobile() && addClass(html, 'mobile');\r\n is.firefox() && addClass(html, 'firefox');\r\n is.safari() && addClass(html, 'safari');\r\n is.ios() && addClass(html, 'ios');\r\n is.iphone() && addClass(html, 'iphone');\r\n is.ipad() && addClass(html, 'ipad');\r\n is.ie() && addClass(html, 'ie');\r\n is.edge() && addClass(html, 'edge');\r\n is.chrome() && addClass(html, 'chrome');\r\n is.mac() && addClass(html, 'osx');\r\n is.windows() && addClass(html, 'windows');\r\n navigator.userAgent.match('CriOS') && addClass(html, 'chrome');\r\n};\r\n\r\nexport default detectorInit;\r\n","/*-----------------------------------------------\r\n| DomNode\r\n-----------------------------------------------*/\r\nclass DomNode {\r\n constructor(node) {\r\n this.node = node;\r\n }\r\n\r\n addClass(className) {\r\n this.isValidNode() && this.node.classList.add(className);\r\n }\r\n\r\n removeClass(className) {\r\n this.isValidNode() && this.node.classList.remove(className);\r\n }\r\n\r\n toggleClass(className) {\r\n this.isValidNode() && this.node.classList.toggle(className);\r\n }\r\n\r\n hasClass(className) {\r\n this.isValidNode() && this.node.classList.contains(className);\r\n }\r\n\r\n data(key) {\r\n if (this.isValidNode()) {\r\n try {\r\n return JSON.parse(this.node.dataset[this.camelize(key)]);\r\n } catch (e) {\r\n return this.node.dataset[this.camelize(key)];\r\n }\r\n }\r\n return null;\r\n }\r\n\r\n attr(name) {\r\n return this.isValidNode() && this.node[name];\r\n }\r\n\r\n setAttribute(name, value) {\r\n this.isValidNode() && this.node.setAttribute(name, value);\r\n }\r\n\r\n removeAttribute(name) {\r\n this.isValidNode() && this.node.removeAttribute(name);\r\n }\r\n\r\n setProp(name, value) {\r\n this.isValidNode() && (this.node[name] = value);\r\n }\r\n\r\n on(event, cb) {\r\n this.isValidNode() && this.node.addEventListener(event, cb);\r\n }\r\n\r\n isValidNode() {\r\n return !!this.node;\r\n }\r\n\r\n // eslint-disable-next-line class-methods-use-this\r\n camelize(str) {\r\n const text = str.replace(/[-_\\s.]+(.)?/g, (_, c) => (c ? c.toUpperCase() : ''));\r\n return `${text.substr(0, 1).toLowerCase()}${text.substr(1)}`;\r\n }\r\n}\r\n\r\nexport default DomNode;\r\n","/* eslint-disable */\r\nconst orders = [\r\n {\r\n id: 1,\r\n dropdownId: 'order-dropdown-1',\r\n orderId: '#181',\r\n mailLink: 'mailto:ricky@example.com',\r\n name: 'Ricky Antony',\r\n email: 'ricky@example.com',\r\n date: '20/04/2019',\r\n address: 'Ricky Antony, 2392 Main Avenue, Penasauka, New Jersey 02149',\r\n shippingType: 'Via Flat Rate',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$99'\r\n },\r\n {\r\n id: 2,\r\n dropdownId: 'order-dropdown-2',\r\n orderId: '#182',\r\n mailLink: 'mailto:kin@example.com',\r\n name: 'Kin Rossow',\r\n email: 'kin@example.com',\r\n date: '20/04/2019',\r\n address: 'Kin Rossow, 1 Hollywood Blvd,Beverly Hills, California 90210',\r\n shippingType: 'Via Free Shipping',\r\n status: 'Processing',\r\n badge: { type: 'primary', icon: 'fas fa-redo' },\r\n amount: '$120'\r\n },\r\n {\r\n id: 3,\r\n dropdownId: 'order-dropdown-3',\r\n orderId: '#183',\r\n mailLink: 'mailto:merry@example.com',\r\n name: 'Merry Diana',\r\n email: 'merry@example.com',\r\n date: '30/04/2019',\r\n address: 'Merry Diana, 1 Infinite Loop, Cupertino, California 90210',\r\n shippingType: 'Via Link Road',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$70'\r\n },\r\n {\r\n id: 4,\r\n dropdownId: 'order-dropdown-4',\r\n orderId: '#184',\r\n mailLink: 'mailto:bucky@example.com',\r\n name: 'Bucky Robert',\r\n email: 'bucky@example.com',\r\n date: '30/04/2019',\r\n address: 'Bucky Robert, 1 Infinite Loop, Cupertino, California 90210',\r\n shippingType: 'Via Free Shipping',\r\n status: 'Pending',\r\n badge: { type: 'warning', icon: 'fas fa-stream' },\r\n amount: '$92'\r\n },\r\n {\r\n id: 5,\r\n dropdownId: 'order-dropdown-5',\r\n orderId: '#185',\r\n mailLink: 'mailto:rocky@example.com',\r\n name: 'Rocky Zampa',\r\n email: 'rocky@example.com',\r\n date: '30/04/2019',\r\n address: 'Rocky Zampa, 1 Infinite Loop, Cupertino, California 90210',\r\n shippingType: 'Via Free Road',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$120'\r\n },\r\n {\r\n id: 6,\r\n dropdownId: 'order-dropdown-6',\r\n orderId: '#186',\r\n mailLink: 'mailto:ricky@example.com',\r\n name: 'Ricky John',\r\n email: 'ricky@example.com',\r\n date: '30/04/2019',\r\n address: 'Ricky John, 1 Infinite Loop, Cupertino, California 90210',\r\n shippingType: 'Via Free Shipping',\r\n status: 'Processing',\r\n badge: { type: 'primary', icon: 'fas fa-redo' },\r\n amount: '$145'\r\n },\r\n {\r\n id: 7,\r\n dropdownId: 'order-dropdown-7',\r\n orderId: '#187',\r\n mailLink: 'mailto:cristofer@example.com',\r\n name: 'Cristofer Henric',\r\n email: 'cristofer@example.com',\r\n date: '30/04/2019',\r\n address: 'Cristofer Henric, 1 Infinite Loop, Cupertino, California 90210',\r\n shippingType: 'Via Flat Rate',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$55'\r\n },\r\n {\r\n id: 8,\r\n dropdownId: 'order-dropdown-8',\r\n orderId: '#188',\r\n mailLink: 'mailto:lee@example.com',\r\n name: 'Brate Lee',\r\n email: 'lee@example.com',\r\n date: '29/04/2019',\r\n address: 'Brate Lee, 1 Infinite Loop, Cupertino, California 90210',\r\n shippingType: 'Via Link Road',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$90'\r\n },\r\n {\r\n id: 9,\r\n dropdownId: 'order-dropdown-9',\r\n orderId: '#189',\r\n mailLink: 'mailto:Stephenson@example.com',\r\n name: 'Thomas Stephenson',\r\n email: 'Stephenson@example.com',\r\n date: '29/04/2019',\r\n address: 'Thomas Stephenson, 116 Ballifeary Road, Bamff',\r\n shippingType: 'Via Flat Rate',\r\n status: 'Processing',\r\n badge: { type: 'primary', icon: 'fas fa-redo' },\r\n amount: '$52'\r\n },\r\n {\r\n id: 10,\r\n dropdownId: 'order-dropdown-10',\r\n orderId: '#190',\r\n mailLink: 'mailto:eviewsing@example.com',\r\n name: 'Evie Singh',\r\n email: 'eviewsing@example.com',\r\n date: '29/04/2019',\r\n address: 'Evie Singh, 54 Castledore Road, Tunstead',\r\n shippingType: 'Via Flat Rate',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$90'\r\n },\r\n {\r\n id: 11,\r\n dropdownId: 'order-dropdown-11',\r\n orderId: '#191',\r\n mailLink: 'mailto:peter@example.com',\r\n name: 'David Peters',\r\n email: 'peter@example.com',\r\n date: '29/04/2019',\r\n address: 'David Peters, Rhyd Y Groes, Rhosgoch, LL66 0AT',\r\n shippingType: 'Via Link Road',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$69'\r\n },\r\n {\r\n id: 12,\r\n dropdownId: 'order-dropdown-12',\r\n orderId: '#192',\r\n mailLink: 'mailto:jennifer@example.com',\r\n name: 'Jennifer Johnson',\r\n email: 'jennifer@example.com',\r\n date: '28/04/2019',\r\n address: 'Jennifer Johnson, Rhyd Y Groes, Rhosgoch, LL66 0AT',\r\n shippingType: 'Via Flat Rate',\r\n status: 'Processing',\r\n badge: { type: 'primary', icon: 'fas fa-redo' },\r\n amount: '$112'\r\n },\r\n {\r\n id: 13,\r\n dropdownId: 'order-dropdown-13',\r\n orderId: '#193',\r\n mailLink: 'mailto:okuneva@example.com',\r\n name: ' Demarcus Okuneva',\r\n email: 'okuneva@example.com',\r\n date: '28/04/2019',\r\n address: ' Demarcus Okuneva, 90555 Upton Drive Jeffreyview, UT 08771',\r\n shippingType: 'Via Flat Rate',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$99'\r\n },\r\n {\r\n id: 14,\r\n dropdownId: 'order-dropdown-14',\r\n orderId: '#194',\r\n mailLink: 'mailto:simeon@example.com',\r\n name: 'Simeon Harber',\r\n email: 'simeon@example.com',\r\n date: '27/04/2019',\r\n address:\r\n 'Simeon Harber, 702 Kunde Plain Apt. 634 East Bridgetview, HI 13134-1862',\r\n shippingType: 'Via Free Shipping',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$129'\r\n },\r\n {\r\n id: 15,\r\n dropdownId: 'order-dropdown-15',\r\n orderId: '#195',\r\n mailLink: 'mailto:lavon@example.com',\r\n name: 'Lavon Haley',\r\n email: 'lavon@example.com',\r\n date: '27/04/2019',\r\n address: 'Lavon Haley, 30998 Adonis Locks McGlynnside, ID 27241',\r\n shippingType: 'Via Free Shipping',\r\n status: 'Pending',\r\n badge: { type: 'warning', icon: 'fas fa-stream' },\r\n amount: '$70'\r\n },\r\n {\r\n id: 16,\r\n dropdownId: 'order-dropdown-16',\r\n orderId: '#196',\r\n mailLink: 'mailto:ashley@example.com',\r\n name: 'Ashley Kirlin',\r\n email: 'ashley@example.com',\r\n date: '26/04/2019',\r\n address:\r\n 'Ashley Kirlin, 43304 Prosacco Shore South Dejuanfurt, MO 18623-0505',\r\n shippingType: 'Via Link Road',\r\n status: 'Processing',\r\n badge: { type: 'primary', icon: 'fas fa-redo' },\r\n amount: '$39'\r\n },\r\n {\r\n id: 17,\r\n dropdownId: 'order-dropdown-17',\r\n orderId: '#197',\r\n mailLink: 'mailto:johnnie@example.com',\r\n name: 'Johnnie Considine',\r\n email: 'johnnie@example.com',\r\n date: '26/04/2019',\r\n address:\r\n 'Johnnie Considine, 6008 Hermann Points Suite 294 Hansenville, TN 14210',\r\n shippingType: 'Via Flat Rate',\r\n status: 'Pending',\r\n badge: { type: 'warning', icon: 'fas fa-stream' },\r\n amount: '$70'\r\n },\r\n {\r\n id: 18,\r\n dropdownId: 'order-dropdown-18',\r\n orderId: '#198',\r\n mailLink: 'mailto:trace@example.com',\r\n name: 'Trace Farrell',\r\n email: 'trace@example.com',\r\n date: '26/04/2019',\r\n address: 'Trace Farrell, 431 Steuber Mews Apt. 252 Germanland, AK 25882',\r\n shippingType: 'Via Free Shipping',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$70'\r\n },\r\n {\r\n id: 19,\r\n dropdownId: 'order-dropdown-19',\r\n orderId: '#199',\r\n mailLink: 'mailto:nienow@example.com',\r\n name: 'Estell Nienow',\r\n email: 'nienow@example.com',\r\n date: '26/04/2019',\r\n address: 'Estell Nienow, 4167 Laverna Manor Marysemouth, NV 74590',\r\n shippingType: 'Via Free Shipping',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$59'\r\n },\r\n {\r\n id: 20,\r\n dropdownId: 'order-dropdown-20',\r\n orderId: '#200',\r\n mailLink: 'mailto:howe@example.com',\r\n name: 'Daisha Howe',\r\n email: 'howe@example.com',\r\n date: '25/04/2019',\r\n address:\r\n 'Daisha Howe, 829 Lavonne Valley Apt. 074 Stehrfort, RI 77914-0379',\r\n shippingType: 'Via Free Shipping',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$39'\r\n },\r\n {\r\n id: 21,\r\n dropdownId: 'order-dropdown-21',\r\n orderId: '#201',\r\n mailLink: 'mailto:haley@example.com',\r\n name: 'Miles Haley',\r\n email: 'haley@example.com',\r\n date: '24/04/2019',\r\n address: 'Miles Haley, 53150 Thad Squares Apt. 263 Archibaldfort, MO 00837',\r\n shippingType: 'Via Flat Rate',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$55'\r\n },\r\n {\r\n id: 22,\r\n dropdownId: 'order-dropdown-22',\r\n orderId: '#202',\r\n mailLink: 'mailto:watsica@example.com',\r\n name: 'Brenda Watsica',\r\n email: 'watsica@example.com',\r\n date: '24/04/2019',\r\n address: \"Brenda Watsica, 9198 O'Kon Harbors Morarborough, IA 75409-7383\",\r\n shippingType: 'Via Free Shipping',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$89'\r\n },\r\n {\r\n id: 23,\r\n dropdownId: 'order-dropdown-23',\r\n orderId: '#203',\r\n mailLink: 'mailto:ellie@example.com',\r\n name: \"Ellie O'Reilly\",\r\n email: 'ellie@example.com',\r\n date: '24/04/2019',\r\n address:\r\n \"Ellie O'Reilly, 1478 Kaitlin Haven Apt. 061 Lake Muhammadmouth, SC 35848\",\r\n shippingType: 'Via Free Shipping',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$47'\r\n },\r\n {\r\n id: 24,\r\n dropdownId: 'order-dropdown-24',\r\n orderId: '#204',\r\n mailLink: 'mailto:garry@example.com',\r\n name: 'Garry Brainstrow',\r\n email: 'garry@example.com',\r\n date: '23/04/2019',\r\n address: 'Garry Brainstrow, 13572 Kurt Mews South Merritt, IA 52491',\r\n shippingType: 'Via Free Shipping',\r\n status: 'Completed',\r\n badge: { type: 'success', icon: 'fas fa-check' },\r\n amount: '$139'\r\n },\r\n {\r\n id: 25,\r\n dropdownId: 'order-dropdown-25',\r\n orderId: '#205',\r\n mailLink: 'mailto:estell@example.com',\r\n name: 'Estell Pollich',\r\n email: 'estell@example.com',\r\n date: '23/04/2019',\r\n address: 'Estell Pollich, 13572 Kurt Mews South Merritt, IA 52491',\r\n shippingType: 'Via Free Shipping',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$49'\r\n },\r\n {\r\n id: 26,\r\n dropdownId: 'order-dropdown-26',\r\n orderId: '#206',\r\n mailLink: 'mailto:ara@example.com',\r\n name: 'Ara Mueller',\r\n email: 'ara@example.com',\r\n date: '23/04/2019',\r\n address: 'Ara Mueller, 91979 Kohler Place Waelchiborough, CT 41291',\r\n shippingType: 'Via Flat Rate',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$19'\r\n },\r\n {\r\n id: 27,\r\n dropdownId: 'order-dropdown-27',\r\n orderId: '#207',\r\n mailLink: 'mailto:blick@example.com',\r\n name: 'Lucienne Blick',\r\n email: 'blick@example.com',\r\n date: '23/04/2019',\r\n address:\r\n 'Lucienne Blick, 6757 Giuseppe Meadows Geraldinemouth, MO 48819-4970',\r\n shippingType: 'Via Flat Rate',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$59'\r\n },\r\n {\r\n id: 28,\r\n dropdownId: 'order-dropdown-28',\r\n orderId: '#208',\r\n mailLink: 'mailto:haag@example.com',\r\n name: 'Laverne Haag',\r\n email: 'haag@example.com',\r\n date: '22/04/2019',\r\n address: 'Laverne Haag, 2327 Kaylee Mill East Citlalli, AZ 89582-3143',\r\n shippingType: 'Via Flat Rate',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$49'\r\n },\r\n {\r\n id: 29,\r\n dropdownId: 'order-dropdown-29',\r\n orderId: '#209',\r\n mailLink: 'mailto:bednar@example.com',\r\n name: 'Brandon Bednar',\r\n email: 'bednar@example.com',\r\n date: '22/04/2019',\r\n address:\r\n 'Brandon Bednar, 25156 Isaac Crossing Apt. 810 Lonborough, CO 83774-5999',\r\n shippingType: 'Via Flat Rate',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$39'\r\n },\r\n {\r\n id: 30,\r\n dropdownId: 'order-dropdown-30',\r\n orderId: '#210',\r\n mailLink: 'mailto:dimitri@example.com',\r\n name: 'Dimitri Boehm',\r\n email: 'dimitri@example.com',\r\n date: '23/04/2019',\r\n address: 'Dimitri Boehm, 71603 Wolff Plains Apt. 885 Johnstonton, MI 01581',\r\n shippingType: 'Via Flat Rate',\r\n status: 'On Hold',\r\n badge: { type: 'secondary', icon: 'fas fa-ban' },\r\n amount: '$111'\r\n }\r\n];\r\n\r\nconst advanceAjaxTableInit = () => {\r\n const togglePaginationButtonDisable = (button, disabled) => {\r\n button.disabled = disabled;\r\n button.classList[disabled ? 'add' : 'remove']('disabled');\r\n };\r\n // Selectors\r\n const table = document.getElementById('advanceAjaxTable');\r\n\r\n if (table) {\r\n const options = {\r\n page: 10,\r\n pagination: {\r\n item: \"
  • \"\r\n },\r\n item: values => {\r\n const {\r\n orderId,\r\n id,\r\n name,\r\n email,\r\n date,\r\n address,\r\n shippingType,\r\n status,\r\n badge,\r\n amount\r\n } = values;\r\n return `\r\n \r\n \r\n \r\n ${orderId}\r\n \r\n by\r\n ${name}\r\n
    \r\n ${email}\r\n \r\n \r\n ${date}\r\n \r\n \r\n ${address}\r\n

    ${shippingType}

    \r\n \r\n \r\n \r\n ${status}\r\n \r\n \r\n \r\n \r\n ${amount}\r\n \r\n \r\n
    \r\n \r\n
    \r\n View\r\n Edit\r\n Refund\r\n
    \r\n Archive\r\n Archive\r\n
    \r\n
    \r\n \r\n \r\n `;\r\n }\r\n };\r\n const paginationButtonNext = table.querySelector(\r\n '[data-list-pagination=\"next\"]'\r\n );\r\n const paginationButtonPrev = table.querySelector(\r\n '[data-list-pagination=\"prev\"]'\r\n );\r\n const viewAll = table.querySelector('[data-list-view=\"*\"]');\r\n const viewLess = table.querySelector('[data-list-view=\"less\"]');\r\n const listInfo = table.querySelector('[data-list-info]');\r\n const listFilter = document.querySelector('[data-list-filter]');\r\n\r\n const orderList = new window.List(table, options, orders);\r\n\r\n // Fallback\r\n orderList.on('updated', item => {\r\n const fallback =\r\n table.querySelector('.fallback') ||\r\n document.getElementById(options.fallback);\r\n\r\n if (fallback) {\r\n if (item.matchingItems.length === 0) {\r\n fallback.classList.remove('d-none');\r\n } else {\r\n fallback.classList.add('d-none');\r\n }\r\n }\r\n });\r\n\r\n const totalItem = orderList.items.length;\r\n const itemsPerPage = orderList.page;\r\n const btnDropdownClose =\r\n orderList.listContainer.querySelector('.btn-close');\r\n let pageQuantity = Math.ceil(totalItem / itemsPerPage);\r\n let numberOfcurrentItems = orderList.visibleItems.length;\r\n let pageCount = 1;\r\n\r\n btnDropdownClose &&\r\n btnDropdownClose.addEventListener('search.close', () =>\r\n orderList.fuzzySearch('')\r\n );\r\n\r\n const updateListControls = () => {\r\n listInfo &&\r\n (listInfo.innerHTML = `${orderList.i} to ${numberOfcurrentItems} of ${totalItem}`);\r\n paginationButtonPrev &&\r\n togglePaginationButtonDisable(paginationButtonPrev, pageCount === 1);\r\n paginationButtonNext &&\r\n togglePaginationButtonDisable(\r\n paginationButtonNext,\r\n pageCount === pageQuantity\r\n );\r\n\r\n if (pageCount > 1 && pageCount < pageQuantity) {\r\n togglePaginationButtonDisable(paginationButtonNext, false);\r\n togglePaginationButtonDisable(paginationButtonPrev, false);\r\n }\r\n };\r\n updateListControls();\r\n\r\n if (paginationButtonNext) {\r\n paginationButtonNext.addEventListener('click', e => {\r\n e.preventDefault();\r\n pageCount += 1;\r\n\r\n const nextInitialIndex = orderList.i + itemsPerPage;\r\n nextInitialIndex <= orderList.size() &&\r\n orderList.show(nextInitialIndex, itemsPerPage);\r\n numberOfcurrentItems += orderList.visibleItems.length;\r\n updateListControls();\r\n });\r\n }\r\n\r\n if (paginationButtonPrev) {\r\n paginationButtonPrev.addEventListener('click', e => {\r\n e.preventDefault();\r\n pageCount -= 1;\r\n\r\n numberOfcurrentItems -= orderList.visibleItems.length;\r\n const prevItem = orderList.i - itemsPerPage;\r\n prevItem > 0 && orderList.show(prevItem, itemsPerPage);\r\n updateListControls();\r\n });\r\n }\r\n\r\n const toggleViewBtn = () => {\r\n viewLess.classList.toggle('d-none');\r\n viewAll.classList.toggle('d-none');\r\n };\r\n\r\n if (viewAll) {\r\n viewAll.addEventListener('click', () => {\r\n orderList.show(1, totalItem);\r\n pageQuantity = 1;\r\n pageCount = 1;\r\n numberOfcurrentItems = totalItem;\r\n updateListControls();\r\n toggleViewBtn();\r\n });\r\n }\r\n if (viewLess) {\r\n viewLess.addEventListener('click', () => {\r\n orderList.show(1, itemsPerPage);\r\n pageQuantity = Math.ceil(totalItem / itemsPerPage);\r\n pageCount = 1;\r\n numberOfcurrentItems = orderList.visibleItems.length;\r\n updateListControls();\r\n toggleViewBtn();\r\n });\r\n }\r\n if (options.pagination) {\r\n table.querySelector('.pagination').addEventListener('click', e => {\r\n if (e.target.classList[0] === 'page') {\r\n pageCount = Number(e.target.innerText);\r\n updateListControls();\r\n }\r\n });\r\n }\r\n if (options.filter) {\r\n const { key } = options.filter;\r\n listFilter.addEventListener('change', e => {\r\n orderList.filter(item => {\r\n if (e.target.value === '') {\r\n return true;\r\n }\r\n return item\r\n .values()\r\n [key].toLowerCase()\r\n .includes(e.target.value.toLowerCase());\r\n });\r\n });\r\n }\r\n }\r\n};\r\n\r\nexport default advanceAjaxTableInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Anchor JS */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst anchors = new window.AnchorJS();\r\nanchors.options = {\r\n icon: '#',\r\n};\r\nanchors.add('[data-anchor]');\r\n","import utils from './utils';\r\n/*-----------------------------------------------\r\n| Bottom Bar Control\r\n-----------------------------------------------*/\r\n\r\nconst bottomBarInit = () => {\r\n const bottomBars = document.querySelectorAll('[data-bottom-bar]');\r\n const navbarButtons = [\r\n document.querySelector('[data-bs-target=\"#navbarVerticalCollapse\"]'),\r\n document.querySelector('[data-bs-target=\"#navbarStandard\"]'),\r\n ];\r\n\r\n const isElementInViewport = (el, offsetTop = 0) => {\r\n const rect = el.getBoundingClientRect();\r\n\r\n return (\r\n rect.bottom > 0 &&\r\n rect.top > offsetTop &&\r\n rect.right > 0 &&\r\n rect.left < (window.innerWidth || document.documentElement.clientWidth) &&\r\n rect.top < (window.innerHeight || document.documentElement.clientHeight)\r\n );\r\n };\r\n\r\n if (bottomBars.length) {\r\n bottomBars.forEach((bar) => {\r\n // get options\r\n const barOptions = utils.getData(bar, 'bottom-bar');\r\n const defaultOptions = {\r\n target: '#bottom-bar-target',\r\n offsetTop: 0,\r\n breakPoint: 'lg',\r\n };\r\n const { target, offsetTop, breakPoint } = window._.merge(\r\n defaultOptions,\r\n barOptions\r\n );\r\n\r\n // select target\r\n const targetEl = document.getElementById(target);\r\n\r\n // handle Bottombar\r\n const toggleBottomBar = () => {\r\n if (\r\n window.matchMedia(`(max-width: ${utils.breakpoints[breakPoint]}px)`)\r\n .matches\r\n ) {\r\n if (!isElementInViewport(targetEl, offsetTop)) {\r\n utils.removeClass(bar, 'hide');\r\n } else {\r\n utils.addClass(bar, 'hide');\r\n }\r\n }\r\n };\r\n\r\n window.addEventListener('scroll', toggleBottomBar);\r\n\r\n const toggleBottomBarOnNavbarCollapse = (el) => {\r\n if (!utils.hasClass(el, 'collapsed')) {\r\n utils.addClass(bar, 'hide');\r\n } else if (!isElementInViewport(targetEl, offsetTop)) {\r\n utils.removeClass(bar, 'hide');\r\n }\r\n };\r\n\r\n navbarButtons.forEach(\r\n (btn) =>\r\n btn &&\r\n btn.addEventListener('click', () =>\r\n toggleBottomBarOnNavbarCollapse(btn)\r\n )\r\n );\r\n });\r\n }\r\n};\r\n\r\nexport default bottomBarInit;\r\n","import DomNode from './node';\r\nimport utils from './utils';\r\n\r\n/*-----------------------------------------------\r\n| Bulk Select\r\n-----------------------------------------------*/\r\n\r\nconst elementMap = new Map();\r\n\r\nclass BulkSelect {\r\n constructor(element, option) {\r\n this.element = element;\r\n this.option = {\r\n displayNoneClassName: 'd-none',\r\n ...option\r\n };\r\n elementMap.set(this.element, this);\r\n }\r\n\r\n // Static\r\n static getInstance(element) {\r\n if (elementMap.has(element)) {\r\n return elementMap.get(element);\r\n }\r\n return null;\r\n }\r\n\r\n init() {\r\n this.attachNodes();\r\n this.clickBulkCheckbox();\r\n this.clickRowCheckbox();\r\n }\r\n\r\n getSelectedRows() {\r\n return Array.from(this.bulkSelectRows)\r\n .filter(row => row.checked)\r\n .map(row => utils.getData(row, 'bulk-select-row'));\r\n }\r\n\r\n attachNodes() {\r\n const { body, actions, replacedElement } = utils.getData(\r\n this.element,\r\n 'bulk-select'\r\n );\r\n this.actions = new DomNode(document.getElementById(actions));\r\n this.replacedElement = new DomNode(\r\n document.getElementById(replacedElement)\r\n );\r\n this.bulkSelectRows = document\r\n .getElementById(body)\r\n .querySelectorAll('[data-bulk-select-row]');\r\n }\r\n\r\n attachRowNodes(elms) {\r\n this.bulkSelectRows = elms;\r\n }\r\n\r\n clickBulkCheckbox() {\r\n // Handle click event in bulk checkbox\r\n this.element.addEventListener('click', () => {\r\n if (this.element.indeterminate === 'indeterminate') {\r\n this.actions.addClass(this.option.displayNoneClassName);\r\n this.replacedElement.removeClass(this.option.displayNoneClassName);\r\n\r\n this.removeBulkCheck();\r\n\r\n this.bulkSelectRows.forEach(el => {\r\n const rowCheck = new DomNode(el);\r\n rowCheck.setProp('checked', false);\r\n rowCheck.setAttribute('checked', false);\r\n });\r\n return;\r\n }\r\n\r\n this.toggleDisplay();\r\n this.bulkSelectRows.forEach(el => {\r\n // eslint-disable-next-line\r\n el.checked = this.element.checked;\r\n });\r\n });\r\n }\r\n\r\n clickRowCheckbox() {\r\n // Handle click event in checkbox of each row\r\n this.bulkSelectRows.forEach(el => {\r\n const rowCheck = new DomNode(el);\r\n rowCheck.on('click', () => {\r\n if (this.element.indeterminate !== 'indeterminate') {\r\n this.element.indeterminate = true;\r\n this.element.setAttribute('indeterminate', 'indeterminate');\r\n this.element.checked = true;\r\n this.element.setAttribute('checked', true);\r\n\r\n this.actions.removeClass(this.option.displayNoneClassName);\r\n this.replacedElement.addClass(this.option.displayNoneClassName);\r\n }\r\n\r\n if ([...this.bulkSelectRows].every(element => element.checked)) {\r\n this.element.indeterminate = false;\r\n this.element.setAttribute('indeterminate', false);\r\n }\r\n\r\n if ([...this.bulkSelectRows].every(element => !element.checked)) {\r\n this.removeBulkCheck();\r\n this.toggleDisplay();\r\n }\r\n });\r\n });\r\n }\r\n\r\n removeBulkCheck() {\r\n this.element.indeterminate = false;\r\n this.element.removeAttribute('indeterminate');\r\n this.element.checked = false;\r\n this.element.setAttribute('checked', false);\r\n }\r\n\r\n toggleDisplay() {\r\n this.actions.toggleClass(this.option.displayNoneClassName);\r\n this.replacedElement.toggleClass(this.option.displayNoneClassName);\r\n }\r\n}\r\n\r\nfunction bulkSelectInit() {\r\n const bulkSelects = document.querySelectorAll('[data-bulk-select');\r\n\r\n if (bulkSelects.length) {\r\n bulkSelects.forEach(el => {\r\n const bulkSelect = new BulkSelect(el);\r\n bulkSelect.init();\r\n });\r\n }\r\n}\r\n\r\nexport default bulkSelectInit;\r\n\r\nwindow.BulkSelect = BulkSelect;\r\n","import utils from './utils';\r\n\r\n/*-----------------------------------------------\r\n| Chat\r\n-----------------------------------------------*/\r\nconst chatInit = () => {\r\n const Events = {\r\n CLICK: 'click',\r\n SHOWN_BS_TAB: 'shown.bs.tab',\r\n KEYUP: 'keyup',\r\n EMOJI: 'emoji'\r\n };\r\n\r\n const Selector = {\r\n CHAT_SIDEBAR: '.chat-sidebar',\r\n CHAT_CONTACT: '.chat-contact',\r\n CHAT_CONTENT_SCROLL_AREA: '.chat-content-scroll-area',\r\n CHAT_CONTENT_SCROLL_AREA_ACTIVE:\r\n '.card-chat-pane.active .chat-content-scroll-area',\r\n CHAT_EMOJIAREA: '.chat-editor-area .emojiarea-editor',\r\n BTN_SEND: '.btn-send',\r\n EMOJIEAREA_EDITOR: '.emojiarea-editor',\r\n BTN_INFO: '.btn-chat-info',\r\n CONVERSATION_INFO: '.conversation-info',\r\n CONTACTS_LIST_SHOW: '.contacts-list-show'\r\n };\r\n\r\n const ClassName = {\r\n UNREAD_MESSAGE: 'unread-message',\r\n TEXT_PRIMARY: 'text-primary',\r\n SHOW: 'show'\r\n };\r\n\r\n const DATA_KEY = {\r\n INDEX: 'index'\r\n };\r\n\r\n const $chatSidebar = document.querySelector(Selector.CHAT_SIDEBAR);\r\n const $chatContact = document.querySelectorAll(Selector.CHAT_CONTACT);\r\n const $chatEmojiarea = document.querySelector(Selector.CHAT_EMOJIAREA);\r\n const $btnSend = document.querySelector(Selector.BTN_SEND);\r\n const $currentChatArea = document.querySelector(\r\n Selector.CHAT_CONTENT_SCROLL_AREA\r\n );\r\n\r\n // Set scrollbar position\r\n const setScrollbarPosition = $chatArea => {\r\n if ($chatArea) {\r\n const scrollArea = $chatArea;\r\n scrollArea.scrollTop = $chatArea.scrollHeight;\r\n }\r\n };\r\n\r\n setTimeout(() => {\r\n setScrollbarPosition($currentChatArea);\r\n }, 700);\r\n\r\n document.querySelectorAll(Selector.CHAT_CONTACT).forEach(el => {\r\n el.addEventListener(Events.CLICK, e => {\r\n const $this = e.currentTarget;\r\n $this.classList.add('active');\r\n // Hide contact list sidebar on responsive\r\n window.innerWidth < 768 &&\r\n !e.target.classList.contains('hover-actions') &&\r\n ($chatSidebar.style.left = '-100%');\r\n\r\n // Remove unread-message class when read\r\n $this.classList.contains(ClassName.UNREAD_MESSAGE) &&\r\n $this.classList.remove(ClassName.UNREAD_MESSAGE);\r\n });\r\n });\r\n\r\n $chatContact.forEach(el => {\r\n el.addEventListener(Events.SHOWN_BS_TAB, () => {\r\n $chatEmojiarea.innerHTML = '';\r\n $btnSend.classList.remove(ClassName.TEXT_PRIMARY);\r\n const TargetChatArea = document.querySelector(\r\n Selector.CHAT_CONTENT_SCROLL_AREA_ACTIVE\r\n );\r\n setScrollbarPosition(TargetChatArea);\r\n });\r\n });\r\n\r\n // change send button color on\r\n\r\n if ($chatEmojiarea) {\r\n $chatEmojiarea.setAttribute('placeholder', 'Type your message');\r\n $chatEmojiarea.addEventListener(Events.KEYUP, e => {\r\n if (e.target.textContent.length <= 0) {\r\n $btnSend.classList.remove(ClassName.TEXT_PRIMARY);\r\n if (e.target.innerHTML === '
    ') {\r\n e.target.innerHTML = '';\r\n }\r\n } else {\r\n $btnSend.classList.add(ClassName.TEXT_PRIMARY);\r\n }\r\n\r\n const TargetChatArea = document.querySelector(\r\n Selector.CHAT_CONTENT_SCROLL_AREA_ACTIVE\r\n );\r\n setScrollbarPosition(TargetChatArea);\r\n });\r\n }\r\n // Open conversation info sidebar\r\n $chatEmojiarea &&\r\n document.querySelectorAll(Selector.BTN_INFO).forEach(el => {\r\n el.addEventListener(Events.CLICK, e => {\r\n const $this = e.currentTarget;\r\n const dataIndex = utils.getData($this, DATA_KEY.INDEX);\r\n const $info = document.querySelector(\r\n `${Selector.CONVERSATION_INFO}[data-${DATA_KEY.INDEX}='${dataIndex}']`\r\n );\r\n $info.classList.toggle(ClassName.SHOW);\r\n });\r\n });\r\n\r\n // Show contact list sidebar on responsive\r\n document.querySelectorAll(Selector.CONTACTS_LIST_SHOW).forEach(el => {\r\n el.addEventListener(Events.CLICK, function () {\r\n $chatSidebar.style.left = 0;\r\n });\r\n });\r\n\r\n // Set scrollbar area height on resize\r\n utils.resize(() => {\r\n const TargetChatArea = document.querySelector(\r\n Selector.CHAT_CONTENT_SCROLL_AREA_ACTIVE\r\n );\r\n setScrollbarPosition(TargetChatArea);\r\n });\r\n};\r\n\r\nexport default chatInit;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* choices */\r\n/* -------------------------------------------------------------------------- */\r\nconst choicesInit = () => {\r\n if (window.Choices) {\r\n const elements = document.querySelectorAll('.js-choice');\r\n elements.forEach((item) => {\r\n const userOptions = utils.getData(item, 'options');\r\n const choices = new window.Choices(item, {\r\n itemSelectText: '',\r\n ...userOptions,\r\n });\r\n\r\n const needsValidation = document.querySelectorAll('.needs-validation');\r\n\r\n needsValidation.forEach((validationItem) => {\r\n const selectFormValidation = () => {\r\n validationItem.querySelectorAll('.choices').forEach((choicesItem) => {\r\n const singleSelect = choicesItem.querySelector(\r\n '.choices__list--single'\r\n );\r\n const multipleSelect = choicesItem.querySelector(\r\n '.choices__list--multiple'\r\n );\r\n\r\n if (choicesItem.querySelector('[required]')) {\r\n if (singleSelect) {\r\n if (\r\n singleSelect\r\n .querySelector('.choices__item--selectable')\r\n ?.getAttribute('data-value') !== ''\r\n ) {\r\n choicesItem.classList.remove('invalid');\r\n choicesItem.classList.add('valid');\r\n } else {\r\n choicesItem.classList.remove('valid');\r\n choicesItem.classList.add('invalid');\r\n }\r\n }\r\n //----- for multiple select only ----------\r\n if (multipleSelect) {\r\n if (choicesItem.getElementsByTagName('option').length) {\r\n choicesItem.classList.remove('invalid');\r\n choicesItem.classList.add('valid');\r\n } else {\r\n choicesItem.classList.remove('valid');\r\n choicesItem.classList.add('invalid');\r\n }\r\n }\r\n\r\n //------ select end ---------------\r\n }\r\n });\r\n };\r\n\r\n validationItem.addEventListener('submit', () => {\r\n selectFormValidation();\r\n });\r\n\r\n item.addEventListener('change', () => {\r\n selectFormValidation();\r\n });\r\n });\r\n\r\n return choices;\r\n });\r\n }\r\n};\r\n\r\nexport default choicesInit;\r\n","import utils from './utils';\r\n\r\n/*-----------------------------------------------\r\n| Cookie notice\r\n-----------------------------------------------*/\r\nconst cookieNoticeInit = () => {\r\n const Selector = {\r\n NOTICE: '.notice',\r\n DATA_TOGGLE_Notice: '[data-bs-toggle=\"notice\"]',\r\n };\r\n\r\n const Events = {\r\n CLICK: 'click',\r\n HIDDEN_BS_TOAST: 'hidden.bs.toast',\r\n };\r\n\r\n const DataKeys = {\r\n OPTIONS: 'options',\r\n };\r\n\r\n const ClassNames = {\r\n HIDE: 'hide',\r\n };\r\n\r\n const notices = document.querySelectorAll(Selector.NOTICE);\r\n let showNotice = true;\r\n notices.forEach((item) => {\r\n const notice = new window.bootstrap.Toast(item);\r\n const options = {\r\n autoShow: false,\r\n autoShowDelay: 0,\r\n showOnce: false,\r\n cookieExpireTime: 3600000,\r\n ...utils.getData(item, DataKeys.OPTIONS),\r\n };\r\n const { showOnce, autoShow, autoShowDelay } = options;\r\n\r\n if (showOnce) {\r\n const hasNotice = utils.getCookie('notice');\r\n showNotice = hasNotice === null;\r\n }\r\n\r\n if (autoShow && showNotice) {\r\n setTimeout(() => {\r\n notice.show();\r\n }, autoShowDelay);\r\n }\r\n\r\n item.addEventListener(Events.HIDDEN_BS_TOAST, function (e) {\r\n const el = e.currentTarget;\r\n const toastOptions = {\r\n cookieExpireTime: 3600000,\r\n showOnce: false,\r\n ...utils.getData(el, DataKeys.OPTIONS),\r\n };\r\n toastOptions.showOnce &&\r\n utils.setCookie('notice', false, toastOptions.cookieExpireTime);\r\n });\r\n });\r\n\r\n const btnNoticeToggle = document.querySelector(Selector.DATA_TOGGLE_Notice);\r\n btnNoticeToggle &&\r\n btnNoticeToggle.addEventListener(Events.CLICK, ({ currentTarget }) => {\r\n const id = currentTarget.getAttribute('href');\r\n const notice = new window.bootstrap.Toast(document.querySelector(id));\r\n\r\n /*eslint-disable-next-line*/\r\n const el = notice._element;\r\n utils.hasClass(el, ClassNames.HIDE) ? notice.show() : notice.hide();\r\n });\r\n};\r\n\r\nexport default cookieNoticeInit;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Copy LinK */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst copyLink = () => {\r\n const copyLinkModal = document.getElementById('copyLinkModal');\r\n copyLinkModal &&\r\n copyLinkModal.addEventListener('shown.bs.modal', () => {\r\n const invitationLink = document.querySelector('.invitation-link');\r\n invitationLink.select();\r\n });\r\n\r\n const copyButtons = document.querySelectorAll('[data-copy]');\r\n copyButtons &&\r\n copyButtons.forEach((button) => {\r\n const tooltip = new window.bootstrap.Tooltip(button);\r\n\r\n button.addEventListener('mouseover', () => tooltip.show());\r\n button.addEventListener('mouseleave', () => tooltip.hide());\r\n\r\n button.addEventListener('click', (e) => {\r\n e.stopPropagation();\r\n const el = e.target;\r\n el.setAttribute('data-original-title', 'Copied');\r\n tooltip.show();\r\n el.setAttribute('data-original-title', 'Copy to clipboard');\r\n tooltip.update();\r\n const inputID = utils.getData(el, 'copy');\r\n const input = document.querySelector(inputID);\r\n input.select();\r\n document.execCommand('copy');\r\n });\r\n });\r\n};\r\n\r\nexport default copyLink;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Count Up */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst countupInit = () => {\r\n if (window.countUp) {\r\n const countups = document.querySelectorAll('[data-countup]');\r\n countups.forEach((node) => {\r\n const { endValue, ...options } = utils.getData(node, 'countup');\r\n const countUp = new window.countUp.CountUp(node, endValue, {\r\n duration: 5,\r\n ...options,\r\n });\r\n if (!countUp.error) {\r\n countUp.start();\r\n } else {\r\n console.error(countUp.error);\r\n }\r\n });\r\n }\r\n};\r\n\r\nexport default countupInit;\r\n","/*-----------------------------------------------\r\n| Data table\r\n-----------------------------------------------*/\r\nconst dataTablesInit = () => {\r\n if (window.jQuery) {\r\n const $ = window.jQuery;\r\n\r\n const dataTables = $('.data-table');\r\n const customDataTable = (elem) => {\r\n elem.find('.pagination').addClass('pagination-sm');\r\n };\r\n dataTables.length &&\r\n dataTables.each((index, value) => {\r\n const $this = $(value);\r\n const options = $.extend(\r\n {\r\n dom:\r\n \"<'row mx-0'<'col-md-6'l><'col-md-6'f>>\" +\r\n \"<'table-responsive scrollbar'tr>\" +\r\n \"<'row g-0 align-items-center justify-content-center justify-content-sm-between'<'col-auto mb-2 mb-sm-0 px-3'i><'col-auto px-3'p>>\",\r\n },\r\n $this.data('options')\r\n );\r\n $this.DataTable(options);\r\n const $wrpper = $this.closest('.dataTables_wrapper');\r\n customDataTable($wrpper);\r\n $this.on('draw.dt', () => customDataTable($wrpper));\r\n });\r\n }\r\n};\r\nexport default dataTablesInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Draggable */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nimport utils from './utils';\r\n\r\nconst draggableInit = () => {\r\n const Selectors = {\r\n BODY: 'body',\r\n KANBAN_CONTAINER: '.kanban-container',\r\n KABNBAN_COLUMN: '.kanban-column',\r\n KANBAN_ITEMS_CONTAINER: '.kanban-items-container',\r\n KANBAN_ITEM: '.kanban-item',\r\n ADD_CARD_FORM: '.add-card-form',\r\n };\r\n\r\n const Events = {\r\n DRAG_START: 'drag:start',\r\n DRAG_STOP: 'drag:stop',\r\n };\r\n\r\n const ClassNames = {\r\n FORM_ADDED: 'form-added',\r\n };\r\n\r\n const columns = document.querySelectorAll(Selectors.KABNBAN_COLUMN);\r\n const columnContainers = document.querySelectorAll(\r\n Selectors.KANBAN_ITEMS_CONTAINER\r\n );\r\n const container = document.querySelector(Selectors.KANBAN_CONTAINER);\r\n\r\n if (!!columnContainers.length) {\r\n // Initialize Sortable\r\n const sortable = new window.Draggable.Sortable(columnContainers, {\r\n draggable: Selectors.KANBAN_ITEM,\r\n delay: 200,\r\n mirror: {\r\n appendTo: Selectors.BODY,\r\n constrainDimensions: true,\r\n },\r\n scrollable: {\r\n draggable: Selectors.KANBAN_ITEM,\r\n scrollableElements: [...columnContainers, container],\r\n },\r\n });\r\n\r\n // Hide form when drag start\r\n sortable.on(Events.DRAG_START, () => {\r\n columns.forEach((column) => {\r\n utils.hasClass(column, ClassNames.FORM_ADDED) &&\r\n column.classList.remove(ClassNames.FORM_ADDED);\r\n });\r\n });\r\n\r\n // Place forms and other contents bottom of the sortable container\r\n sortable.on(Events.DRAG_STOP, ({ data: { source: el } }) => {\r\n const columnContainer = el.closest(Selectors.KANBAN_ITEMS_CONTAINER);\r\n const form = columnContainer.querySelector(Selectors.ADD_CARD_FORM);\r\n\r\n !el.nextElementSibling && columnContainer.appendChild(form);\r\n });\r\n }\r\n};\r\n\r\nexport default draggableInit;\r\n","/*-----------------------------------------------\r\n| Dashboard Table dropdown\r\n-----------------------------------------------*/\r\nconst dropdownMenuInit = () => {\r\n // Only for ios\r\n if (window.is.ios()) {\r\n const Event = {\r\n SHOWN_BS_DROPDOWN: 'shown.bs.dropdown',\r\n HIDDEN_BS_DROPDOWN: 'hidden.bs.dropdown'\r\n };\r\n const Selector = {\r\n TABLE_RESPONSIVE: '.table-responsive',\r\n DROPDOWN_MENU: '.dropdown-menu'\r\n };\r\n document.querySelectorAll(Selector.TABLE_RESPONSIVE).forEach(table => {\r\n table.addEventListener(Event.SHOWN_BS_DROPDOWN, e => {\r\n const t = e.currentTarget;\r\n if (t.scrollWidth > t.clientWidth) {\r\n t.style.paddingBottom =\r\n e.target.nextElementSibling.clientHeight + 'px';\r\n }\r\n });\r\n table.addEventListener(Event.HIDDEN_BS_DROPDOWN, e => {\r\n e.currentTarget.style.paddingBottom = '';\r\n });\r\n });\r\n }\r\n};\r\n\r\n// Reference\r\n// https://github.com/twbs/bootstrap/issues/11037#issuecomment-274870381\r\n\r\nexport default dropdownMenuInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Open dropdown on hover */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst dropdownOnHover = () => {\r\n const navbarArea = document.querySelector(\"[data-top-nav-dropdowns]\");\r\n\r\n if (navbarArea) {\r\n navbarArea.addEventListener(\"mouseover\", (e) => {\r\n if (\r\n e.target.className.includes(\"dropdown-toggle\") &&\r\n window.innerWidth > 992\r\n ) {\r\n const dropdownInstance = new window.bootstrap.Dropdown(e.target);\r\n \r\n /* eslint-disable no-underscore-dangle */\r\n dropdownInstance._element.classList.add('show')\r\n dropdownInstance._menu.classList.add('show')\r\n dropdownInstance._menu.setAttribute('data-bs-popper', 'none')\r\n \r\n e.target.parentNode.addEventListener(\"mouseleave\", () => {\r\n dropdownInstance.hide();\r\n });\r\n }\r\n });\r\n }\r\n};\r\n\r\nexport default dropdownOnHover;\r\n","/* eslint-disable */\r\nimport utils from './utils';\r\n\r\n/*-----------------------------------------------\r\n| Dropzone\r\n-----------------------------------------------*/\r\n\r\nwindow.Dropzone ? (window.Dropzone.autoDiscover = false) : '';\r\n\r\nconst dropzoneInit = () => {\r\n const { merge } = window._;\r\n\r\n const Selector = {\r\n DROPZONE: '[data-dropzone]',\r\n DZ_ERROR_MESSAGE: '.dz-error-message',\r\n DZ_PREVIEW: '.dz-preview',\r\n DZ_PROGRESS: '.dz-preview .dz-preview-cover .dz-progress',\r\n DZ_PREVIEW_COVER: '.dz-preview .dz-preview-cover'\r\n };\r\n\r\n const ClassName = {\r\n DZ_FILE_PROCESSING: 'dz-file-processing',\r\n DZ_FILE_COMPLETE: 'dz-file-complete',\r\n DZ_COMPLETE: 'dz-complete',\r\n DZ_PROCESSING: 'dz-processing'\r\n };\r\n\r\n const DATA_KEY = {\r\n OPTIONS: 'options'\r\n };\r\n\r\n const Events = {\r\n ADDED_FILE: 'addedfile',\r\n REMOVED_FILE: 'removedfile',\r\n COMPLETE: 'complete'\r\n };\r\n\r\n const dropzones = document.querySelectorAll(Selector.DROPZONE);\r\n\r\n !!dropzones.length &&\r\n dropzones.forEach(item => {\r\n let userOptions = utils.getData(item, DATA_KEY.OPTIONS);\r\n userOptions = userOptions ? userOptions : {};\r\n const data = userOptions.data ? userOptions.data : {};\r\n const options = merge(\r\n {\r\n url: '/assets/php/',\r\n addRemoveLinks: false,\r\n previewsContainer: item.querySelector(Selector.DZ_PREVIEW),\r\n previewTemplate: item.querySelector(Selector.DZ_PREVIEW).innerHTML,\r\n thumbnailWidth: null,\r\n thumbnailHeight: null,\r\n maxFilesize: 20,\r\n autoProcessQueue: false,\r\n filesizeBase: 1000,\r\n init: function init() {\r\n const thisDropzone = this;\r\n\r\n if (data.length) {\r\n data.forEach(v => {\r\n const mockFile = { name: v.name, size: v.size };\r\n thisDropzone.options.addedfile.call(thisDropzone, mockFile);\r\n thisDropzone.options.thumbnail.call(thisDropzone, mockFile, `${v.url}/${v.name}`);\r\n });\r\n }\r\n\r\n thisDropzone.on(Events.ADDED_FILE, function addedfile() {\r\n if ('maxFiles' in userOptions) {\r\n if (\r\n userOptions.maxFiles === 1 &&\r\n item.querySelectorAll(Selector.DZ_PREVIEW_COVER).length > 1\r\n ) {\r\n item.querySelector(Selector.DZ_PREVIEW_COVER).remove();\r\n }\r\n if (userOptions.maxFiles === 1 && this.files.length > 1) {\r\n this.removeFile(this.files[0]);\r\n }\r\n }\r\n });\r\n },\r\n error(file, message) {\r\n if (file.previewElement) {\r\n file.previewElement.classList.add('dz-error');\r\n if (typeof message !== 'string' && message.error) {\r\n message = message.error;\r\n }\r\n for (let node of file.previewElement.querySelectorAll('[data-dz-errormessage]')) {\r\n node.textContent = message;\r\n }\r\n }\r\n }\r\n },\r\n userOptions\r\n );\r\n // eslint-disable-next-line\r\n item.querySelector(Selector.DZ_PREVIEW).innerHTML = '';\r\n\r\n const dropzone = new window.Dropzone(item, options);\r\n\r\n dropzone.on(Events.ADDED_FILE, () => {\r\n if (item.querySelector(Selector.DZ_PREVIEW_COVER)) {\r\n item\r\n .querySelector(Selector.DZ_PREVIEW_COVER)\r\n .classList.remove(ClassName.DZ_FILE_COMPLETE);\r\n }\r\n item.classList.add(ClassName.DZ_FILE_PROCESSING);\r\n });\r\n dropzone.on(Events.REMOVED_FILE, () => {\r\n if (item.querySelector(Selector.DZ_PREVIEW_COVER)) {\r\n item.querySelector(Selector.DZ_PREVIEW_COVER).classList.remove(ClassName.DZ_PROCESSING);\r\n }\r\n item.classList.add(ClassName.DZ_FILE_COMPLETE);\r\n });\r\n dropzone.on(Events.COMPLETE, () => {\r\n if (item.querySelector(Selector.DZ_PREVIEW_COVER)) {\r\n item.querySelector(Selector.DZ_PREVIEW_COVER).classList.remove(ClassName.DZ_PROCESSING);\r\n }\r\n\r\n item.classList.add(ClassName.DZ_FILE_COMPLETE);\r\n });\r\n });\r\n};\r\n\r\nexport default dropzoneInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* from-validation */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst formValidationInit = () => {\r\n // Example starter JavaScript for disabling form submissions if there are invalid fields\r\n \"use strict\";\r\n\r\n // Fetch all the forms we want to apply custom Bootstrap validation styles to\r\n var forms = document.querySelectorAll(\".needs-validation\");\r\n\r\n // Loop over them and prevent submission\r\n Array.prototype.slice.call(forms).forEach(function (form) {\r\n form.addEventListener(\r\n \"submit\",\r\n function (event) {\r\n if (!form.checkValidity()) {\r\n event.preventDefault();\r\n event.stopPropagation();\r\n }\r\n\r\n form.classList.add(\"was-validated\");\r\n },\r\n false\r\n );\r\n });\r\n};\r\n\r\nexport default formValidationInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* FullCalendar */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nimport utils from './utils';\r\nconst { merge } = window._;\r\n\r\nconst renderCalendar = (el, option) => {\r\n const options = merge(\r\n {\r\n initialView: 'dayGridMonth',\r\n editable: true,\r\n direction: document.querySelector('html').getAttribute('dir'),\r\n headerToolbar: {\r\n left: 'prev,next today',\r\n center: 'title',\r\n right: 'dayGridMonth,timeGridWeek,timeGridDay'\r\n },\r\n buttonText: {\r\n month: 'Month',\r\n week: 'Week',\r\n day: 'Day'\r\n }\r\n },\r\n option\r\n );\r\n const calendar = new window.FullCalendar.Calendar(el, options);\r\n calendar.render();\r\n document\r\n .querySelector('.navbar-vertical-toggle')\r\n ?.addEventListener('navbar.vertical.toggle', () => calendar.updateSize());\r\n return calendar;\r\n};\r\n\r\nconst fullCalendarInit = () => {\r\n const calendars = document.querySelectorAll('[data-calendar]');\r\n calendars.forEach(item => {\r\n const options = utils.getData(item, 'calendar');\r\n renderCalendar(item, options);\r\n });\r\n};\r\n\r\nconst fullCalendar = {\r\n renderCalendar,\r\n fullCalendarInit\r\n};\r\nexport default fullCalendar;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Glightbox */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst glightboxInit = () => {\r\n if (window.GLightbox) {\r\n window.GLightbox({\r\n selector: '[data-gallery]',\r\n });\r\n }\r\n};\r\nexport default glightboxInit;\r\n","import utils from './utils';\r\n/*-----------------------------------------------\r\n| Gooogle Map\r\n-----------------------------------------------*/\r\n\r\nfunction initMap() {\r\n const themeController = document.body;\r\n const $googlemaps = document.querySelectorAll('.googlemap');\r\n\r\n if ($googlemaps.length && window.google) {\r\n // Visit https://snazzymaps.com/ for more themes\r\n const mapStyles = {\r\n Default: [\r\n {\r\n featureType: 'water',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#e9e9e9' }, { lightness: 17 }],\r\n },\r\n {\r\n featureType: 'landscape',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#f5f5f5' }, { lightness: 20 }],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#ffffff' }, { lightness: 17 }],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#ffffff' }, { lightness: 29 }, { weight: 0.2 }],\r\n },\r\n {\r\n featureType: 'road.arterial',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#ffffff' }, { lightness: 18 }],\r\n },\r\n {\r\n featureType: 'road.local',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#ffffff' }, { lightness: 16 }],\r\n },\r\n {\r\n featureType: 'poi',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#f5f5f5' }, { lightness: 21 }],\r\n },\r\n {\r\n featureType: 'poi.park',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#dedede' }, { lightness: 21 }],\r\n },\r\n {\r\n elementType: 'labels.text.stroke',\r\n stylers: [\r\n { visibility: 'on' },\r\n { color: '#ffffff' },\r\n { lightness: 16 },\r\n ],\r\n },\r\n {\r\n elementType: 'labels.text.fill',\r\n stylers: [\r\n { saturation: 36 },\r\n { color: '#333333' },\r\n { lightness: 40 },\r\n ],\r\n },\r\n { elementType: 'labels.icon', stylers: [{ visibility: 'off' }] },\r\n {\r\n featureType: 'transit',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#f2f2f2' }, { lightness: 19 }],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#fefefe' }, { lightness: 20 }],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#fefefe' }, { lightness: 17 }, { weight: 1.2 }],\r\n },\r\n ],\r\n Gray: [\r\n {\r\n featureType: 'all',\r\n elementType: 'labels.text.fill',\r\n stylers: [\r\n { saturation: 36 },\r\n { color: '#000000' },\r\n { lightness: 40 },\r\n ],\r\n },\r\n {\r\n featureType: 'all',\r\n elementType: 'labels.text.stroke',\r\n stylers: [\r\n { visibility: 'on' },\r\n { color: '#000000' },\r\n { lightness: 16 },\r\n ],\r\n },\r\n {\r\n featureType: 'all',\r\n elementType: 'labels.icon',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#000000' }, { lightness: 20 }],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#000000' }, { lightness: 17 }, { weight: 1.2 }],\r\n },\r\n {\r\n featureType: 'landscape',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 20 }],\r\n },\r\n {\r\n featureType: 'poi',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 21 }],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#000000' }, { lightness: 17 }],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#000000' }, { lightness: 29 }, { weight: 0.2 }],\r\n },\r\n {\r\n featureType: 'road.arterial',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 18 }],\r\n },\r\n {\r\n featureType: 'road.local',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 16 }],\r\n },\r\n {\r\n featureType: 'transit',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 19 }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 17 }],\r\n },\r\n ],\r\n Midnight: [\r\n {\r\n featureType: 'all',\r\n elementType: 'labels.text.fill',\r\n stylers: [{ color: '#ffffff' }],\r\n },\r\n {\r\n featureType: 'all',\r\n elementType: 'labels.text.stroke',\r\n stylers: [{ color: '#000000' }, { lightness: 13 }],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#000000' }],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#144b53' }, { lightness: 14 }, { weight: 1.4 }],\r\n },\r\n {\r\n featureType: 'landscape',\r\n elementType: 'all',\r\n stylers: [{ color: '#08304b' }],\r\n },\r\n {\r\n featureType: 'poi',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#0c4152' }, { lightness: 5 }],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#000000' }],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#0b434f' }, { lightness: 25 }],\r\n },\r\n {\r\n featureType: 'road.arterial',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#000000' }],\r\n },\r\n {\r\n featureType: 'road.arterial',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#0b3d51' }, { lightness: 16 }],\r\n },\r\n {\r\n featureType: 'road.local',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }],\r\n },\r\n {\r\n featureType: 'transit',\r\n elementType: 'all',\r\n stylers: [{ color: '#146474' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'all',\r\n stylers: [{ color: '#021019' }],\r\n },\r\n ],\r\n Hopper: [\r\n {\r\n featureType: 'water',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#165c64' },\r\n { saturation: 34 },\r\n { lightness: -69 },\r\n { visibility: 'on' },\r\n ],\r\n },\r\n {\r\n featureType: 'landscape',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#b7caaa' },\r\n { saturation: -14 },\r\n { lightness: -18 },\r\n { visibility: 'on' },\r\n ],\r\n },\r\n {\r\n featureType: 'landscape.man_made',\r\n elementType: 'all',\r\n stylers: [\r\n { hue: '#cbdac1' },\r\n { saturation: -6 },\r\n { lightness: -9 },\r\n { visibility: 'on' },\r\n ],\r\n },\r\n {\r\n featureType: 'road',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#8d9b83' },\r\n { saturation: -89 },\r\n { lightness: -12 },\r\n { visibility: 'on' },\r\n ],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#d4dad0' },\r\n { saturation: -88 },\r\n { lightness: 54 },\r\n { visibility: 'simplified' },\r\n ],\r\n },\r\n {\r\n featureType: 'road.arterial',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#bdc5b6' },\r\n { saturation: -89 },\r\n { lightness: -3 },\r\n { visibility: 'simplified' },\r\n ],\r\n },\r\n {\r\n featureType: 'road.local',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#bdc5b6' },\r\n { saturation: -89 },\r\n { lightness: -26 },\r\n { visibility: 'on' },\r\n ],\r\n },\r\n {\r\n featureType: 'poi',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#c17118' },\r\n { saturation: 61 },\r\n { lightness: -45 },\r\n { visibility: 'on' },\r\n ],\r\n },\r\n {\r\n featureType: 'poi.park',\r\n elementType: 'all',\r\n stylers: [\r\n { hue: '#8ba975' },\r\n { saturation: -46 },\r\n { lightness: -28 },\r\n { visibility: 'on' },\r\n ],\r\n },\r\n {\r\n featureType: 'transit',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#a43218' },\r\n { saturation: 74 },\r\n { lightness: -51 },\r\n { visibility: 'simplified' },\r\n ],\r\n },\r\n {\r\n featureType: 'administrative.province',\r\n elementType: 'all',\r\n stylers: [\r\n { hue: '#ffffff' },\r\n { saturation: 0 },\r\n { lightness: 100 },\r\n { visibility: 'simplified' },\r\n ],\r\n },\r\n {\r\n featureType: 'administrative.neighborhood',\r\n elementType: 'all',\r\n stylers: [\r\n { hue: '#ffffff' },\r\n { saturation: 0 },\r\n { lightness: 100 },\r\n { visibility: 'off' },\r\n ],\r\n },\r\n {\r\n featureType: 'administrative.locality',\r\n elementType: 'labels',\r\n stylers: [\r\n { hue: '#ffffff' },\r\n { saturation: 0 },\r\n { lightness: 100 },\r\n { visibility: 'off' },\r\n ],\r\n },\r\n {\r\n featureType: 'administrative.land_parcel',\r\n elementType: 'all',\r\n stylers: [\r\n { hue: '#ffffff' },\r\n { saturation: 0 },\r\n { lightness: 100 },\r\n { visibility: 'off' },\r\n ],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'all',\r\n stylers: [\r\n { hue: '#3a3935' },\r\n { saturation: 5 },\r\n { lightness: -57 },\r\n { visibility: 'off' },\r\n ],\r\n },\r\n {\r\n featureType: 'poi.medical',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#cba923' },\r\n { saturation: 50 },\r\n { lightness: -46 },\r\n { visibility: 'on' },\r\n ],\r\n },\r\n ],\r\n Beard: [\r\n {\r\n featureType: 'poi.business',\r\n elementType: 'labels.text',\r\n stylers: [{ visibility: 'on' }, { color: '#333333' }],\r\n },\r\n ],\r\n AssassianCreed: [\r\n {\r\n featureType: 'all',\r\n elementType: 'all',\r\n stylers: [{ visibility: 'on' }],\r\n },\r\n {\r\n featureType: 'all',\r\n elementType: 'labels',\r\n stylers: [{ visibility: 'off' }, { saturation: '-100' }],\r\n },\r\n {\r\n featureType: 'all',\r\n elementType: 'labels.text.fill',\r\n stylers: [\r\n { saturation: 36 },\r\n { color: '#000000' },\r\n { lightness: 40 },\r\n { visibility: 'off' },\r\n ],\r\n },\r\n {\r\n featureType: 'all',\r\n elementType: 'labels.text.stroke',\r\n stylers: [\r\n { visibility: 'off' },\r\n { color: '#000000' },\r\n { lightness: 16 },\r\n ],\r\n },\r\n {\r\n featureType: 'all',\r\n elementType: 'labels.icon',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#000000' }, { lightness: 20 }],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#000000' }, { lightness: 17 }, { weight: 1.2 }],\r\n },\r\n {\r\n featureType: 'landscape',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 20 }],\r\n },\r\n {\r\n featureType: 'landscape',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#4d6059' }],\r\n },\r\n {\r\n featureType: 'landscape',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#4d6059' }],\r\n },\r\n {\r\n featureType: 'landscape.natural',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#4d6059' }],\r\n },\r\n {\r\n featureType: 'poi',\r\n elementType: 'geometry',\r\n stylers: [{ lightness: 21 }],\r\n },\r\n {\r\n featureType: 'poi',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#4d6059' }],\r\n },\r\n {\r\n featureType: 'poi',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#4d6059' }],\r\n },\r\n {\r\n featureType: 'road',\r\n elementType: 'geometry',\r\n stylers: [{ visibility: 'on' }, { color: '#7f8d89' }],\r\n },\r\n {\r\n featureType: 'road',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#7f8d89' }],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#7f8d89' }, { lightness: 17 }],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#7f8d89' }, { lightness: 29 }, { weight: 0.2 }],\r\n },\r\n {\r\n featureType: 'road.arterial',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 18 }],\r\n },\r\n {\r\n featureType: 'road.arterial',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#7f8d89' }],\r\n },\r\n {\r\n featureType: 'road.arterial',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#7f8d89' }],\r\n },\r\n {\r\n featureType: 'road.local',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 16 }],\r\n },\r\n {\r\n featureType: 'road.local',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#7f8d89' }],\r\n },\r\n {\r\n featureType: 'road.local',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#7f8d89' }],\r\n },\r\n {\r\n featureType: 'transit',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#000000' }, { lightness: 19 }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'all',\r\n stylers: [{ color: '#2b3638' }, { visibility: 'on' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'geometry',\r\n stylers: [{ color: '#2b3638' }, { lightness: 17 }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'geometry.fill',\r\n stylers: [{ color: '#24282b' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'geometry.stroke',\r\n stylers: [{ color: '#24282b' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'labels',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'labels.text',\r\n stylers: [{ visibility: 'off ' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'labels.text.fill',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'labels.text.stroke',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'labels.icon',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n ],\r\n SubtleGray: [\r\n {\r\n featureType: 'administrative',\r\n elementType: 'all',\r\n stylers: [{ saturation: '-100' }],\r\n },\r\n {\r\n featureType: 'administrative.province',\r\n elementType: 'all',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'landscape',\r\n elementType: 'all',\r\n stylers: [\r\n { saturation: -100 },\r\n { lightness: 65 },\r\n { visibility: 'on' },\r\n ],\r\n },\r\n {\r\n featureType: 'poi',\r\n elementType: 'all',\r\n stylers: [\r\n { saturation: -100 },\r\n { lightness: '50' },\r\n { visibility: 'simplified' },\r\n ],\r\n },\r\n {\r\n featureType: 'road',\r\n elementType: 'all',\r\n stylers: [{ saturation: -100 }],\r\n },\r\n {\r\n featureType: 'road.highway',\r\n elementType: 'all',\r\n stylers: [{ visibility: 'simplified' }],\r\n },\r\n {\r\n featureType: 'road.arterial',\r\n elementType: 'all',\r\n stylers: [{ lightness: '30' }],\r\n },\r\n {\r\n featureType: 'road.local',\r\n elementType: 'all',\r\n stylers: [{ lightness: '40' }],\r\n },\r\n {\r\n featureType: 'transit',\r\n elementType: 'all',\r\n stylers: [{ saturation: -100 }, { visibility: 'simplified' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'geometry',\r\n stylers: [\r\n { hue: '#ffff00' },\r\n { lightness: -25 },\r\n { saturation: -97 },\r\n ],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'labels',\r\n stylers: [{ lightness: -25 }, { saturation: -100 }],\r\n },\r\n ],\r\n Tripitty: [\r\n {\r\n featureType: 'all',\r\n elementType: 'labels',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'administrative',\r\n elementType: 'all',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'landscape',\r\n elementType: 'all',\r\n stylers: [{ color: '#2c5ca5' }],\r\n },\r\n {\r\n featureType: 'poi',\r\n elementType: 'all',\r\n stylers: [{ color: '#2c5ca5' }],\r\n },\r\n {\r\n featureType: 'road',\r\n elementType: 'all',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'transit',\r\n elementType: 'all',\r\n stylers: [{ visibility: 'off' }],\r\n },\r\n {\r\n featureType: 'water',\r\n elementType: 'all',\r\n stylers: [{ color: '#193a70' }, { visibility: 'on' }],\r\n },\r\n ],\r\n Cobalt: [\r\n {\r\n featureType: 'all',\r\n elementType: 'all',\r\n stylers: [\r\n {\r\n invert_lightness: true,\r\n },\r\n {\r\n saturation: 10,\r\n },\r\n {\r\n lightness: 30,\r\n },\r\n {\r\n gamma: 0.5,\r\n },\r\n {\r\n hue: '#435158',\r\n },\r\n ],\r\n },\r\n ],\r\n };\r\n\r\n $googlemaps.forEach((itm) => {\r\n const latLng = utils.getData(itm, 'latlng').split(',');\r\n const markerPopup = itm.innerHTML;\r\n const icon = utils.getData(itm, 'icon')\r\n ? utils.getData(itm, 'icon')\r\n : 'https://maps.gstatic.com/mapfiles/api-3/images/spotlight-poi.png';\r\n const zoom = utils.getData(itm, 'zoom');\r\n const mapElement = itm;\r\n const mapStyle = utils.getData(itm, 'theme');\r\n\r\n if (utils.getData(itm, 'theme') === 'streetview') {\r\n const pov = utils.getData(itm, 'pov');\r\n const mapOptions = {\r\n position: { lat: Number(latLng[0]), lng: Number(latLng[1]) },\r\n pov,\r\n zoom,\r\n gestureHandling: 'none',\r\n scrollwheel: false,\r\n };\r\n\r\n return new window.google.maps.StreetViewPanorama(\r\n mapElement,\r\n mapOptions\r\n );\r\n }\r\n\r\n const mapOptions = {\r\n zoom,\r\n scrollwheel: utils.getData(itm, 'scrollwheel'),\r\n center: new window.google.maps.LatLng(latLng[0], latLng[1]),\r\n styles:\r\n localStorage.getItem('theme') === 'dark'\r\n ? mapStyles.Cobalt\r\n : mapStyles[mapStyle],\r\n };\r\n\r\n const map = new window.google.maps.Map(mapElement, mapOptions);\r\n const infowindow = new window.google.maps.InfoWindow({\r\n content: markerPopup,\r\n });\r\n const marker = new window.google.maps.Marker({\r\n position: new window.google.maps.LatLng(latLng[0], latLng[1]),\r\n icon,\r\n map,\r\n });\r\n\r\n marker.addListener('click', () => {\r\n infowindow.open(map, marker);\r\n });\r\n\r\n themeController &&\r\n themeController.addEventListener(\r\n 'clickControl',\r\n ({ detail: { control, value } }) => {\r\n if (control === 'theme') {\r\n map.set(\r\n 'styles',\r\n value === 'dark' ? mapStyles.Cobalt : mapStyles[mapStyle]\r\n );\r\n }\r\n }\r\n );\r\n return null;\r\n });\r\n }\r\n}\r\n\r\nexport default initMap;\r\n","const hideOnCollapseInit = () => {\r\n\r\n const previewMailForm = document.querySelector('#previewMailForm')\r\n const previewFooter = document.querySelector('#preview-footer')\r\n if (previewMailForm) {\r\n previewMailForm.addEventListener(\"show.bs.collapse\", () => {\r\n previewFooter.classList.add(\"d-none\");\r\n })\r\n }\r\n\r\n}\r\n\r\nexport default hideOnCollapseInit;","/* -------------------------------------------------------------------------- */\r\n/* Icon copy to clipboard */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst iconCopiedInit = () => {\r\n const iconList = document.getElementById(\"icon-list\");\r\n const iconCopiedToast = document.getElementById(\"icon-copied-toast\");\r\n const iconCopiedToastInstance = new window.bootstrap.Toast(iconCopiedToast);\r\n\r\n if (iconList) {\r\n iconList.addEventListener(\"click\", (e) => {\r\n const el = e.target;\r\n if (el.tagName === \"INPUT\") {\r\n el.select();\r\n el.setSelectionRange(0, 99999);\r\n document.execCommand(\"copy\");\r\n iconCopiedToast.querySelector(\r\n \".toast-body\"\r\n ).innerHTML = `Copied: ${el.value}`;\r\n iconCopiedToastInstance.show();\r\n }\r\n });\r\n }\r\n};\r\n\r\nexport default iconCopiedInit;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Inputmask */\r\n/* -------------------------------------------------------------------------- */\r\nconst inputmaskInit = () => {\r\n if (window.Inputmask) {\r\n const elements = document.querySelectorAll('[data-input-mask]');\r\n elements.forEach(item => {\r\n const userOptions = utils.getData(item, 'input-mask');\r\n const defaultOptions = {\r\n showMaskOnFocus: false,\r\n showMaskOnHover: false,\r\n jitMasking: true\r\n };\r\n const maskOptions = window._.merge(defaultOptions, userOptions);\r\n const inputmask = new window.Inputmask({\r\n ...maskOptions\r\n }).mask(item);\r\n\r\n return inputmask;\r\n });\r\n }\r\n};\r\n\r\nexport default inputmaskInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Kanbah */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nimport utils from './utils';\r\n\r\nconst kanbanInit = () => {\r\n const Selectors = {\r\n KANBAN_COLUMN: '.kanban-column',\r\n KANBAN_ITEMS_CONTAINER: '.kanban-items-container',\r\n BTN_ADD_CARD: '.btn-add-card',\r\n COLLAPSE: '.collapse',\r\n ADD_LIST_FORM: '#addListForm',\r\n BTN_COLLAPSE_DISMISS: '[data-dismiss=\"collapse\"]',\r\n BTN_FORM_HIDE: '[data-btn-form=\"hide\"]',\r\n INPUT_ADD_CARD: '[data-input=\"add-card\"]',\r\n INPUT_ADD_LIST: '[data-input=\"add-list\"]',\r\n };\r\n\r\n const ClassNames = {\r\n FORM_ADDED: 'form-added',\r\n D_NONE: 'd-none',\r\n };\r\n\r\n const Events = {\r\n CLICK: 'click',\r\n SHOW_BS_COLLAPSE: 'show.bs.collapse',\r\n SHOWN_BS_COLLAPSE: 'shown.bs.collapse',\r\n };\r\n\r\n const addCardButtons = document.querySelectorAll(Selectors.BTN_ADD_CARD);\r\n const formHideButtons = document.querySelectorAll(Selectors.BTN_FORM_HIDE);\r\n const addListForm = document.querySelector(Selectors.ADD_LIST_FORM);\r\n const collapseDismissButtons = document.querySelectorAll(\r\n Selectors.BTN_COLLAPSE_DISMISS\r\n );\r\n\r\n // Show add card form and place scrollbar bottom of the list\r\n addCardButtons &&\r\n addCardButtons.forEach((button) => {\r\n button.addEventListener(Events.CLICK, ({ currentTarget: el }) => {\r\n const column = el.closest(Selectors.KANBAN_COLUMN);\r\n const container = column.querySelector(\r\n Selectors.KANBAN_ITEMS_CONTAINER\r\n );\r\n const scrollHeight = container.scrollHeight;\r\n\r\n column.classList.add(ClassNames.FORM_ADDED);\r\n container.querySelector(Selectors.INPUT_ADD_CARD).focus();\r\n container.scrollTo({ top: scrollHeight });\r\n });\r\n });\r\n\r\n // Remove add card form\r\n formHideButtons.forEach((button) => {\r\n button.addEventListener(Events.CLICK, ({ currentTarget: el }) => {\r\n el.closest(Selectors.KANBAN_COLUMN).classList.remove(\r\n ClassNames.FORM_ADDED\r\n );\r\n });\r\n });\r\n\r\n if (addListForm) {\r\n // Hide add list button when the form is going to show\r\n addListForm.addEventListener(\r\n Events.SHOW_BS_COLLAPSE,\r\n ({ currentTarget: el }) => {\r\n const nextElement = el.nextElementSibling;\r\n nextElement && nextElement.classList.add(ClassNames.D_NONE);\r\n }\r\n );\r\n\r\n // Focus input field when the form is shown\r\n addListForm.addEventListener(\r\n Events.SHOWN_BS_COLLAPSE,\r\n ({ currentTarget: el }) => {\r\n el.querySelector(Selectors.INPUT_ADD_LIST).focus();\r\n }\r\n );\r\n }\r\n\r\n // Hide add list form when the dismiss button is clicked\r\n collapseDismissButtons.forEach((button) => {\r\n button.addEventListener(Events.CLICK, ({ currentTarget: el }) => {\r\n const collapseElement = el.closest(Selectors.COLLAPSE);\r\n const collapse = window.bootstrap.Collapse.getInstance(collapseElement);\r\n\r\n utils.hasClass(collapseElement.nextElementSibling, ClassNames.D_NONE) &&\r\n collapseElement.nextElementSibling.classList.remove(ClassNames.D_NONE);\r\n collapse.hide();\r\n });\r\n });\r\n};\r\n\r\nexport default kanbanInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* leaflet */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst leafletActiveUserInit = () => {\r\n const points = [\r\n {\r\n lat: 53.958332,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 52.958332,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 51.958332,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 53.958332,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 54.958332,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 55.958332,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 53.908332,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 53.008332,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 53.158332,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 53.000032,\r\n long: -1.080278,\r\n name: 'Diana Meyer',\r\n street: 'Slude Strand 27',\r\n location: '1130 Kobenhavn'\r\n },\r\n {\r\n lat: 52.292001,\r\n long: -2.22,\r\n name: 'Anke Schroder',\r\n street: 'Industrivej 54',\r\n location: '4140 Borup'\r\n },\r\n {\r\n lat: 52.392001,\r\n long: -2.22,\r\n name: 'Anke Schroder',\r\n street: 'Industrivej 54',\r\n location: '4140 Borup'\r\n },\r\n {\r\n lat: 51.492001,\r\n long: -2.22,\r\n name: 'Anke Schroder',\r\n street: 'Industrivej 54',\r\n location: '4140 Borup'\r\n },\r\n {\r\n lat: 51.192001,\r\n long: -2.22,\r\n name: 'Anke Schroder',\r\n street: 'Industrivej 54',\r\n location: '4140 Borup'\r\n },\r\n {\r\n lat: 52.292001,\r\n long: -2.22,\r\n name: 'Anke Schroder',\r\n street: 'Industrivej 54',\r\n location: '4140 Borup'\r\n },\r\n {\r\n lat: 54.392001,\r\n long: -2.22,\r\n name: 'Anke Schroder',\r\n street: 'Industrivej 54',\r\n location: '4140 Borup'\r\n },\r\n {\r\n lat: 51.292001,\r\n long: -2.22,\r\n name: 'Anke Schroder',\r\n street: 'Industrivej 54',\r\n location: '4140 Borup'\r\n },\r\n {\r\n lat: 52.102001,\r\n long: -2.22,\r\n name: 'Anke Schroder',\r\n street: 'Industrivej 54',\r\n location: '4140 Borup'\r\n },\r\n {\r\n lat: 52.202001,\r\n long: -2.22,\r\n name: 'Anke Schroder',\r\n street: 'Industrivej 54',\r\n location: '4140 Borup'\r\n },\r\n {\r\n lat: 51.063202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.363202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.463202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.563202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.763202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.863202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.963202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.000202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.000202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.163202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 52.263202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 53.463202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 55.163202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 56.263202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 56.463202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 56.563202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 56.663202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 56.763202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 56.863202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 56.963202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 57.973202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 57.163202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.163202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.263202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.363202,\r\n long: -1.308,\r\n name: 'Tobias Vogel',\r\n street: 'Mollebakken 33',\r\n location: '3650 Olstykke'\r\n },\r\n {\r\n lat: 51.409,\r\n long: -2.647,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.68,\r\n long: -1.49,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 50.259998,\r\n long: -5.051,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 54.906101,\r\n long: -1.38113,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.383331,\r\n long: -1.466667,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.483002,\r\n long: -2.2931,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 51.509865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 51.109865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 51.209865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 51.309865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 51.409865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 51.609865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 51.709865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 51.809865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 51.909865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.109865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.209865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.309865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.409865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.509865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.609865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.709865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.809865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.909865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.519865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.529865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.539865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.549865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 52.549865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.109865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.209865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.319865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.329865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.409865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.559865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.619865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.629865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.639865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.649865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.669865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.669865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.719865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.739865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.749865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.759865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.769865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.769865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.819865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.829865,\r\n long: -0.118092,\r\n name: 'Richard Hendricks',\r\n street: '37 Seafield Place',\r\n location: 'London'\r\n },\r\n {\r\n lat: 53.483959,\r\n long: -2.244644,\r\n name: 'Ethel B. Brooks',\r\n street: '2576 Sun Valley Road'\r\n },\r\n {\r\n lat: 40.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 39.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 38.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 37.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 40.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 41.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 42.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 43.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 44.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 45.737,\r\n long: -73.923,\r\n name: 'Marshall D. Lewis',\r\n street: '1489 Michigan Avenue',\r\n location: 'Michigan'\r\n },\r\n {\r\n lat: 46.7128,\r\n long: 74.006,\r\n name: 'Elizabeth C. Lyons',\r\n street: '4553 Kenwood Place',\r\n location: 'Fort Lauderdale'\r\n },\r\n {\r\n lat: 40.7128,\r\n long: 74.1181,\r\n name: 'Elizabeth C. Lyons',\r\n street: '4553 Kenwood Place',\r\n location: 'Fort Lauderdale'\r\n },\r\n {\r\n lat: 14.235,\r\n long: 51.9253,\r\n name: 'Ralph D. Wylie',\r\n street: '3186 Levy Court',\r\n location: 'North Reading'\r\n },\r\n {\r\n lat: 15.235,\r\n long: 51.9253,\r\n name: 'Ralph D. Wylie',\r\n street: '3186 Levy Court',\r\n location: 'North Reading'\r\n },\r\n {\r\n lat: 16.235,\r\n long: 51.9253,\r\n name: 'Ralph D. Wylie',\r\n street: '3186 Levy Court',\r\n location: 'North Reading'\r\n },\r\n {\r\n lat: 14.235,\r\n long: 51.9253,\r\n name: 'Ralph D. Wylie',\r\n street: '3186 Levy Court',\r\n location: 'North Reading'\r\n },\r\n {\r\n lat: 15.8267,\r\n long: 47.9218,\r\n name: 'Hope A. Atkins',\r\n street: '3715 Hillcrest Drive',\r\n location: 'Seattle'\r\n },\r\n {\r\n lat: 15.9267,\r\n long: 47.9218,\r\n name: 'Hope A. Atkins',\r\n street: '3715 Hillcrest Drive',\r\n location: 'Seattle'\r\n },\r\n {\r\n lat: 23.4425,\r\n long: 58.4438,\r\n name: 'Samuel R. Bailey',\r\n street: '2883 Raoul Wallenberg Place',\r\n location: 'Cheshire'\r\n },\r\n {\r\n lat: 23.5425,\r\n long: 58.3438,\r\n name: 'Samuel R. Bailey',\r\n street: '2883 Raoul Wallenberg Place',\r\n location: 'Cheshire'\r\n },\r\n {\r\n lat: -37.8927369333,\r\n long: 175.4087452333,\r\n name: 'Samuel R. Bailey',\r\n street: '3228 Glory Road',\r\n location: 'Nashville'\r\n },\r\n {\r\n lat: -38.9064188833,\r\n long: 175.4441556833,\r\n name: 'Samuel R. Bailey',\r\n street: '3228 Glory Road',\r\n location: 'Nashville'\r\n },\r\n {\r\n lat: -12.409874,\r\n long: -65.596832,\r\n name: 'Ann J. Perdue',\r\n street: '921 Ella Street',\r\n location: 'Dublin'\r\n },\r\n {\r\n lat: -22.090887,\r\n long: -57.411827,\r\n name: 'Jorge C. Woods',\r\n street: '4800 North Bend River Road',\r\n location: 'Allen'\r\n },\r\n {\r\n lat: -19.019585,\r\n long: -65.261963,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: -16.500093,\r\n long: -68.214684,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: -17.413977,\r\n long: -66.165321,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: -16.489689,\r\n long: -68.119293,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: 54.766323,\r\n long: 3.08603729,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: 54.866323,\r\n long: 3.08603729,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: 49.537685,\r\n long: 3.08603729,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: 54.715424,\r\n long: 0.509207,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: 44.891666,\r\n long: 10.136665,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: 48.078335,\r\n long: 14.535004,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: -26.358055,\r\n long: 27.398056,\r\n name: 'Russ E. Panek',\r\n street: '4068 Hartland Avenue',\r\n location: 'Appleton'\r\n },\r\n {\r\n lat: -29.1,\r\n long: 26.2167,\r\n name: 'Wilbur J. Dry',\r\n street: '2043 Jadewood Drive',\r\n location: 'Northbrook'\r\n },\r\n {\r\n lat: -29.883333,\r\n long: 31.049999,\r\n name: 'Wilbur J. Dry',\r\n street: '2043 Jadewood Drive',\r\n location: 'Northbrook'\r\n },\r\n {\r\n lat: -26.266111,\r\n long: 27.865833,\r\n name: 'Wilbur J. Dry',\r\n street: '2043 Jadewood Drive',\r\n location: 'Northbrook'\r\n },\r\n {\r\n lat: -29.087217,\r\n long: 26.154898,\r\n name: 'Wilbur J. Dry',\r\n street: '2043 Jadewood Drive',\r\n location: 'Northbrook'\r\n },\r\n {\r\n lat: -33.958252,\r\n long: 25.619022,\r\n name: 'Wilbur J. Dry',\r\n street: '2043 Jadewood Drive',\r\n location: 'Northbrook'\r\n },\r\n {\r\n lat: -33.977074,\r\n long: 22.457581,\r\n name: 'Wilbur J. Dry',\r\n street: '2043 Jadewood Drive',\r\n location: 'Northbrook'\r\n },\r\n {\r\n lat: -26.563404,\r\n long: 27.844164,\r\n name: 'Wilbur J. Dry',\r\n street: '2043 Jadewood Drive',\r\n location: 'Northbrook'\r\n },\r\n {\r\n lat: 51.21389,\r\n long: -102.462776,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 52.321945,\r\n long: -106.584167,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 50.288055,\r\n long: -107.793892,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 52.7575,\r\n long: -108.28611,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 50.393333,\r\n long: -105.551941,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 50.930557,\r\n long: -102.807777,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 52.856388,\r\n long: -104.610001,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 52.289722,\r\n long: -106.666664,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 52.201942,\r\n long: -105.123055,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 53.278046,\r\n long: -110.00547,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 49.13673,\r\n long: -102.990959,\r\n name: 'Joseph B. Poole',\r\n street: '3364 Lunetta Street',\r\n location: 'Wichita Falls'\r\n },\r\n {\r\n lat: 45.484531,\r\n long: -73.597023,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 45.266666,\r\n long: -71.900002,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 45.349998,\r\n long: -72.51667,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 47.333332,\r\n long: -79.433334,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 45.400002,\r\n long: -74.033333,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 45.683334,\r\n long: -73.433334,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 48.099998,\r\n long: -77.783333,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 45.5,\r\n long: -72.316666,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 46.349998,\r\n long: -72.550003,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 48.119999,\r\n long: -69.18,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 45.599998,\r\n long: -75.25,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 46.099998,\r\n long: -71.300003,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 45.700001,\r\n long: -73.633331,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 47.68,\r\n long: -68.879997,\r\n name: 'Claudette D. Nowakowski',\r\n street: '3742 Farland Avenue',\r\n location: 'San Antonio'\r\n },\r\n {\r\n lat: 46.716667,\r\n long: -79.099998,\r\n name: '299'\r\n },\r\n {\r\n lat: 45.016666,\r\n long: -72.099998,\r\n name: '299'\r\n }\r\n ];\r\n\r\n const { L } = window;\r\n const mapContainer = document.getElementById('map');\r\n if (L && mapContainer) {\r\n const getFilterColor = () =>\r\n localStorage.getItem('theme') === 'dark'\r\n ? [\r\n 'invert:98%',\r\n 'grayscale:69%',\r\n 'bright:89%',\r\n 'contrast:111%',\r\n 'hue:205deg',\r\n 'saturate:1000%'\r\n ]\r\n : ['bright:101%', 'contrast:101%', 'hue:23deg', 'saturate:225%'];\r\n\r\n const tileLayerTheme =\r\n 'https://{s}.basemaps.cartocdn.com/light_all/{z}/{x}/{y}{r}.png';\r\n\r\n const tiles = L.tileLayer.colorFilter(tileLayerTheme, {\r\n attribution: null,\r\n transparent: true,\r\n filter: getFilterColor()\r\n });\r\n\r\n const map = L.map('map', {\r\n center: L.latLng(10.737, 0),\r\n zoom: 0,\r\n layers: [tiles],\r\n minZoom: 1.3,\r\n zoomSnap: 0.5,\r\n dragging: !L.Browser.mobile,\r\n tap: !L.Browser.mobile\r\n });\r\n\r\n const mcg = L.markerClusterGroup({\r\n chunkedLoading: false,\r\n spiderfyOnMaxZoom: false\r\n });\r\n\r\n points.map(point => {\r\n const { name, location, street } = point;\r\n const icon = L.icon({\r\n iconUrl: `data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAACXBIWXMAAAFgAAABYAEg2RPaAAADpElEQVRYCZ1XS1LbQBBtybIdiMEJKSpUqihgEW/xDdARyAnirOIl3MBH8NK7mBvkBpFv4Gy9IRSpFIQiRPyNfqkeZkY9HwmFt7Lm06+7p/vN2MmyDIrQ6QebALAHAD4AbFuWfQeAAACGs5H/w5jlsJJw4wMA+GhMFuMA99jIDJJOP+ihZwDQFmNuowWO1wS3viDXpdEdZPEc0odruj0EgN5s5H8tJOEEX8R3rbkMtcU34NTqhe5nSQTJ7Tkk80s6/Gk28scGiULguFBffgdufdEwWoQ0uoXo8hdAlooVH0REjISfwZSlyHGh0V5n6aHAtKTxXI5g6nQnMH0P4bEgwtR18Yw8Pj8QZ4ARUAI0Hl+fQZZGisGEBVwHr7XKzox57DXZ/ij8Cdwe2u057z9/wygOxRl4S2vSUHx1oucaMQGAHTrgtdag9mK5aN+Wx/uAAQ9Zenp/SRce4TpaNbQK4+sTcGqeTB/aIXv3XN5oj2VKqii++U0JunpZ8urxee4hvjqVc2hHpBDXuKKT9XMgVYJ1/1fPGSeaikzgmWWkMIi9bVf8UhotXxzORn5gWFchI8QyttlzjS0qpsaIGY2MMsujV/AUSdcY0dDpB6/EiOPYzclR1CI5mOez3ekHvrFLxa7cR5pTscfrXjk0Vhm5V2PqLUWnH3R5GbPGpMVD7E1ckXesKBQ7AS/vmQ1c0+kHuxpBj98lTCm8pbc5QRJRdZ6qHb/wGryXq3Lxszv+5gySuwvxueXySwYvHEjuQ9ofTGKYlrmK1EsCHMd5SoD7mZ1HHFCBHLNbMEshvrugqWLn01hpVVJhFgVGkDvK7hR6n2B+d9C7xsqWsbkqHv4cCsWezEb+o2SR+SFweUBxfA5wH7kShjKt2vWL57Px3GhIFEezkb8pxvUWHYhotAfCk2AtkEcxoOttrxUWDR5svb1emSQKj0WXK1HYIgFREbiBqmoZcB2RkbE+byMZiosorVgAZF1ID7yQhEs38wa7nUqNDezdlavC2HbBGSQkGgZ8uJVBmzeiKCRRpEa9ilWghORVeGB7BxeSKF5xqbFBkxBrFKUk/JHA7ppENQaCnCjthK+3opCEYyANztXmZN858cDYWSUSHk3A311GAZDvo6deNKUk1EsqnJoQlkYBNlmxQZeaMgmxoUokICoHDce351RCCiuKoirJWEgNOYvQplM2VCLhUqF7jf94rW9kHVUjQeheV4riv0i4ZOzzz/2y/+0KAOAfr4EE4HpCFhwAAAAASUVORK5CYII=\r\n `\r\n });\r\n const marker = L.marker(\r\n new L.LatLng(point.lat, point.long),\r\n { icon },\r\n {\r\n name,\r\n location\r\n }\r\n );\r\n const popupContent = `\r\n
    ${name}
    \r\n

    ${street}, ${location}

    \r\n `;\r\n const popup = L.popup({ minWidth: 180 }).setContent(popupContent);\r\n marker.bindPopup(popup);\r\n mcg.addLayer(marker);\r\n return true;\r\n });\r\n map.addLayer(mcg);\r\n const themeController = document.body;\r\n\r\n themeController.addEventListener(\r\n 'clickControl',\r\n ({ detail: { control, value } }) => {\r\n if (control === 'theme') {\r\n tiles.updateFilter(\r\n value === 'dark'\r\n ? [\r\n 'invert:98%',\r\n 'grayscale:69%',\r\n 'bright:89%',\r\n 'contrast:111%',\r\n 'hue:205deg',\r\n 'saturate:1000%'\r\n ]\r\n : ['bright:101%', 'contrast:101%', 'hue:23deg', 'saturate:225%']\r\n );\r\n }\r\n }\r\n );\r\n }\r\n};\r\n\r\nexport default leafletActiveUserInit;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Data Table */\r\n/* -------------------------------------------------------------------------- */\r\n/* eslint-disable */\r\n\r\nconst togglePaginationButtonDisable = (button, disabled) => {\r\n button.disabled = disabled;\r\n button.classList[disabled ? 'add' : 'remove']('disabled');\r\n};\r\n\r\nconst listInit = () => {\r\n if (window.List) {\r\n const lists = document.querySelectorAll('[data-list]');\r\n\r\n if (lists.length) {\r\n lists.forEach(el => {\r\n const bulkSelect = el.querySelector('[data-bulk-select]');\r\n let options = utils.getData(el, 'list');\r\n\r\n if (options.pagination) {\r\n options = {\r\n ...options,\r\n pagination: {\r\n item: \"
  • \",\r\n ...options.pagination\r\n }\r\n };\r\n }\r\n\r\n const paginationButtonNext = el.querySelector(\r\n '[data-list-pagination=\"next\"]'\r\n );\r\n const paginationButtonPrev = el.querySelector(\r\n '[data-list-pagination=\"prev\"]'\r\n );\r\n const viewAll = el.querySelector('[data-list-view=\"*\"]');\r\n const viewLess = el.querySelector('[data-list-view=\"less\"]');\r\n const listInfo = el.querySelector('[data-list-info]');\r\n const listFilter = document.querySelector('[data-list-filter]');\r\n const list = new window.List(el, options);\r\n\r\n //-------fallback-----------\r\n\r\n list.on('updated', item => {\r\n const fallback =\r\n el.querySelector('.fallback') ||\r\n document.getElementById(options.fallback);\r\n\r\n if (fallback) {\r\n if (item.matchingItems.length === 0) {\r\n fallback.classList.remove('d-none');\r\n } else {\r\n fallback.classList.add('d-none');\r\n }\r\n }\r\n });\r\n\r\n // ---------------------------------------\r\n\r\n const totalItem = list.items.length;\r\n const itemsPerPage = list.page;\r\n const btnDropdownClose = list.listContainer.querySelector('.btn-close');\r\n let pageQuantity = Math.ceil(totalItem / itemsPerPage);\r\n let numberOfcurrentItems = list.visibleItems.length;\r\n let pageCount = 1;\r\n\r\n btnDropdownClose &&\r\n btnDropdownClose.addEventListener('search.close', () => {\r\n list.fuzzySearch('');\r\n });\r\n\r\n const updateListControls = () => {\r\n listInfo &&\r\n (listInfo.innerHTML = `${list.i} to ${numberOfcurrentItems} of ${totalItem}`);\r\n paginationButtonPrev &&\r\n togglePaginationButtonDisable(\r\n paginationButtonPrev,\r\n pageCount === 1\r\n );\r\n paginationButtonNext &&\r\n togglePaginationButtonDisable(\r\n paginationButtonNext,\r\n pageCount === pageQuantity\r\n );\r\n\r\n if (pageCount > 1 && pageCount < pageQuantity) {\r\n togglePaginationButtonDisable(paginationButtonNext, false);\r\n togglePaginationButtonDisable(paginationButtonPrev, false);\r\n }\r\n };\r\n\r\n // List info\r\n updateListControls();\r\n\r\n if (paginationButtonNext) {\r\n paginationButtonNext.addEventListener('click', e => {\r\n e.preventDefault();\r\n pageCount += 1;\r\n\r\n const nextInitialIndex = list.i + itemsPerPage;\r\n nextInitialIndex <= list.size() &&\r\n list.show(nextInitialIndex, itemsPerPage);\r\n numberOfcurrentItems += list.visibleItems.length;\r\n updateListControls();\r\n });\r\n }\r\n\r\n if (paginationButtonPrev) {\r\n paginationButtonPrev.addEventListener('click', e => {\r\n e.preventDefault();\r\n pageCount -= 1;\r\n\r\n numberOfcurrentItems -= list.visibleItems.length;\r\n const prevItem = list.i - itemsPerPage;\r\n prevItem > 0 && list.show(prevItem, itemsPerPage);\r\n updateListControls();\r\n });\r\n }\r\n\r\n const toggleViewBtn = () => {\r\n viewLess.classList.toggle('d-none');\r\n viewAll.classList.toggle('d-none');\r\n };\r\n\r\n if (viewAll) {\r\n viewAll.addEventListener('click', () => {\r\n list.show(1, totalItem);\r\n pageQuantity = 1;\r\n pageCount = 1;\r\n numberOfcurrentItems = totalItem;\r\n updateListControls();\r\n toggleViewBtn();\r\n });\r\n }\r\n if (viewLess) {\r\n viewLess.addEventListener('click', () => {\r\n list.show(1, itemsPerPage);\r\n pageQuantity = Math.ceil(totalItem / itemsPerPage);\r\n pageCount = 1;\r\n numberOfcurrentItems = list.visibleItems.length;\r\n updateListControls();\r\n toggleViewBtn();\r\n });\r\n }\r\n // numbering pagination\r\n if (options.pagination) {\r\n el.querySelector('.pagination').addEventListener('click', e => {\r\n if (e.target.classList[0] === 'page') {\r\n pageCount = Number(e.target.innerText);\r\n updateListControls();\r\n }\r\n });\r\n }\r\n if (options.filter) {\r\n const { key } = options.filter;\r\n listFilter.addEventListener('change', e => {\r\n list.filter(item => {\r\n if (e.target.value === '') {\r\n return true;\r\n }\r\n return item\r\n .values()\r\n [key].toLowerCase()\r\n .includes(e.target.value.toLowerCase());\r\n });\r\n });\r\n }\r\n\r\n //bulk-select\r\n if (bulkSelect) {\r\n const bulkSelectInstance = window.BulkSelect.getInstance(bulkSelect);\r\n bulkSelectInstance.attachRowNodes(\r\n list.items.map(item =>\r\n item.elm.querySelector('[data-bulk-select-row]')\r\n )\r\n );\r\n\r\n bulkSelect.addEventListener('change', () => {\r\n if (list) {\r\n if (bulkSelect.checked) {\r\n list.items.forEach(item => {\r\n item.elm.querySelector(\r\n '[data-bulk-select-row]'\r\n ).checked = true;\r\n });\r\n } else {\r\n list.items.forEach(item => {\r\n item.elm.querySelector(\r\n '[data-bulk-select-row]'\r\n ).checked = false;\r\n });\r\n }\r\n }\r\n });\r\n }\r\n });\r\n }\r\n }\r\n};\r\n\r\nexport default listInit;\r\n","import utils from \"./utils\";\r\n\r\nconst lottieInit = () => {\r\n const lotties = document.querySelectorAll(\".lottie\");\r\n if (lotties.length) {\r\n lotties.forEach((item) => {\r\n const options = utils.getData(item, \"options\");\r\n window.bodymovin.loadAnimation({\r\n container: item,\r\n path: \"../img/animated-icons/warning-light.json\",\r\n renderer: \"svg\",\r\n loop: true,\r\n autoplay: true,\r\n name: \"Hello World\",\r\n ...options,\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default lottieInit;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Navbar Combo Layout */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst navbarComboInit = () => {\r\n const Selector = {\r\n NAVBAR_VERTICAL: '.navbar-vertical',\r\n NAVBAR_TOP_COMBO: '[data-navbar-top=\"combo\"]',\r\n COLLAPSE: '.collapse',\r\n DATA_MOVE_CONTAINER: '[data-move-container]',\r\n NAVBAR_NAV: '.navbar-nav',\r\n NAVBAR_VERTICAL_DIVIDER: '.navbar-vertical-divider',\r\n };\r\n\r\n const ClassName = {\r\n FLEX_COLUMN: 'flex-column',\r\n };\r\n\r\n const navbarVertical = document.querySelector(Selector.NAVBAR_VERTICAL);\r\n const navbarTopCombo = document.querySelector(Selector.NAVBAR_TOP_COMBO);\r\n\r\n const moveNavContent = (windowWidth) => {\r\n const navbarVerticalBreakpoint = utils.getBreakpoint(navbarVertical);\r\n const navbarTopBreakpoint = utils.getBreakpoint(navbarTopCombo);\r\n\r\n if (windowWidth < navbarTopBreakpoint) {\r\n const navbarCollapse = navbarTopCombo.querySelector(Selector.COLLAPSE);\r\n const navbarTopContent = navbarCollapse.innerHTML;\r\n\r\n if (navbarTopContent) {\r\n const targetID = utils.getData(navbarTopCombo, 'move-target');\r\n const targetElement = document.querySelector(targetID);\r\n\r\n navbarCollapse.innerHTML = '';\r\n targetElement.insertAdjacentHTML(\r\n 'afterend',\r\n `\r\n
    \r\n \r\n ${navbarTopContent}\r\n
    \r\n `\r\n );\r\n\r\n if (navbarVerticalBreakpoint < navbarTopBreakpoint) {\r\n const navbarNav = document\r\n .querySelector(Selector.DATA_MOVE_CONTAINER)\r\n .querySelector(Selector.NAVBAR_NAV);\r\n utils.addClass(navbarNav, ClassName.FLEX_COLUMN);\r\n }\r\n }\r\n } else {\r\n const moveableContainer = document.querySelector(\r\n Selector.DATA_MOVE_CONTAINER\r\n );\r\n if (moveableContainer) {\r\n const navbarNav = moveableContainer.querySelector(Selector.NAVBAR_NAV);\r\n utils.hasClass(navbarNav, ClassName.FLEX_COLUMN) &&\r\n navbarNav.classList.remove(ClassName.FLEX_COLUMN);\r\n moveableContainer\r\n .querySelector(Selector.NAVBAR_VERTICAL_DIVIDER)\r\n .remove();\r\n navbarTopCombo.querySelector(Selector.COLLAPSE).innerHTML =\r\n moveableContainer.innerHTML;\r\n moveableContainer.remove();\r\n }\r\n }\r\n };\r\n\r\n moveNavContent(window.innerWidth);\r\n\r\n utils.resize(() => moveNavContent(window.innerWidth));\r\n};\r\n\r\nexport default navbarComboInit;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Navbar Darken on scroll */\r\n/* -------------------------------------------------------------------------- */\r\nconst navbarDarkenOnScroll = () => {\r\n const Selector = {\r\n NAVBAR: '[data-navbar-darken-on-scroll]',\r\n NAVBAR_COLLAPSE: '.navbar-collapse',\r\n NAVBAR_TOGGLER: '.navbar-toggler',\r\n };\r\n\r\n const ClassNames = {\r\n COLLAPSED: 'collapsed',\r\n };\r\n\r\n const Events = {\r\n SCROLL: 'scroll',\r\n SHOW_BS_COLLAPSE: 'show.bs.collapse',\r\n HIDE_BS_COLLAPSE: 'hide.bs.collapse',\r\n HIDDEN_BS_COLLAPSE: 'hidden.bs.collapse',\r\n };\r\n\r\n const DataKey = {\r\n NAVBAR_DARKEN_ON_SCROLL: 'navbar-darken-on-scroll',\r\n };\r\n\r\n const navbar = document.querySelector(Selector.NAVBAR);\r\n\r\n function removeNavbarBgClass() {\r\n navbar.classList.remove('bg-dark');\r\n navbar.classList.remove('bg-100');\r\n }\r\n\r\n const toggleThemeClass = (theme) => {\r\n if (theme === 'dark') {\r\n navbar.classList.remove('navbar-dark');\r\n navbar.classList.add('navbar-light');\r\n } else {\r\n navbar.classList.remove('navbar-light');\r\n navbar.classList.add('navbar-dark');\r\n }\r\n };\r\n\r\n function getBgClassName(name, defaultColorName) {\r\n const parent = document.documentElement;\r\n const allColors = {\r\n ...utils.getColors(parent),\r\n ...utils.getGrays(parent),\r\n };\r\n\r\n const colorName = Object.keys(allColors).includes(name)\r\n ? name\r\n : defaultColorName;\r\n const color = allColors[colorName];\r\n const bgClassName = `bg-${colorName}`;\r\n return { color, bgClassName };\r\n }\r\n\r\n if (navbar) {\r\n const theme = localStorage.getItem('theme');\r\n let defaultColorName = theme === 'dark' ? '100' : 'dark';\r\n const name = utils.getData(navbar, DataKey.NAVBAR_DARKEN_ON_SCROLL);\r\n\r\n toggleThemeClass(theme);\r\n const themeController = document.body;\r\n themeController.addEventListener(\r\n 'clickControl',\r\n ({ detail: { control, value } }) => {\r\n if (control === 'theme') {\r\n toggleThemeClass(value);\r\n defaultColorName = value === 'dark' ? '100' : 'dark';\r\n if (\r\n navbar.classList.contains('bg-dark') ||\r\n navbar.classList.contains('bg-100')\r\n ) {\r\n removeNavbarBgClass();\r\n navbar.classList.add(\r\n getBgClassName(name, defaultColorName).bgClassName\r\n );\r\n }\r\n }\r\n }\r\n );\r\n\r\n const windowHeight = window.innerHeight;\r\n const html = document.documentElement;\r\n const navbarCollapse = navbar.querySelector(Selector.NAVBAR_COLLAPSE);\r\n const colorRgb = utils.hexToRgb(\r\n getBgClassName(name, defaultColorName).color\r\n );\r\n const { backgroundImage } = window.getComputedStyle(navbar);\r\n const transition = 'background-color 0.35s ease';\r\n\r\n navbar.style.backgroundImage = 'none';\r\n // Change navbar background color on scroll\r\n window.addEventListener(Events.SCROLL, () => {\r\n const { scrollTop } = html;\r\n let alpha = (scrollTop / windowHeight) * 2;\r\n alpha >= 1 && (alpha = 1);\r\n navbar.style.backgroundColor = `rgba(${colorRgb[0]}, ${colorRgb[1]}, ${colorRgb[2]}, ${alpha})`;\r\n navbar.style.backgroundImage =\r\n alpha > 0 || utils.hasClass(navbarCollapse, 'show')\r\n ? backgroundImage\r\n : 'none';\r\n });\r\n\r\n // Toggle bg class on window resize\r\n utils.resize(() => {\r\n const breakPoint = utils.getBreakpoint(navbar);\r\n if (window.innerWidth > breakPoint) {\r\n removeNavbarBgClass();\r\n navbar.style.backgroundImage = html.scrollTop\r\n ? backgroundImage\r\n : 'none';\r\n navbar.style.transition = 'none';\r\n } else if (\r\n utils.hasClass(\r\n navbar.querySelector(Selector.NAVBAR_TOGGLER),\r\n ClassNames.COLLAPSED\r\n )\r\n ) {\r\n removeNavbarBgClass();\r\n navbar.style.backgroundImage = backgroundImage;\r\n }\r\n\r\n if (window.innerWidth <= breakPoint) {\r\n navbar.style.transition = utils.hasClass(navbarCollapse, 'show')\r\n ? transition\r\n : 'none';\r\n }\r\n });\r\n\r\n navbarCollapse.addEventListener(Events.SHOW_BS_COLLAPSE, () => {\r\n navbar.classList.add(getBgClassName(name, defaultColorName).bgClassName);\r\n navbar.style.backgroundImage = backgroundImage;\r\n navbar.style.transition = transition;\r\n });\r\n\r\n navbarCollapse.addEventListener(Events.HIDE_BS_COLLAPSE, () => {\r\n removeNavbarBgClass();\r\n !html.scrollTop && (navbar.style.backgroundImage = 'none');\r\n });\r\n\r\n navbarCollapse.addEventListener(Events.HIDDEN_BS_COLLAPSE, () => {\r\n navbar.style.transition = 'none';\r\n });\r\n }\r\n};\r\n\r\nexport default navbarDarkenOnScroll;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Navbar Top */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst navbarTopDropShadow = () => {\r\n const Selector = {\r\n NAVBAR: '.navbar:not(.navbar-vertical)',\r\n NAVBAR_VERTICAL: '.navbar-vertical',\r\n NAVBAR_VERTICAL_CONTENT: '.navbar-vertical-content',\r\n NAVBAR_VERTICAL_COLLAPSE: 'navbarVerticalCollapse',\r\n };\r\n\r\n const ClassNames = {\r\n NAVBAR_GLASS_SHADOW: 'navbar-glass-shadow',\r\n SHOW: 'show',\r\n };\r\n\r\n const Events = {\r\n SCROLL: 'scroll',\r\n SHOW_BS_COLLAPSE: 'show.bs.collapse',\r\n HIDDEN_BS_COLLAPSE: 'hidden.bs.collapse',\r\n };\r\n let navDropShadowFlag = true;\r\n\r\n const $navbar = document.querySelector(Selector.NAVBAR);\r\n const $navbarVertical = document.querySelector(Selector.NAVBAR_VERTICAL);\r\n const $navbarVerticalContent = document.querySelector(\r\n Selector.NAVBAR_VERTICAL_CONTENT\r\n );\r\n const $navbarVerticalCollapse = document.getElementById(\r\n Selector.NAVBAR_VERTICAL_COLLAPSE\r\n );\r\n const html = document.documentElement;\r\n const breakPoint = utils.getBreakpoint($navbarVertical);\r\n const setDropShadow = ($elem) => {\r\n if ($elem.scrollTop > 0 && navDropShadowFlag) {\r\n $navbar && $navbar.classList.add(ClassNames.NAVBAR_GLASS_SHADOW);\r\n } else {\r\n $navbar && $navbar.classList.remove(ClassNames.NAVBAR_GLASS_SHADOW);\r\n }\r\n };\r\n\r\n window.addEventListener(Events.SCROLL, () => {\r\n setDropShadow(html);\r\n });\r\n\r\n if ($navbarVerticalContent) {\r\n $navbarVerticalContent.addEventListener(Events.SCROLL, () => {\r\n if (window.outerWidth < breakPoint) {\r\n navDropShadowFlag = true;\r\n setDropShadow($navbarVerticalContent);\r\n }\r\n });\r\n }\r\n if ($navbarVerticalCollapse) {\r\n $navbarVerticalCollapse.addEventListener(Events.SHOW_BS_COLLAPSE, () => {\r\n if (window.outerWidth < breakPoint) {\r\n navDropShadowFlag = false;\r\n setDropShadow(html);\r\n }\r\n });\r\n }\r\n if ($navbarVerticalCollapse) {\r\n $navbarVerticalCollapse.addEventListener(Events.HIDDEN_BS_COLLAPSE, () => {\r\n if (\r\n utils.hasClass($navbarVerticalCollapse, ClassNames.SHOW) &&\r\n window.outerWidth < breakPoint\r\n ) {\r\n navDropShadowFlag = false;\r\n } else {\r\n navDropShadowFlag = true;\r\n }\r\n setDropShadow(html);\r\n });\r\n }\r\n};\r\n\r\nexport default navbarTopDropShadow;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Navbar Vertical */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst handleNavbarVerticalCollapsed = () => {\r\n const Selector = {\r\n HTML: 'html',\r\n NAVBAR_VERTICAL_TOGGLE: '.navbar-vertical-toggle',\r\n NAVBAR_VERTICAL_COLLAPSE: '.navbar-vertical .navbar-collapse',\r\n ECHART_RESPONSIVE: '[data-echart-responsive]',\r\n };\r\n\r\n const Events = {\r\n CLICK: 'click',\r\n MOUSE_OVER: 'mouseover',\r\n MOUSE_LEAVE: 'mouseleave',\r\n NAVBAR_VERTICAL_TOGGLE: 'navbar.vertical.toggle',\r\n };\r\n const ClassNames = {\r\n NAVBAR_VERTICAL_COLLAPSED: 'navbar-vertical-collapsed',\r\n NAVBAR_VERTICAL_COLLAPSED_HOVER: 'navbar-vertical-collapsed-hover',\r\n };\r\n const navbarVerticalToggle = document.querySelector(\r\n Selector.NAVBAR_VERTICAL_TOGGLE\r\n );\r\n const html = document.querySelector(Selector.HTML);\r\n const navbarVerticalCollapse = document.querySelector(\r\n Selector.NAVBAR_VERTICAL_COLLAPSE\r\n );\r\n\r\n if (navbarVerticalToggle) {\r\n navbarVerticalToggle.addEventListener(Events.CLICK, (e) => {\r\n navbarVerticalToggle.blur();\r\n html.classList.toggle(ClassNames.NAVBAR_VERTICAL_COLLAPSED);\r\n\r\n // Set collapse state on localStorage\r\n const isNavbarVerticalCollapsed = utils.getItemFromStore(\r\n 'isNavbarVerticalCollapsed'\r\n );\r\n utils.setItemToStore(\r\n 'isNavbarVerticalCollapsed',\r\n !isNavbarVerticalCollapsed\r\n );\r\n\r\n const event = new CustomEvent(Events.NAVBAR_VERTICAL_TOGGLE);\r\n e.currentTarget.dispatchEvent(event);\r\n });\r\n }\r\n if (navbarVerticalCollapse) {\r\n navbarVerticalCollapse.addEventListener(Events.MOUSE_OVER, () => {\r\n if (utils.hasClass(html, ClassNames.NAVBAR_VERTICAL_COLLAPSED)) {\r\n html.classList.add(ClassNames.NAVBAR_VERTICAL_COLLAPSED_HOVER);\r\n }\r\n });\r\n navbarVerticalCollapse.addEventListener(Events.MOUSE_LEAVE, () => {\r\n if (utils.hasClass(html, ClassNames.NAVBAR_VERTICAL_COLLAPSED_HOVER)) {\r\n html.classList.remove(ClassNames.NAVBAR_VERTICAL_COLLAPSED_HOVER);\r\n }\r\n });\r\n }\r\n};\r\n\r\nexport default handleNavbarVerticalCollapsed;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* noUiSlider */\r\n/* -------------------------------------------------------------------------- */\r\nconst nouisliderInit = () => {\r\n if (window.noUiSlider) {\r\n const elements = document.querySelectorAll('[data-nouislider]');\r\n elements.forEach(item => {\r\n const sliderValue = document.querySelector('[data-nouislider-value]');\r\n const userOptions = utils.getData(item, 'nouislider');\r\n const defaultOptions = {\r\n start: [10],\r\n connect: [true, false],\r\n step: 1,\r\n range: { min: [0], max: [100] },\r\n tooltips: true\r\n };\r\n const options = window._.merge(defaultOptions, userOptions);\r\n window.noUiSlider.create(item, { ...options });\r\n\r\n sliderValue &&\r\n item.noUiSlider.on('update', (values, handle) => {\r\n sliderValue.innerHTML = values[handle];\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default nouisliderInit;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Popover */\r\n/* -------------------------------------------------------------------------- */\r\nconst picmoInit = () => {\r\n const picmoBtns = document.querySelectorAll('[data-picmo]');\r\n if (picmoBtns) {\r\n Array.from(picmoBtns).forEach(btn => {\r\n const inputTarget = utils.getData(btn, 'picmo-input-target');\r\n const userOptions = utils.getData(btn, 'picmo');\r\n const defaultOptions = {\r\n referenceElement: btn,\r\n triggerElement: btn,\r\n position: 'bottom-center',\r\n showCloseButton: false\r\n };\r\n const options = window._.merge(defaultOptions, userOptions);\r\n const picker = window.picmoPopup.createPopup(\r\n { showPreview: false },\r\n { ...options }\r\n );\r\n btn.addEventListener('click', () => {\r\n picker.toggle();\r\n });\r\n const input = document.querySelector(inputTarget);\r\n picker.addEventListener('emoji:select', selection => {\r\n if (input) {\r\n input.innerHTML += selection.emoji;\r\n }\r\n });\r\n });\r\n }\r\n};\r\nexport default picmoInit;\r\n","import utils from './utils';\r\n/*-----------------------------------------------\r\n| Inline Player [plyr]\r\n-----------------------------------------------*/\r\n\r\nconst plyrInit = () => {\r\n if (window.Plyr) {\r\n const plyrs = document.querySelectorAll('.player');\r\n plyrs.forEach((plyr) => {\r\n const userOptions = utils.getData(plyr, 'options');\r\n const defaultOptions = { captions: { active: true } };\r\n const options = window._.merge(defaultOptions, userOptions);\r\n return new window.Plyr(plyr, options);\r\n });\r\n }\r\n};\r\n\r\nexport default plyrInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Popover */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst popoverInit = () => {\r\n const popoverTriggerList = [].slice.call(\r\n document.querySelectorAll('[data-bs-toggle=\"popover\"]')\r\n );\r\n popoverTriggerList.map(popoverTriggerEl => {\r\n return new window.bootstrap.Popover(popoverTriggerEl);\r\n });\r\n};\r\n\r\nexport default popoverInit;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Bootstrap Animated Progress */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst progressAnimationToggle = () => {\r\n const animatedProgress = document.querySelectorAll(\r\n '[data-progress-animation]'\r\n );\r\n\r\n animatedProgress.forEach((progress) => {\r\n progress.addEventListener('click', (e) => {\r\n const progressID = utils.getData(e.currentTarget, 'progressAnimation');\r\n const $progress = document.getElementById(progressID);\r\n $progress.classList.toggle('progress-bar-animated');\r\n });\r\n });\r\n};\r\n\r\nexport default progressAnimationToggle;\r\n","import utils from './utils';\r\n\r\n/*-----------------------------------------------\r\n| Quantity\r\n-----------------------------------------------*/\r\nconst quantityInit = () => {\r\n const Selector = {\r\n DATA_QUANTITY_BTN: '[data-quantity] [data-type]',\r\n DATA_QUANTITY: '[data-quantity]',\r\n DATA_QUANTITY_INPUT: '[data-quantity] input[type=\"number\"]',\r\n };\r\n\r\n const Events = {\r\n CLICK: 'click',\r\n };\r\n\r\n const Attributes = {\r\n MIN: 'min',\r\n };\r\n\r\n const DataKey = {\r\n TYPE: 'type',\r\n };\r\n\r\n const quantities = document.querySelectorAll(Selector.DATA_QUANTITY_BTN);\r\n\r\n quantities.forEach((quantity) => {\r\n quantity.addEventListener(Events.CLICK, (e) => {\r\n const el = e.currentTarget;\r\n const type = utils.getData(el, DataKey.TYPE);\r\n const numberInput = el\r\n .closest(Selector.DATA_QUANTITY)\r\n .querySelector(Selector.DATA_QUANTITY_INPUT);\r\n\r\n const min = numberInput.getAttribute(Attributes.MIN);\r\n let value = parseInt(numberInput.value, 10);\r\n\r\n if (type === 'plus') {\r\n value += 1;\r\n } else {\r\n value = value > min ? (value -= 1) : value;\r\n }\r\n numberInput.value = value;\r\n });\r\n });\r\n};\r\n\r\nexport default quantityInit;\r\n","import utils from \"./utils\";\r\n/* -------------------------------------------------------------------------- */\r\n\r\n/* Ratings */\r\n\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst ratingInit = () => {\r\n const raters = document.querySelectorAll(\"[data-rater]\");\r\n\r\n raters.forEach((rater) => {\r\n let options = {\r\n reverse:utils.getItemFromStore('isRTL'),\r\n starSize: 32,\r\n step: 0.5,\r\n element: rater,\r\n rateCallback(rating, done) {\r\n this.setRating(rating);\r\n done();\r\n },\r\n ...utils.getData(rater, \"rater\"),\r\n };\r\n\r\n return window.raterJs(options);\r\n });\r\n\r\n\r\n\r\n};\r\nexport default ratingInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Scrollbars */\r\n/* -------------------------------------------------------------------------- */\r\n// import utils from './utils';\r\n\r\nconst scrollInit = () => {\r\n\tconst dropdownElements = Array.from(document.querySelectorAll('[data-hide-on-body-scroll]'));\r\n\r\n\tif (window.innerWidth < 1200) {\r\n\t\twindow.addEventListener('scroll', () => {\r\n\t\t\tdropdownElements.forEach(dropdownElement => {\r\n\t\t\t\tconst instanceEl = window.bootstrap.Dropdown.getInstance(dropdownElement);\r\n\t\t\t\tinstanceEl && instanceEl.hide();\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n};\r\nexport default scrollInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Scrollbars */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst scrollbarInit = () => {\r\n Array.prototype.forEach.call(\r\n document.querySelectorAll('.scrollbar-overlay'),\r\n (el) => new window.SimpleBar(el, { autoHide: true })\r\n );\r\n};\r\n\r\nexport default scrollbarInit;\r\n","const searchInit = () => {\r\n const Selectors = {\r\n SEARCH_DISMISS: '[data-bs-dismiss=\"search\"]',\r\n DROPDOWN_TOGGLE: '[data-bs-toggle=\"dropdown\"]',\r\n DROPDOWN_MENU: '.dropdown-menu',\r\n SEARCH_BOX: '.search-box',\r\n SEARCH_INPUT: '.search-input',\r\n SEARCH_TOGGLE: '[data-bs-toggle=\"search\"]',\r\n };\r\n\r\n const ClassName = {\r\n SHOW: 'show',\r\n };\r\n\r\n const Attribute = {\r\n ARIA_EXPANDED: 'aria-expanded',\r\n };\r\n\r\n const Events = {\r\n CLICK: 'click',\r\n FOCUS: 'focus',\r\n SHOW_BS_DROPDOWN: 'show.bs.dropdown',\r\n SEARCH_CLOSE: 'search.close',\r\n };\r\n\r\n const hideSearchSuggestion = (searchArea) => {\r\n const el = searchArea.querySelector(Selectors.SEARCH_TOGGLE);\r\n const dropdownMenu = searchArea.querySelector(Selectors.DROPDOWN_MENU);\r\n if (!el || !dropdownMenu) return;\r\n\r\n el.setAttribute(Attribute.ARIA_EXPANDED, 'false');\r\n el.classList.remove(ClassName.SHOW);\r\n dropdownMenu.classList.remove(ClassName.SHOW);\r\n };\r\n\r\n const searchAreas = document.querySelectorAll(Selectors.SEARCH_BOX);\r\n\r\n const hideAllSearchAreas = () => {\r\n searchAreas.forEach(hideSearchSuggestion);\r\n };\r\n\r\n searchAreas.forEach((searchArea) => {\r\n const input = searchArea.querySelector(Selectors.SEARCH_INPUT);\r\n const btnDropdownClose = searchArea.querySelector(Selectors.SEARCH_DISMISS);\r\n const dropdownMenu = searchArea.querySelector(Selectors.DROPDOWN_MENU);\r\n\r\n if (input) {\r\n input.addEventListener(Events.FOCUS, () => {\r\n hideAllSearchAreas();\r\n const el = searchArea.querySelector(Selectors.SEARCH_TOGGLE);\r\n if (!el || !dropdownMenu) return;\r\n el.setAttribute(Attribute.ARIA_EXPANDED, 'true');\r\n el.classList.add(ClassName.SHOW);\r\n dropdownMenu.classList.add(ClassName.SHOW);\r\n });\r\n }\r\n\r\n document.addEventListener(Events.CLICK, ({ target }) => {\r\n !searchArea.contains(target) && hideSearchSuggestion(searchArea);\r\n });\r\n\r\n btnDropdownClose &&\r\n btnDropdownClose.addEventListener(Events.CLICK, (e) => {\r\n hideSearchSuggestion(searchArea);\r\n input.value = '';\r\n const event = new CustomEvent(Events.SEARCH_CLOSE);\r\n e.currentTarget.dispatchEvent(event);\r\n });\r\n });\r\n\r\n document.querySelectorAll(Selectors.DROPDOWN_TOGGLE).forEach((dropdown) => {\r\n dropdown.addEventListener(Events.SHOW_BS_DROPDOWN, () => {\r\n hideAllSearchAreas();\r\n });\r\n });\r\n};\r\n\r\nexport default searchInit;\r\n","/*-----------------------------------------------\r\n| Select2\r\n-----------------------------------------------*/\r\n\r\nconst select2Init = () => {\r\n if (window.jQuery) {\r\n const $ = window.jQuery;\r\n\r\n const select2 = $('.selectpicker');\r\n select2.length\r\n && select2.each((index, value) => {\r\n const $this = $(value);\r\n const options = $.extend({ theme: 'bootstrap-5' }, $this.data('options'));\r\n $this.select2(options);\r\n });\r\n }\r\n};\r\n\r\nexport default select2Init;\r\n","import utils from './utils';\r\n\r\n/*-----------------------------------------------\r\n| Swiper\r\n-----------------------------------------------*/\r\nconst swiperInit = () => {\r\n const swipers = document.querySelectorAll('[data-swiper]');\r\n const navbarVerticalToggle = document.querySelector(\r\n '.navbar-vertical-toggle'\r\n );\r\n swipers.forEach((swiper) => {\r\n const options = utils.getData(swiper, 'swiper');\r\n const thumbsOptions = options.thumb;\r\n let thumbsInit;\r\n if (thumbsOptions) {\r\n const thumbImages = swiper.querySelectorAll('img');\r\n let slides = '';\r\n thumbImages.forEach((img) => {\r\n slides += `\r\n
    \r\n \r\n
    \r\n `;\r\n });\r\n\r\n const thumbs = document.createElement('div');\r\n thumbs.setAttribute('class', 'swiper-container thumb');\r\n thumbs.innerHTML = `
    ${slides}
    `;\r\n\r\n if (thumbsOptions.parent) {\r\n const parent = document.querySelector(thumbsOptions.parent);\r\n parent.parentNode.appendChild(thumbs);\r\n } else {\r\n swiper.parentNode.appendChild(thumbs);\r\n }\r\n\r\n thumbsInit = new window.Swiper(thumbs, thumbsOptions);\r\n }\r\n\r\n const swiperNav = swiper.querySelector('.swiper-nav');\r\n const newSwiper = new window.Swiper(swiper, {\r\n ...options,\r\n navigation: {\r\n nextEl: swiperNav?.querySelector('.swiper-button-next'),\r\n prevEl: swiperNav?.querySelector('.swiper-button-prev'),\r\n },\r\n thumbs: {\r\n swiper: thumbsInit,\r\n },\r\n });\r\n if( navbarVerticalToggle){\r\n navbarVerticalToggle.addEventListener('navbar.vertical.toggle', () => {\r\n newSwiper.update();\r\n });\r\n }\r\n \r\n });\r\n};\r\n\r\nexport default swiperInit;\r\n","// export default themeControl;\r\nimport { setItemToStore, getData, getItemFromStore } from \"./utils\";\r\nimport DomNode from \"./node\";\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Theme Control */\r\n/* -------------------------------------------------------------------------- */\r\n/* eslint-disable no-param-reassign */\r\n/* eslint-disable */\r\nimport CONFIG from \"./config\";\r\nconst initialDomSetup = (element) => {\r\n if (!element) return;\r\n const dataUrlDom = element.querySelector(\r\n '[data-theme-control = \"navbarPosition\"]'\r\n );\r\n const hasDataUrl = dataUrlDom ? getData(dataUrlDom, \"page-url\") : null;\r\n\r\n element.querySelectorAll(\"[data-theme-control]\").forEach((el) => {\r\n const inputDataAttributeValue = getData(el, \"theme-control\");\r\n const localStorageValue = getItemFromStore(inputDataAttributeValue);\r\n if (\r\n inputDataAttributeValue === \"navbarStyle\" &&\r\n !hasDataUrl &&\r\n (getItemFromStore(\"navbarPosition\") === \"top\" ||\r\n getItemFromStore(\"navbarPosition\") === \"double-top\")\r\n ) {\r\n el.setAttribute(\"disabled\", true);\r\n }\r\n if (\r\n el.type === \"select-one\" &&\r\n inputDataAttributeValue === \"navbarPosition\"\r\n ) {\r\n el.value = localStorageValue;\r\n }\r\n if (el.type === \"checkbox\") {\r\n if (inputDataAttributeValue === \"theme\") {\r\n localStorageValue === \"dark\" && el.setAttribute(\"checked\", true);\r\n } else {\r\n localStorageValue && el.setAttribute(\"checked\", true);\r\n }\r\n } else {\r\n const isChecked = localStorageValue === el.value;\r\n isChecked && el.setAttribute(\"checked\", true);\r\n }\r\n });\r\n};\r\n\r\nconst changeTheme = (element) => {\r\n element.querySelectorAll('[data-theme-control = \"theme\"]').forEach((el) => {\r\n const inputDataAttributeValue = getData(el, \"theme-control\");\r\n const localStorageValue = getItemFromStore(inputDataAttributeValue);\r\n\r\n if (el.type === \"checkbox\") {\r\n localStorageValue === \"dark\" ? (el.checked = true) : (el.checked = false);\r\n } else {\r\n localStorageValue === el.value\r\n ? (el.checked = true)\r\n : (el.checked = false);\r\n }\r\n });\r\n};\r\n\r\nconst themeControl = () => {\r\n const themeController = new DomNode(document.body);\r\n\r\n const navbarVertical = document.querySelector(\".navbar-vertical\");\r\n initialDomSetup(themeController.node);\r\n\r\n themeController.on(\"click\", (e) => {\r\n const target = new DomNode(e.target);\r\n\r\n if (target.data(\"theme-control\")) {\r\n const control = target.data(\"theme-control\");\r\n let value = e.target[e.target.type === \"radio\" ? \"value\" : \"checked\"];\r\n if (control === \"theme\") {\r\n typeof value === \"boolean\" && (value = value ? \"dark\" : \"light\");\r\n }\r\n if (control !== \"navbarPosition\") {\r\n CONFIG.hasOwnProperty(control) && setItemToStore(control, value);\r\n switch (control) {\r\n case \"theme\": {\r\n document.documentElement.setAttribute(\"data-bs-theme\", value);\r\n const clickControl = new CustomEvent(\"clickControl\", {\r\n detail: { control, value },\r\n });\r\n e.currentTarget.dispatchEvent(clickControl);\r\n changeTheme(themeController.node);\r\n break;\r\n }\r\n case \"navbarStyle\": {\r\n navbarVertical.classList.remove(\"navbar-card\");\r\n navbarVertical.classList.remove(\"navbar-inverted\");\r\n navbarVertical.classList.remove(\"navbar-vibrant\");\r\n if (value !== \"transparent\") {\r\n navbarVertical.classList.add(`navbar-${value}`);\r\n }\r\n break;\r\n }\r\n case \"reset\": {\r\n Object.keys(CONFIG).forEach((key) => {\r\n localStorage.setItem(key, CONFIG[key]);\r\n });\r\n window.location.reload();\r\n break;\r\n }\r\n default:\r\n window.location.reload();\r\n }\r\n }\r\n }\r\n });\r\n\r\n // control navbar position\r\n themeController.on(\"change\", (e) => {\r\n const target = new DomNode(e.target);\r\n\r\n if (target.data(\"theme-control\") === \"navbarPosition\") {\r\n CONFIG.hasOwnProperty(\"navbarPosition\") &&\r\n setItemToStore(\"navbarPosition\", e.target.value);\r\n\r\n const pageUrl = getData(target.node.selectedOptions[0], \"page-url\");\r\n !!pageUrl\r\n ? window.location.replace(pageUrl)\r\n : window.location.replace(window.location.href.split(\"#\")[0]);\r\n }\r\n });\r\n};\r\n\r\nexport default themeControl;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Tinymce */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst tinymceInit = () => {\r\n if (window.tinymce) {\r\n const tinymces = document.querySelectorAll('[data-tinymce]');\r\n if (tinymces.length) {\r\n window.tinymce.execCommand('mceFocus', false, 'course-description');\r\n window.tinymce.init({\r\n selector: '.tinymce',\r\n height: '50vh',\r\n menubar: false,\r\n skin: utils.settings.tinymce.theme,\r\n content_style: `.mce-content-body { color: ${utils.getGrays().black} }`,\r\n mobile: {\r\n theme: 'mobile',\r\n toolbar: ['undo', 'bold']\r\n },\r\n statusbar: false,\r\n plugins: 'link,image,lists,table,media',\r\n toolbar:\r\n 'styleselect | bold italic link bullist numlist image blockquote table media undo redo',\r\n directionality: utils.getItemFromStore('isRTL') ? 'rtl' : 'ltr',\r\n theme_advanced_toolbar_align: 'center',\r\n setup: editor => {\r\n editor.on('change', () => {\r\n window.tinymce.triggerSave();\r\n });\r\n }\r\n });\r\n }\r\n\r\n const themeController = document.body;\r\n themeController &&\r\n themeController.addEventListener(\r\n 'clickControl',\r\n ({ detail: { control } }) => {\r\n if (control === 'theme') {\r\n window.tinyMCE.editors.forEach(el => {\r\n el.dom.addStyle(\r\n `.mce-content-body{color: ${\r\n utils.getGrays().black\r\n } !important;}`\r\n );\r\n });\r\n }\r\n }\r\n );\r\n }\r\n};\r\n\r\nexport default tinymceInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Toast */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst toastInit = () => {\r\n const toastElList = [].slice.call(document.querySelectorAll('.toast'));\r\n toastElList.map((toastEl) => new window.bootstrap.Toast(toastEl));\r\n\r\n\r\n const liveToastBtn = document.getElementById('liveToastBtn');\r\n\r\n if (liveToastBtn) {\r\n const liveToast = new window.bootstrap.Toast(document.getElementById('liveToast'));\r\n\r\n liveToastBtn.addEventListener('click', () => {\r\n liveToast && liveToast.show();\r\n })\r\n }\r\n};\r\n\r\n\r\nexport default toastInit;\r\n","/* -------------------------------------------------------------------------- */\r\n/* Tooltip */\r\n/* -------------------------------------------------------------------------- */\r\nconst tooltipInit = () => {\r\n const tooltipTriggerList = [].slice.call(\r\n document.querySelectorAll('[data-bs-toggle=\"tooltip\"]')\r\n );\r\n\r\n tooltipTriggerList.map(\r\n (tooltipTriggerEl) => new window.bootstrap.Tooltip(tooltipTriggerEl,{\r\n trigger:'hover'\r\n })\r\n );\r\n};\r\n\r\nexport default tooltipInit;\r\n","/* eslint-disable no-param-reassign */\r\nimport utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Treeview */\r\n/* -------------------------------------------------------------------------- */\r\nconst treeviewInit = () => {\r\n const Events = {\r\n CHANGE: 'change',\r\n SHOW_BS_COLLAPSE: 'show.bs.collapse',\r\n HIDE_BS_COLLAPSE: 'hide.bs.collapse',\r\n };\r\n\r\n const Selector = {\r\n TREEVIEW_ROW:\r\n '.treeview > li > .treeview-row,.treeview-list.collapse-show > li > .treeview-row',\r\n TREEVIEW: '.treeview',\r\n TREEVIEW_LIST: '.treeview-list',\r\n TOGGLE_ELEMENT: \"[data-bs-toggle='collapse']\",\r\n INPUT: 'input',\r\n TREEVIEW_LIST_ITEM: '.treeview-list-item',\r\n CHILD_SELECTOR: ':scope > li > .collapse.collapse-show',\r\n };\r\n\r\n const ClassName = {\r\n TREEVIEW: 'treeview',\r\n TREEVIEW_LIST: 'treeview-list',\r\n TREEVIEW_BORDER: 'treeview-border',\r\n TREEVIEW_BORDER_TRANSPARENT: 'treeview-border-transparent',\r\n COLLAPSE_SHOW: 'collapse-show',\r\n COLLAPSE_HIDDEN: 'collapse-hidden',\r\n TREEVIEW_ROW: 'treeview-row',\r\n TREEVIEW_ROW_ODD: 'treeview-row-odd',\r\n TREEVIEW_ROW_EVEN: 'treeview-row-even',\r\n };\r\n\r\n const treeviews = document.querySelectorAll(Selector.TREEVIEW);\r\n\r\n const makeStriped = (treeview) => {\r\n const tags = Array.from(treeview.querySelectorAll(Selector.TREEVIEW_ROW));\r\n\r\n const uTags = tags.filter((tag) => {\r\n let result = true;\r\n while (tag.parentElement) {\r\n if (tag.parentElement.classList.contains(ClassName.COLLAPSE_HIDDEN)) {\r\n result = false;\r\n break;\r\n }\r\n tag = tag.parentElement;\r\n }\r\n return result;\r\n });\r\n uTags.forEach((tag, index) => {\r\n if (index % 2 === 0) {\r\n tag.classList.add(ClassName.TREEVIEW_ROW_EVEN);\r\n tag.classList.remove(ClassName.TREEVIEW_ROW_ODD);\r\n } else {\r\n tag.classList.add(ClassName.TREEVIEW_ROW_ODD);\r\n tag.classList.remove(ClassName.TREEVIEW_ROW_EVEN);\r\n }\r\n });\r\n };\r\n\r\n if (treeviews.length) {\r\n treeviews.forEach((treeview) => {\r\n const options = utils.getData(treeview, 'options');\r\n const striped = options?.striped;\r\n const select = options?.select;\r\n\r\n if (striped) {\r\n makeStriped(treeview);\r\n }\r\n\r\n const collapseElementList = Array.from(\r\n treeview.querySelectorAll(Selector.TREEVIEW_LIST)\r\n );\r\n const collapseListItem = Array.from(\r\n treeview.querySelectorAll(Selector.TREEVIEW_LIST_ITEM)\r\n );\r\n\r\n collapseListItem.forEach((item) => {\r\n const wholeRow = document.createElement('div');\r\n wholeRow.setAttribute('class', ClassName.TREEVIEW_ROW);\r\n item.prepend(wholeRow);\r\n });\r\n collapseElementList.forEach((collapse) => {\r\n const collapseId = collapse.id;\r\n if (!striped) {\r\n collapse.classList.add(ClassName.TREEVIEW_BORDER);\r\n }\r\n collapse.addEventListener(Events.SHOW_BS_COLLAPSE, (e) => {\r\n e.target.classList.remove(ClassName.COLLAPSE_HIDDEN);\r\n e.target.classList.add(ClassName.COLLAPSE_SHOW);\r\n if (striped) {\r\n makeStriped(treeview);\r\n } else {\r\n e.path[2].classList.add(ClassName.TREEVIEW_BORDER_TRANSPARENT);\r\n }\r\n });\r\n\r\n collapse.addEventListener(Events.HIDE_BS_COLLAPSE, (e) => {\r\n e.target.classList.add(ClassName.COLLAPSE_HIDDEN);\r\n e.target.classList.remove(ClassName.COLLAPSE_SHOW);\r\n\r\n if (striped) {\r\n makeStriped(treeview);\r\n } else {\r\n const childs = e.path[2].querySelectorAll(Selector.CHILD_SELECTOR);\r\n if (\r\n !e.path[2].classList.contains(ClassName.TREEVIEW) &&\r\n childs.length === 0\r\n ) {\r\n e.path[2].classList.remove(ClassName.TREEVIEW_BORDER_TRANSPARENT);\r\n }\r\n }\r\n });\r\n\r\n if (collapse.dataset.show === 'true') {\r\n const parents = [collapse];\r\n while (collapse.parentElement) {\r\n if (\r\n collapse.parentElement.classList.contains(ClassName.TREEVIEW_LIST)\r\n ) {\r\n parents.unshift(collapse.parentElement);\r\n }\r\n collapse = collapse.parentElement;\r\n }\r\n parents.forEach((collapseEl) => {\r\n // eslint-disable-next-line no-new\r\n new window.bootstrap.Collapse(collapseEl, {\r\n show: true,\r\n });\r\n });\r\n }\r\n\r\n if (select) {\r\n const inputElement = treeview.querySelector(\r\n `input[data-target='#${collapseId}']`\r\n );\r\n inputElement.addEventListener(Events.CHANGE, (e) => {\r\n const childInputElements = Array.from(\r\n treeview\r\n .querySelector(`#${collapseId}`)\r\n .querySelectorAll(Selector.INPUT)\r\n );\r\n childInputElements.forEach((input) => {\r\n input.checked = e.target.checked;\r\n });\r\n });\r\n }\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default treeviewInit;\r\n","import utils from './utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Typed Text */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst typedTextInit = () => {\r\n const typedTexts = document.querySelectorAll('.typed-text');\r\n if (typedTexts.length && window.Typed) {\r\n typedTexts.forEach((typedText) => {\r\n return new window.Typed(typedText, {\r\n strings: utils.getData(typedText, 'typedText'),\r\n typeSpeed: 100,\r\n loop: true,\r\n backDelay: 1500,\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default typedTextInit;\r\n","const unresolvedTicketsTabInit = () => {\r\n const dropdownToggle = document.querySelectorAll('.dropdown-toggle-item a')\r\n const layout = document.querySelector('.table-layout')\r\n dropdownToggle.forEach(item => {\r\n item.addEventListener('shown.bs.tab', (e) => {\r\n layout.innerText = e.target.innerText\r\n })\r\n })\r\n}\r\n\r\nexport default unresolvedTicketsTabInit;","/* -------------------------------------------------------------------------- */\r\n/* step wizard */\r\n/* -------------------------------------------------------------------------- */\r\nconst wizardInit = () => {\r\n const wizards = document.querySelectorAll('.theme-wizard');\r\n\r\n const tabPillEl = document.querySelectorAll(\r\n '#pill-tab2 [data-bs-toggle=\"pill\"]'\r\n );\r\n const tabProgressBar = document.querySelector('.theme-wizard .progress');\r\n\r\n wizards.forEach(wizard => {\r\n let tabToggleButtonEl = wizard.querySelectorAll('[data-wizard-step]');\r\n let inputEmail = wizard.querySelector('[data-wizard-validate-email]');\r\n let emailPattern = inputEmail.getAttribute('pattern');\r\n let inputPassword = wizard.querySelector('[data-wizard-validate-password]');\r\n let inputConfirmPassword = wizard.querySelector(\r\n '[data-wizard-validate-confirm-password]'\r\n );\r\n let form = wizard.querySelector('[novalidate]');\r\n let nextButton = wizard.querySelector('.next button');\r\n let prevButton = wizard.querySelector('.previous button');\r\n let cardFooter = wizard.querySelector('.theme-wizard .card-footer');\r\n let count = 0;\r\n\r\n const validatePattern = (pattern, value) => {\r\n const regexPattern = new RegExp(pattern);\r\n return regexPattern.test(String(value).toLowerCase());\r\n };\r\n\r\n prevButton.classList.add('d-none');\r\n\r\n // on button click tab change\r\n nextButton.addEventListener('click', () => {\r\n if (\r\n (!(\r\n inputEmail.value && validatePattern(emailPattern, inputEmail.value)\r\n ) ||\r\n !inputPassword.value ||\r\n !inputConfirmPassword.value) &&\r\n form.className.includes('needs-validation')\r\n ) {\r\n form.classList.add('was-validated');\r\n } else {\r\n count = count + 1;\r\n const tab = new window.bootstrap.Tab(tabToggleButtonEl[count]);\r\n tab.show();\r\n }\r\n });\r\n\r\n prevButton.addEventListener('click', () => {\r\n count = count - 1;\r\n const tab = new window.bootstrap.Tab(tabToggleButtonEl[count]);\r\n tab.show();\r\n });\r\n if (tabToggleButtonEl.length) {\r\n tabToggleButtonEl.forEach((item, index) => {\r\n /* eslint-disable */\r\n\r\n item.addEventListener('shown.bs.tab', e => {\r\n if (\r\n (!(\r\n inputEmail.value &&\r\n validatePattern(emailPattern, inputEmail.value)\r\n ) ||\r\n !inputPassword.value ||\r\n !inputConfirmPassword.value) &&\r\n form.className.includes('needs-validation')\r\n ) {\r\n e.preventDefault();\r\n form.classList.add('was-validated');\r\n return null;\r\n /* eslint-enable */\r\n }\r\n count = index;\r\n // can't go back tab\r\n if (count === tabToggleButtonEl.length - 1) {\r\n tabToggleButtonEl.forEach(tab => {\r\n tab.setAttribute('data-bs-toggle', 'modal');\r\n tab.setAttribute('data-bs-target', '#error-modal');\r\n });\r\n }\r\n //add done class\r\n for (let i = 0; i < count; i = i + 1) {\r\n tabToggleButtonEl[i].classList.add('done');\r\n }\r\n //remove done class\r\n for (let j = count; j < tabToggleButtonEl.length; j = j + 1) {\r\n tabToggleButtonEl[j].classList.remove('done');\r\n }\r\n // card footer remove at last step\r\n if (count > tabToggleButtonEl.length - 2) {\r\n item.classList.add('done');\r\n cardFooter.classList.add('d-none');\r\n } else {\r\n cardFooter.classList.remove('d-none');\r\n }\r\n // prev-button removing\r\n if (count > 0) {\r\n prevButton.classList.remove('d-none');\r\n } else {\r\n prevButton.classList.add('d-none');\r\n }\r\n });\r\n });\r\n }\r\n });\r\n\r\n // control wizard progressbar\r\n if (tabPillEl.length) {\r\n const dividedProgressbar = 100 / tabPillEl.length;\r\n tabProgressBar.querySelector('.progress-bar').style.width =\r\n dividedProgressbar + '%';\r\n\r\n tabPillEl.forEach((item, index) => {\r\n item.addEventListener('shown.bs.tab', () => {\r\n tabProgressBar.querySelector('.progress-bar').style.width =\r\n dividedProgressbar * (index + 1) + '%';\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default wizardInit;\r\n","const { dayjs } = window;\r\nconst currentDay = dayjs && dayjs().format(\"DD\");\r\nconst currentMonth = dayjs && dayjs().format(\"MM\");\r\nconst prevMonth = dayjs && dayjs().subtract(1, \"month\").format(\"MM\");\r\nconst nextMonth = dayjs && dayjs().add(1, \"month\").format(\"MM\");\r\nconst currentYear = dayjs && dayjs().format(\"YYYY\");\r\nconst events = [\r\n {\r\n title: \"Boot Camp\",\r\n start: `${currentYear}-${currentMonth}-01 10:00:00`,\r\n end: `${currentYear}-${currentMonth}-03 16:00:00`,\r\n description:\r\n \"Boston Harbor Now in partnership with the Friends of Christopher Columbus Park, the Wharf District Council and the City of Boston is proud to announce the New Year's Eve Midnight Harbor Fireworks! This beloved nearly 40-year old tradition is made possible by the generous support of local waterfront organizations and businesses and the support of the City of Boston and the Office of Mayor Marty Walsh.\",\r\n className: \"bg-success-subtle\",\r\n location:\r\n \"Boston Harborwalk, Christopher Columbus Park,
    Boston, MA 02109, United States\",\r\n organizer: \"Boston Harbor Now\",\r\n },\r\n {\r\n title: `Crain's New York Business `,\r\n start: `${currentYear}-${currentMonth}-11`,\r\n description:\r\n \"Crain's 2020 Hall of Fame. Sponsored Content By Crain's Content Studio. Crain's Content Studio Presents: New Jersey: Perfect for Business. Crain's Business Forum: Letitia James, New York State Attorney General. Crain's NYC Summit: Examining racial disparities during the pandemic\",\r\n className: \"bg-primary-subtle\",\r\n },\r\n {\r\n title: \"Conference\",\r\n start: `${currentYear}-${currentMonth}-${currentDay}`,\r\n description:\r\n \"The Milken Institute Global Conference gathered the best minds in the world to tackle some of its most stubborn challenges. It was a unique experience in which individuals with the power to enact change connected with experts who are reinventing health, technology, philanthropy, industry, and media.\",\r\n className: \"bg-success-subtle\",\r\n allDay: true,\r\n schedules: [\r\n {\r\n title: \"Reporting\",\r\n start: `${currentYear}-${currentMonth}-${currentDay} 11:00:00`,\r\n description:\r\n \"Time to start the conference and will briefly describe all information about the event. \",\r\n className: \"event-bg-success-subtle\",\r\n },\r\n {\r\n title: \"Lunch\",\r\n start: `${currentYear}-${currentMonth}-${currentDay} 14:00:00`,\r\n description: \"Lunch facility for all the attendance in the conference.\",\r\n className: \"event-bg-success-subtle\",\r\n },\r\n {\r\n title: \"Contest\",\r\n start: `${currentYear}-${currentMonth}-${currentDay} 16:00:00`,\r\n description: \"The starting of the programming contest\",\r\n className: \"event-bg-success-subtle\",\r\n },\r\n {\r\n title: \"Dinner\",\r\n start: `${currentYear}-${currentMonth}-${currentDay} 22:00:00`,\r\n description: \"Dinner facility for all the attendance in the conference\",\r\n className: \"event-bg-success-subtle\",\r\n },\r\n ],\r\n },\r\n {\r\n title: `ICT Expo ${currentYear} - Product Release`,\r\n start: `${currentYear}-${currentMonth}-16 10:00:00`,\r\n description: `ICT Expo ${currentYear} is the largest private-sector exposition aimed at showcasing IT and ITES products and services in Switzerland.`,\r\n end: `${currentYear}-${currentMonth}-18 16:00:00`,\r\n className: \"bg-warning-subtle\",\r\n },\r\n {\r\n title: \"Meeting\",\r\n start: `${currentYear}-${currentMonth}-07 10:00:00`,\r\n description:\r\n \"Discuss about the upcoming projects in current year and assign all tasks to the individuals\",\r\n },\r\n {\r\n title: \"Contest\",\r\n start: `${currentYear}-${currentMonth}-14 10:00:00`,\r\n description:\r\n \"PeaceX is an international peace and amity organisation that aims at casting a pall at the striking issues surmounting the development of peoples and is committed to impacting the lives of young people all over the world.\",\r\n },\r\n {\r\n title: \"Event With Url\",\r\n start: `${currentYear}-${currentMonth}-23`,\r\n description:\r\n \"Sample example of a event with url. Click the event, will redirect to the given link.\",\r\n className: \"bg-success-subtle\",\r\n url: \"http://google.com\",\r\n },\r\n {\r\n title: \"Competition\",\r\n start: `${currentYear}-${currentMonth}-26`,\r\n description:\r\n \"The Future of Zambia – Top 30 Under 30 is an annual award, ranking scheme, and recognition platform for young Zambian achievers under the age of 30, who are building brands, creating jobs, changing the game, and transforming the country.\",\r\n className: \"bg-danger-subtle\",\r\n },\r\n {\r\n title: \"Birthday Party\",\r\n start: `${currentYear}-${nextMonth}-05`,\r\n description: \"Will celebrate birthday party with my friends and family\",\r\n className: \"bg-primary-subtle\",\r\n },\r\n {\r\n title: \"Click for Google\",\r\n url: \"http://google.com/\",\r\n start: `${currentYear}-${prevMonth}-10`,\r\n description:\r\n \"Applications are open for the New Media Writing Prize 2020. The New Media Writing Prize (NMWP) showcases exciting and inventive stories and poetry that integrate a variety of formats, platforms, and digital media.\",\r\n className: \"bg-primary-subtle\",\r\n },\r\n];\r\n\r\nexport default events;\r\n","\"use strict\";\r\n\r\nimport utils from \"../utils\";\r\nimport events from \"./events\";\r\nimport getTemplate from \"./template\";\r\nimport { renderCalendar } from \"../fullcalendar\";\r\n\r\n/*-----------------------------------------------\r\n| Calendar\r\n-----------------------------------------------*/\r\nconst appCalendarInit = () => {\r\n const Selectors = {\r\n ACTIVE: \".active\",\r\n ADD_EVENT_FORM: \"#addEventForm\",\r\n ADD_EVENT_MODAL: \"#addEventModal\",\r\n CALENDAR: \"#appCalendar\",\r\n CALENDAR_TITLE: \".calendar-title\",\r\n DATA_CALENDAR_VIEW: \"[data-fc-view]\",\r\n DATA_EVENT: \"[data-event]\",\r\n DATA_VIEW_TITLE: \"[data-view-title]\",\r\n EVENT_DETAILS_MODAL: \"#eventDetailsModal\",\r\n EVENT_DETAILS_MODAL_CONTENT: \"#eventDetailsModal .modal-content\",\r\n EVENT_START_DATE: '#addEventModal [name=\"startDate\"]',\r\n INPUT_TITLE: '[name=\"title\"]',\r\n };\r\n\r\n const Events = {\r\n CLICK: \"click\",\r\n SHOWN_BS_MODAL: \"shown.bs.modal\",\r\n SUBMIT: \"submit\",\r\n };\r\n\r\n const DataKeys = {\r\n EVENT: \"event\",\r\n FC_VIEW: \"fc-view\",\r\n };\r\n\r\n const ClassNames = {\r\n ACTIVE: \"active\",\r\n };\r\n\r\n const eventList = events.reduce(\r\n (acc, val) =>\r\n val.schedules ? acc.concat(val.schedules.concat(val)) : acc.concat(val),\r\n []\r\n );\r\n\r\n const updateTitle = (title) => {\r\n document.querySelector(Selectors.CALENDAR_TITLE).textContent = title;\r\n };\r\n\r\n const appCalendar = document.querySelector(Selectors.CALENDAR);\r\n const addEventForm = document.querySelector(Selectors.ADD_EVENT_FORM);\r\n const addEventModal = document.querySelector(Selectors.ADD_EVENT_MODAL);\r\n const eventDetailsModal = document.querySelector(\r\n Selectors.EVENT_DETAILS_MODAL\r\n );\r\n\r\n if (appCalendar) {\r\n const calendar = renderCalendar(appCalendar, {\r\n headerToolbar: false,\r\n dayMaxEvents: 2,\r\n height: 800,\r\n stickyHeaderDates: false,\r\n views: {\r\n week: {\r\n eventLimit: 3,\r\n },\r\n },\r\n eventTimeFormat: {\r\n hour: \"numeric\",\r\n minute: \"2-digit\",\r\n omitZeroMinute: true,\r\n meridiem: true,\r\n },\r\n events: eventList,\r\n eventClick: (info) => {\r\n if (info.event.url) {\r\n window.open(info.event.url, \"_blank\");\r\n info.jsEvent.preventDefault();\r\n } else {\r\n const template = getTemplate(info.event);\r\n document.querySelector(\r\n Selectors.EVENT_DETAILS_MODAL_CONTENT\r\n ).innerHTML = template;\r\n const modal = new window.bootstrap.Modal(eventDetailsModal);\r\n modal.show();\r\n }\r\n },\r\n dateClick(info) {\r\n const modal = new window.bootstrap.Modal(addEventModal);\r\n modal.show();\r\n /*eslint-disable-next-line*/\r\n const flatpickr = document.querySelector(\r\n Selectors.EVENT_START_DATE\r\n )._flatpickr;\r\n flatpickr.setDate([info.dateStr]);\r\n },\r\n });\r\n\r\n updateTitle(calendar.currentData.viewTitle);\r\n\r\n document.querySelectorAll(Selectors.DATA_EVENT).forEach((button) => {\r\n button.addEventListener(Events.CLICK, (e) => {\r\n const el = e.currentTarget;\r\n const type = utils.getData(el, DataKeys.EVENT);\r\n switch (type) {\r\n case \"prev\":\r\n calendar.prev();\r\n updateTitle(calendar.currentData.viewTitle);\r\n break;\r\n case \"next\":\r\n calendar.next();\r\n updateTitle(calendar.currentData.viewTitle);\r\n break;\r\n case \"today\":\r\n calendar.today();\r\n updateTitle(calendar.currentData.viewTitle);\r\n break;\r\n default:\r\n calendar.today();\r\n updateTitle(calendar.currentData.viewTitle);\r\n break;\r\n }\r\n });\r\n });\r\n\r\n document.querySelectorAll(Selectors.DATA_CALENDAR_VIEW).forEach((link) => {\r\n link.addEventListener(Events.CLICK, (e) => {\r\n e.preventDefault();\r\n const el = e.currentTarget;\r\n const text = el.textContent;\r\n el.parentElement\r\n .querySelector(Selectors.ACTIVE)\r\n .classList.remove(ClassNames.ACTIVE);\r\n el.classList.add(ClassNames.ACTIVE);\r\n document.querySelector(Selectors.DATA_VIEW_TITLE).textContent = text;\r\n calendar.changeView(utils.getData(el, DataKeys.FC_VIEW));\r\n updateTitle(calendar.currentData.viewTitle);\r\n });\r\n });\r\n\r\n addEventForm &&\r\n addEventForm.addEventListener(Events.SUBMIT, (e) => {\r\n e.preventDefault();\r\n const { title, startDate, endDate, label, description, allDay } =\r\n e.target;\r\n calendar.addEvent({\r\n title: title.value,\r\n start: startDate.value,\r\n end: endDate.value ? endDate.value : null,\r\n allDay: allDay.checked,\r\n className:\r\n allDay.checked && label.value ? `bg-${label.value}-subtle` : \"\",\r\n description: description.value,\r\n });\r\n e.target.reset();\r\n window.bootstrap.Modal.getInstance(addEventModal).hide();\r\n });\r\n }\r\n\r\n addEventModal &&\r\n addEventModal.addEventListener(\r\n Events.SHOWN_BS_MODAL,\r\n ({ currentTarget }) => {\r\n currentTarget.querySelector(Selectors.INPUT_TITLE).focus();\r\n }\r\n );\r\n};\r\n\r\nexport default appCalendarInit;\r\n","'use strict';\r\n\r\nimport utils from '../utils';\r\nimport managementEvents from './management-events';\r\nimport { renderCalendar } from '../fullcalendar';\r\nimport getTemplate from './template';\r\n\r\n/*-----------------------------------------------\r\n| Project Management Calendar\r\n-----------------------------------------------*/\r\nconst managementCalendarInit = () => {\r\n const Selectors = {\r\n ADD_EVENT_FORM: '#addEventForm',\r\n ADD_EVENT_MODAL: '#addEventModal',\r\n CALENDAR: '#managementAppCalendar',\r\n EVENT_DETAILS_MODAL: '#eventDetailsModal',\r\n EVENT_DETAILS_MODAL_CONTENT: '#eventDetailsModal .modal-content',\r\n DATA_EVENT: '[data-event]',\r\n DATA_VIEW_TITLE: '[data-view-title]',\r\n EVENT_START_DATE: '#addEventModal [name=\"startDate\"]',\r\n EVENT_MANAGEMENT_INFO: '[data-calendar-events]',\r\n };\r\n\r\n const Events = {\r\n CLICK: 'click',\r\n SUBMIT: 'submit',\r\n };\r\n\r\n const managementEventList = [];\r\n const DataKeys = {\r\n EVENT: 'event',\r\n };\r\n\r\n const managementCalendar = document.querySelector(Selectors.CALENDAR);\r\n\r\n if (managementCalendar) {\r\n const calendarData = utils.getData(managementCalendar, 'calendar-option');\r\n const managementCalendarEvents = document.getElementById(\r\n calendarData?.events\r\n );\r\n const addEventForm = document.querySelector(Selectors.ADD_EVENT_FORM);\r\n const addEventModal = document.querySelector(Selectors.ADD_EVENT_MODAL);\r\n const eventDetailsModal = document.querySelector(\r\n Selectors.EVENT_DETAILS_MODAL\r\n );\r\n const updateTitle = (title) => {\r\n const selectTitle = document.getElementById(calendarData?.title);\r\n if (selectTitle) {\r\n selectTitle.textContent = title;\r\n }\r\n };\r\n\r\n const updateDay = (day) => {\r\n const days = [\r\n 'Sunday',\r\n 'Monday',\r\n 'Tuesday',\r\n 'Wednesday',\r\n 'Thursday',\r\n 'Friday',\r\n 'Saturday',\r\n ];\r\n const selectDay = document.getElementById(calendarData?.day);\r\n if (selectDay) {\r\n selectDay.textContent = days[day];\r\n }\r\n };\r\n\r\n if (managementEvents) {\r\n managementEvents.forEach((e) => {\r\n managementEventList.push({\r\n start: e.start,\r\n end: e.end,\r\n display: 'background',\r\n classNames: `border border-2 border-${e.classNames} bg-100`,\r\n });\r\n });\r\n }\r\n\r\n if (managementCalendarEvents) {\r\n managementEvents.forEach((e) => {\r\n managementCalendarEvents.innerHTML += `\r\n
  • \r\n
    \r\n
    ${e.title}
    \r\n

    ${e.startTime || ''} ${\r\n e.endTime ? '-' : ''\r\n } ${e.endTime || ''}

    \r\n
    \r\n
  • `;\r\n });\r\n }\r\n\r\n const eventManagementInfo = document.querySelectorAll(\r\n Selectors.EVENT_MANAGEMENT_INFO\r\n );\r\n\r\n if (eventManagementInfo) {\r\n eventManagementInfo.forEach((li, index) => {\r\n li.addEventListener(Events.CLICK, () => {\r\n const event = managementEvents[index];\r\n const template = getTemplate(event);\r\n document.querySelector(\r\n Selectors.EVENT_DETAILS_MODAL_CONTENT\r\n ).innerHTML = template;\r\n const modal = new window.bootstrap.Modal(eventDetailsModal);\r\n modal.show();\r\n });\r\n });\r\n }\r\n\r\n if (managementCalendar) {\r\n const calendar = renderCalendar(managementCalendar, {\r\n headerToolbar: false,\r\n dayMaxEvents: 2,\r\n height: 360,\r\n stickyHeaderDates: false,\r\n dateClick(info) {\r\n const modal = new window.bootstrap.Modal(addEventModal);\r\n modal.show();\r\n /*eslint-disable-next-line*/\r\n const flatpickr = document.querySelector(\r\n Selectors.EVENT_START_DATE\r\n )._flatpickr;\r\n flatpickr.setDate([info.dateStr]);\r\n },\r\n events: managementEventList,\r\n });\r\n\r\n updateTitle(calendar.currentData.viewTitle);\r\n updateDay(calendar.currentData.currentDate.getDay());\r\n\r\n document.querySelectorAll(Selectors.DATA_EVENT).forEach((button) => {\r\n button.addEventListener(Events.CLICK, (e) => {\r\n const el = e.currentTarget;\r\n const type = utils.getData(el, DataKeys.EVENT);\r\n switch (type) {\r\n case 'prev':\r\n calendar.prev();\r\n updateTitle(calendar.currentData.viewTitle);\r\n break;\r\n case 'next':\r\n calendar.next();\r\n updateTitle(calendar.currentData.viewTitle);\r\n break;\r\n case 'today':\r\n calendar.today();\r\n updateTitle(calendar.currentData.viewTitle);\r\n break;\r\n default:\r\n calendar.today();\r\n updateTitle(calendar.currentData.viewTitle);\r\n break;\r\n }\r\n });\r\n });\r\n\r\n if (addEventForm) {\r\n addEventForm.addEventListener(Events.SUBMIT, (e) => {\r\n e.preventDefault();\r\n e.target.reset();\r\n window.bootstrap.Modal.getInstance(addEventModal).hide();\r\n });\r\n }\r\n }\r\n }\r\n};\r\n\r\nexport default managementCalendarInit;\r\n","const thisDay = window.dayjs && window.dayjs().format('DD');\r\nconst plus2Day = window.dayjs && window.dayjs().add(2, 'day').format('DD');\r\nconst thisMonthNumber = window.dayjs && window.dayjs().format('MM');\r\nconst thisMonthName = window.dayjs && window.dayjs().format('MMM');\r\nconst upcomingMonthNumber = window.dayjs && window.dayjs().add(1, 'month').format('MM');\r\nconst upcomingMonthName = window.dayjs && window.dayjs().format('MMM');\r\n\r\nconst thisYear = window.dayjs && window.dayjs().format('YYYY');\r\nconst managementEvents = [\r\n {\r\n title: 'Monthly team meeting for Falcon React Project',\r\n start: `${thisYear}-${thisMonthNumber}-07`,\r\n end: `${thisYear}-${thisMonthNumber}-09`,\r\n startTime: `07 ${thisMonthName}, ${thisYear}`,\r\n endTime: `10 ${thisMonthName}, ${thisYear}`,\r\n classNames: 'primary',\r\n extendedProps: {\r\n description:\r\n 'Boston Harbor Now in partnership with the Friends of Christopher Columbus Park, the Wharf District Council.',\r\n location:\r\n 'Boston Harborwalk, Christopher Columbus Park,
    Boston, MA 02109, United States',\r\n organizer: 'Boston Harbor Now'\r\n }\r\n },\r\n {\r\n title: 'Newmarket Nights',\r\n start: `${thisYear}-${thisMonthNumber}-16`,\r\n end: `${thisYear}-${thisMonthNumber}-18`,\r\n startTime: `16 ${thisMonthName}, ${thisYear}`,\r\n classNames: 'success',\r\n extendedProps: {\r\n description:\r\n 'Boston Harbor Now in partnership with the Friends of Christopher Columbus Park, the Wharf District Council.',\r\n location:\r\n 'Boston Harborwalk, Christopher Columbus Park,
    Boston, MA 02109, United States',\r\n organizer: 'Boston Harbor Now'\r\n }\r\n },\r\n {\r\n title: 'Folk Festival',\r\n start: `${thisYear}-${thisMonthNumber}-25`,\r\n end: `${thisYear}-${thisMonthNumber}-28`,\r\n startTime: `07 ${thisMonthName}, ${thisYear}`,\r\n endTime: `10 ${thisMonthName}, ${thisYear}`,\r\n classNames: 'warning',\r\n extendedProps: {\r\n description:\r\n 'Boston Harbor Now in partnership with the Friends of Christopher Columbus Park, the Wharf District Council.',\r\n location:\r\n 'Boston Harborwalk, Christopher Columbus Park,
    Boston, MA 02109, United States',\r\n organizer: 'Boston Harbor Now'\r\n }\r\n },\r\n {\r\n title: 'Film Festival',\r\n start: `${thisYear}-${upcomingMonthNumber}-${thisDay}`,\r\n end: `${thisYear}-${upcomingMonthNumber}-${plus2Day}`,\r\n startTime: `07 ${upcomingMonthName}, ${thisYear}`,\r\n endTime: `10 ${upcomingMonthName}, ${thisYear}`,\r\n classNames: 'danger',\r\n extendedProps: {\r\n description:\r\n 'Boston Harbor Now in partnership with the Friends of Christopher Columbus Park, the Wharf District Council.',\r\n location:\r\n 'Boston Harborwalk, Christopher Columbus Park,
    Boston, MA 02109, United States',\r\n organizer: 'Boston Harbor Now'\r\n }\r\n },\r\n {\r\n title: 'Meeting',\r\n start: `${thisYear}-${upcomingMonthNumber}-28`,\r\n startTime: `07 ${upcomingMonthName}, ${thisYear}`,\r\n classNames: 'warning',\r\n extendedProps: {\r\n description:\r\n 'Boston Harbor Now in partnership with the Friends of Christopher Columbus Park, the Wharf District Council.',\r\n location:\r\n 'Boston Harborwalk, Christopher Columbus Park,
    Boston, MA 02109, United States',\r\n organizer: 'Boston Harbor Now'\r\n }\r\n }\r\n];\r\n\r\nexport default managementEvents;\r\n","const getStackIcon = (icon, transform) => `\r\n \r\n \r\n \r\n \r\n`;\r\n\r\nconst getTemplate = event => `\r\n
    \r\n
    \r\n
    ${event.title}
    \r\n ${\r\n !!event.extendedProps.organizer\r\n ? `

    \r\n by ${event.extendedProps.organizer}\r\n

    `\r\n : ''\r\n }\r\n
    \r\n \r\n
    \r\n
    \r\n ${\r\n event.extendedProps.description\r\n ? `\r\n
    \r\n ${getStackIcon('fas fa-align-left')}\r\n
    \r\n
    Description
    \r\n

    \r\n \r\n ${event.extendedProps.description.split(' ').slice(0, 30).join(' ')}\r\n

    \r\n
    \r\n
    \r\n `\r\n : ''\r\n } \r\n
    \r\n ${getStackIcon('fas fa-calendar-check')}\r\n
    \r\n
    Date and Time
    \r\n

    \r\n ${window.dayjs && window.dayjs(event.start).format('dddd, MMMM D, YYYY, h:mm A')} \r\n ${\r\n event.end\r\n ? `–
    ${\r\n window.dayjs &&\r\n window.dayjs(event.end).subtract(1, 'day').format('dddd, MMMM D, YYYY, h:mm A')\r\n }`\r\n : ''\r\n }\r\n

    \r\n
    \r\n
    \r\n ${\r\n event.extendedProps.location\r\n ? `\r\n
    \r\n ${getStackIcon('fas fa-map-marker-alt')}\r\n
    \r\n
    Location
    \r\n

    ${event.extendedProps.location}

    \r\n
    \r\n
    \r\n `\r\n : ''\r\n }\r\n ${\r\n event.schedules\r\n ? `\r\n
    \r\n ${getStackIcon('fas fa-clock')}\r\n
    \r\n
    Schedule
    \r\n \r\n
      \r\n ${event.schedules.map(schedule => `
    • ${schedule.title}
    • `).join('')}\r\n
    \r\n
    \r\n `\r\n : ''\r\n }\r\n
    \r\n
    \r\n\r\n`;\r\n\r\nexport default getTemplate;\r\n","import * as d3 from 'd3';\r\nimport utils from '../../utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* D3 Packed Bubble Chart */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst D3PackedBubbleInit = () => {\r\n const $d3PackedBubble = document.querySelector('.d3-packed-bubble-chart');\r\n\r\n if ($d3PackedBubble) {\r\n const width = 960;\r\n const height = 960;\r\n const itemsSpacing = 30;\r\n\r\n const svg = d3.select('.d3-packed-bubble-svg');\r\n const tooltip = d3.select('.d3-packed-bubble-tooltip');\r\n const tooltipDot = tooltip.select('.d3-tooltip-dot');\r\n const tooltipName = tooltip.select('.d3-tooltip-name');\r\n const tooltipValue = tooltip.select('.d3-tooltip-value');\r\n\r\n const tooltipStyles = {\r\n backgroundColor: utils.getColor('gray-100'),\r\n tooltipNameColor: utils.getColor('gray-700'),\r\n tooltipValueColor: utils.getColor('gray-700'),\r\n };\r\n\r\n const labelStyles = {\r\n fill: '#ffffff',\r\n fontSize: '1.8rem',\r\n };\r\n\r\n const packedBubbleData = [\r\n { name: 'Blockchain', value: 160, color: '#2A7BE4' },\r\n { name: 'NFT', value: 20, color: '#1956A6' },\r\n { name: 'HTML', value: 90, color: '#195099' },\r\n { name: 'Crypto', value: 57, color: '#2A7BE4' },\r\n { name: 'Photoshop', value: 117, color: '#2A7BE4' },\r\n { name: 'UX', value: 20, color: '#1956A6' },\r\n { name: 'AWS', value: 90, color: '#195099' },\r\n { name: '3D', value: 33, color: '#9DBFEB' },\r\n { name: 'Writing', value: 117, color: '#2A7BE4' },\r\n { name: 'sql', value: 20, color: '#1956A6' },\r\n { name: 'Blender', value: 90, color: '#195099' },\r\n { name: 'UI/UX', value: 33, color: '#9DBFEB' },\r\n { name: 'Blockchain', value: 117, color: '#2A7BE4' },\r\n { name: 'css', value: 20, color: '#1956A6' },\r\n { name: 'Marketing', value: 90, color: '#195099' },\r\n { name: 'Meta', value: 33, color: '#9DBFEB' },\r\n { name: 'js', value: 12, color: '#0F67D9' },\r\n { name: 'FOREX', value: 66, color: '#7FA5D5' },\r\n { name: 'UI', value: 33, color: '#8ABBFB' },\r\n { name: 'Vector', value: 56, color: '#85B6F5' },\r\n { name: 'CAD', value: 28, color: '#6486B4' },\r\n { name: 'Python', value: 66, color: '#2A7BE4' },\r\n { name: 'Adobe', value: 66, color: '#68A0E9' },\r\n { name: 'C#', value: 20, color: '#385780' },\r\n { name: 'Branding', value: 88, color: '#74A2DE' },\r\n { name: 'Bitcoin', value: 80, color: '#4E7AB4' },\r\n { name: 'AI', value: 34, color: '#71AFFF' },\r\n ];\r\n\r\n const generateChart = (data) => {\r\n const bubble = (bubbleData) =>\r\n d3.pack().size([width, height]).padding(itemsSpacing)(\r\n d3.hierarchy({ children: bubbleData }).sum((d) => d.value)\r\n );\r\n\r\n tooltip.style('visibility', 'hidden');\r\n\r\n svg\r\n .attr('width', '100%')\r\n .attr('height', '100%')\r\n .attr('viewBox', `-20 10 ${width} ${height}`);\r\n\r\n const root = bubble(data);\r\n\r\n const node = svg\r\n .selectAll()\r\n .data(root.children)\r\n .enter()\r\n .append('g')\r\n .style('cursor', 'pointer')\r\n .style('pointer-events', 'all')\r\n .attr('text-anchor', 'middle')\r\n .on('mousemove', (e) =>\r\n tooltip\r\n .style('top', `${e.clientY - 40}px`)\r\n .style('left', `${e.clientX - 40}px`)\r\n )\r\n .attr('transform', (d) => `translate(${d.x}, ${d.y})`);\r\n\r\n const circle = node\r\n .append('circle')\r\n .style('fill', (d) => d.data.color)\r\n .on('mouseover', (e, d) => {\r\n d3.select(e.target)\r\n .transition()\r\n .ease(d3.easeExpInOut)\r\n .duration(200)\r\n .attr('r', (diagram) => diagram.r * 1.1);\r\n tooltip\r\n .style('visibility', 'visible')\r\n .style('z-index', '100000')\r\n .style('background-color', tooltipStyles.backgroundColor)\r\n .style('border', `1px solid ${d.data.color}`);\r\n tooltipDot.style('background-color', d.data.color);\r\n tooltipName\r\n .text(d.data.name)\r\n .style('color', tooltipStyles.tooltipNameColor);\r\n tooltipValue\r\n .text(d.data.value)\r\n .style('color', tooltipStyles.tooltipValueColor);\r\n })\r\n .on('mouseout', (e) => {\r\n d3.select(e.target)\r\n .transition()\r\n .ease(d3.easeExpInOut)\r\n .duration(200)\r\n .attr('r', (d) => d.r);\r\n tooltip.style('visibility', 'hidden');\r\n });\r\n\r\n const label = node\r\n .append('text')\r\n .style('fill', labelStyles.fill)\r\n .style('font-size', labelStyles.fontSize)\r\n .style('pointer-events', 'none')\r\n .style('opacity', 0)\r\n .attr('dy', '.35em')\r\n .text((d) => d.data.name);\r\n\r\n node.transition().ease(d3.easeExpInOut).duration(1000);\r\n\r\n circle\r\n .transition()\r\n .ease(d3.easeExpInOut)\r\n .duration(1000)\r\n .attr('r', (d) => d.r);\r\n\r\n label\r\n .transition()\r\n .delay(400)\r\n .ease(d3.easeExpInOut)\r\n .duration(2000)\r\n .style('opacity', 1);\r\n };\r\n\r\n generateChart(packedBubbleData);\r\n }\r\n};\r\n\r\nexport default D3PackedBubbleInit;\r\n","import * as d3 from 'd3';\r\nimport utils from '../../utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Trending Keywords */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst trendingKeywordsInit = () => {\r\n const $d3TrendingKeywords = document.querySelector('.d3-trending-keywords');\r\n\r\n if ($d3TrendingKeywords) {\r\n const width = 960;\r\n const height = 960;\r\n const itemsSpacing = 30;\r\n\r\n const svg = d3.select('.d3-trending-keywords-svg');\r\n const tooltip = d3.select('.d3-trending-keywords-tooltip');\r\n const tooltipDot = tooltip.select('.d3-tooltip-dot');\r\n const tooltipName = tooltip.select('.d3-tooltip-name');\r\n const tooltipValue = tooltip.select('.d3-tooltip-value');\r\n\r\n const tooltipStyles = {\r\n backgroundColor: utils.getColor('gray-100'),\r\n tooltipNameColor: utils.getColor('gray-700'),\r\n tooltipValueColor: utils.getColor('gray-700'),\r\n };\r\n\r\n const labelStyles = {\r\n fill: '#ffffff',\r\n fontSize: '1.8rem',\r\n };\r\n\r\n const trendingKeywordsData = [\r\n { name: 'Blockchain', value: 160, color: '#2A7BE4' },\r\n { name: 'NFT', value: 20, color: '#1956A6' },\r\n { name: 'HTML', value: 90, color: '#195099' },\r\n { name: 'Crypto', value: 57, color: '#2A7BE4' },\r\n { name: 'Photoshop', value: 117, color: '#2A7BE4' },\r\n { name: 'UX', value: 20, color: '#1956A6' },\r\n { name: 'AWS', value: 90, color: '#195099' },\r\n { name: '3D', value: 33, color: '#9DBFEB' },\r\n { name: 'Writing', value: 117, color: '#2A7BE4' },\r\n { name: 'sql', value: 20, color: '#1956A6' },\r\n { name: 'Blender', value: 90, color: '#195099' },\r\n { name: 'UI/UX', value: 33, color: '#9DBFEB' },\r\n { name: 'Blockchain', value: 117, color: '#2A7BE4' },\r\n { name: 'css', value: 20, color: '#1956A6' },\r\n { name: 'Marketing', value: 90, color: '#195099' },\r\n { name: 'Meta', value: 33, color: '#9DBFEB' },\r\n { name: 'js', value: 12, color: '#0F67D9' },\r\n { name: 'FOREX', value: 66, color: '#7FA5D5' },\r\n { name: 'UI', value: 33, color: '#8ABBFB' },\r\n { name: 'Vector', value: 56, color: '#85B6F5' },\r\n { name: 'CAD', value: 28, color: '#6486B4' },\r\n { name: 'Python', value: 66, color: '#2A7BE4' },\r\n { name: 'Adobe', value: 66, color: '#68A0E9' },\r\n { name: 'C#', value: 20, color: '#385780' },\r\n { name: 'Branding', value: 88, color: '#74A2DE' },\r\n { name: 'Bitcoin', value: 80, color: '#4E7AB4' },\r\n { name: 'AI', value: 34, color: '#71AFFF' },\r\n ];\r\n\r\n const generateChart = (data) => {\r\n const bubble = (bubbleData) =>\r\n d3.pack().size([width, height]).padding(itemsSpacing)(\r\n d3.hierarchy({ children: bubbleData }).sum((d) => d.value)\r\n );\r\n\r\n tooltip.style('visibility', 'hidden');\r\n\r\n svg\r\n .attr('width', '100%')\r\n .attr('height', '100%')\r\n .attr('viewBox', `-20 10 ${width} ${height}`);\r\n\r\n const root = bubble(data);\r\n\r\n const node = svg\r\n .selectAll()\r\n .data(root.children)\r\n .enter()\r\n .append('g')\r\n .style('cursor', 'pointer')\r\n .style('pointer-events', 'all')\r\n .attr('text-anchor', 'middle')\r\n .on('mousemove', (e) =>\r\n tooltip\r\n .style('top', `${e.clientY - 40}px`)\r\n .style('left', `${e.clientX - 40}px`)\r\n )\r\n .attr('transform', (d) => `translate(${d.x}, ${d.y})`);\r\n\r\n const circle = node\r\n .append('circle')\r\n .style('fill', (d) => d.data.color)\r\n .on('mouseover', (e, d) => {\r\n d3.select(e.target)\r\n .transition()\r\n .ease(d3.easeExpInOut)\r\n .duration(200)\r\n .attr('r', (diagram) => diagram.r * 1.1);\r\n tooltip\r\n .style('visibility', 'visible')\r\n .style('z-index', '100000')\r\n .style('background-color', tooltipStyles.backgroundColor)\r\n .style('border', `1px solid ${d.data.color}`);\r\n tooltipDot.style('background-color', d.data.color);\r\n tooltipName\r\n .text(d.data.name)\r\n .style('color', tooltipStyles.tooltipNameColor);\r\n tooltipValue\r\n .text(d.data.value)\r\n .style('color', tooltipStyles.tooltipValueColor);\r\n })\r\n .on('mouseout', (e) => {\r\n d3.select(e.target)\r\n .transition()\r\n .ease(d3.easeExpInOut)\r\n .duration(200)\r\n .attr('r', (d) => d.r);\r\n tooltip.style('visibility', 'hidden');\r\n });\r\n\r\n const label = node\r\n .append('text')\r\n .style('fill', labelStyles.fill)\r\n .style('font-size', labelStyles.fontSize)\r\n .style('pointer-events', 'none')\r\n .style('opacity', 0)\r\n .attr('dy', '.35em')\r\n .text((d) => d.data.name);\r\n\r\n node.transition().ease(d3.easeExpInOut).duration(1000);\r\n\r\n circle\r\n .transition()\r\n .ease(d3.easeExpInOut)\r\n .duration(1000)\r\n .attr('r', (d) => d.r);\r\n\r\n label\r\n .transition()\r\n .delay(400)\r\n .ease(d3.easeExpInOut)\r\n .duration(2000)\r\n .style('opacity', 1);\r\n };\r\n\r\n generateChart(trendingKeywordsData);\r\n }\r\n};\r\n\r\nexport default trendingKeywordsInit;\r\n","import utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* bar-chart */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst barChartInit = () => {\r\n const barChartElement = document.getElementById('chartjs-bar-chart');\r\n\r\n const getOptions = () => ({\r\n type: 'bar',\r\n data: {\r\n labels: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun'],\r\n datasets: [\r\n {\r\n label: '# of Votes',\r\n data: [12, 19, 3, 5, 6, 3],\r\n backgroundColor: [\r\n utils.rgbaColor(utils.getColor('secondary'), 0.2),\r\n utils.rgbaColor(utils.getColor('warning'), 0.2),\r\n utils.rgbaColor(utils.getColor('info'), 0.2),\r\n utils.rgbaColor(utils.getColor('success'), 0.2),\r\n utils.rgbaColor(utils.getColor('info'), 0.2),\r\n utils.rgbaColor(utils.getColor('primary'), 0.2)\r\n ],\r\n borderColor: [\r\n utils.getColor('secondary'),\r\n utils.getColor('warning'),\r\n utils.getColor('info'),\r\n utils.getColor('success'),\r\n utils.getColor('info'),\r\n utils.getColor('primary')\r\n ],\r\n borderWidth: 1\r\n }\r\n ]\r\n },\r\n options: {\r\n plugins: {\r\n tooltip: chartJsDefaultTooltip()\r\n },\r\n scales: {\r\n x: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n },\r\n y: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1),\r\n drawBorder: true\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n chartJsInit(barChartElement, getOptions);\r\n};\r\n\r\nexport default barChartInit;\r\n","/* eslint-disable */\r\nimport utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit, getBubbleDataset } from './chartjs-utils';\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Bubble */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst chartBubble = () => {\r\n const pie = document.getElementById('chartjs-bubble-chart');\r\n const getOptions = () => ({\r\n type: 'bubble',\r\n data: {\r\n datasets: [\r\n {\r\n label: 'Dataset 1',\r\n data: getBubbleDataset(5, 5, 15, 0, 100),\r\n backgroundColor: utils.getSubtleColors()['primary'],\r\n hoverBackgroundColor: utils.getColors()['primary']\r\n },\r\n {\r\n label: 'Dataset 2',\r\n data: getBubbleDataset(5, 5, 15, 0, 100),\r\n backgroundColor: utils.getSubtleColors()['success'],\r\n hoverBackgroundColor: utils.getColors()['success']\r\n },\r\n {\r\n label: 'Dataset 3',\r\n data: getBubbleDataset(5, 5, 15, 0, 100),\r\n backgroundColor: utils.getSubtleColors()['danger'],\r\n hoverBackgroundColor: utils.getColors()['danger']\r\n }\r\n ]\r\n },\r\n options: {\r\n plugins: {\r\n legend: {\r\n position: 'top'\r\n },\r\n tooltip: chartJsDefaultTooltip()\r\n },\r\n scales: {\r\n x: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n },\r\n y: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n chartJsInit(pie, getOptions);\r\n};\r\n\r\nexport default chartBubble;\r\n","import utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Combo */\r\n/* -------------------------------------------------------------------------- */\r\nconst chartCombo = () => {\r\n const combo = document.getElementById('chartjs-combo-chart');\r\n\r\n const getOptions = () => ({\r\n type: 'bar',\r\n data: {\r\n labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July'],\r\n datasets: [\r\n {\r\n type: 'line',\r\n label: 'Dataset 1',\r\n borderColor: utils.getColor('primary'),\r\n borderWidth: 2,\r\n fill: false,\r\n data: [55, 80, -60, -22, -50, 40, 90]\r\n },\r\n {\r\n type: 'bar',\r\n label: 'Dataset 2',\r\n backgroundColor: utils.getSubtleColors()['danger'],\r\n data: [4, -80, 90, -22, 70, 35, -50],\r\n borderWidth: 1\r\n },\r\n {\r\n type: 'bar',\r\n label: 'Dataset 3',\r\n backgroundColor: utils.getSubtleColors()['primary'],\r\n data: [-30, 30, -18, 100, -45, -25, -50],\r\n borderWidth: 1\r\n }\r\n ]\r\n },\r\n options: {\r\n maintainAspectRatio: false,\r\n plugins: {\r\n tooltip: chartJsDefaultTooltip()\r\n },\r\n scales: {\r\n x: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n },\r\n y: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n chartJsInit(combo, getOptions);\r\n};\r\n\r\nexport default chartCombo;\r\n","import utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Doughnut */\r\n/* -------------------------------------------------------------------------- */\r\nconst chartDoughnut = () => {\r\n const doughnut = document.getElementById('chartjs-doughnut-chart');\r\n\r\n const getOptions = () => ({\r\n type: 'doughnut',\r\n data: {\r\n datasets: [\r\n {\r\n data: [5, 3, 2, 1, 1],\r\n backgroundColor: [\r\n utils.rgbaColor(utils.getColor('facebook'), 0.2),\r\n utils.rgbaColor(utils.getColor('youtube'), 0.2),\r\n utils.rgbaColor(utils.getColor('twitter'), 0.2),\r\n utils.rgbaColor(utils.getColor('linkedin'), 0.2),\r\n utils.rgbaColor(utils.getColor('github'), 0.2)\r\n ],\r\n borderWidth: 1,\r\n borderColor: [\r\n utils.getColor('facebook'),\r\n utils.getColor('youtube'),\r\n utils.getColor('twitter'),\r\n utils.getColor('linkedin'),\r\n utils.getColor('github')\r\n ]\r\n }\r\n ],\r\n\r\n labels: ['Facebook', 'Youtube', 'Twitter', 'Linkedin', 'GitHub']\r\n },\r\n options: {\r\n plugins: {\r\n tooltip: chartJsDefaultTooltip()\r\n },\r\n maintainAspectRatio: false\r\n }\r\n });\r\n\r\n chartJsInit(doughnut, getOptions);\r\n};\r\n\r\nexport default chartDoughnut;\r\n","import utils from '../../utils';\r\nimport { chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Half Doughnut */\r\n/* -------------------------------------------------------------------------- */\r\nconst chartHalfDoughnutInit = () => {\r\n const $chartHalfDoughnuts = document.querySelectorAll('[data-half-doughnut]');\r\n\r\n $chartHalfDoughnuts.forEach(($chartHalfDoughnut) => {\r\n if ($chartHalfDoughnut) {\r\n const getOptions = () => {\r\n const userOptions = utils.getData($chartHalfDoughnut, 'half-doughnut');\r\n const defaultOptions = {\r\n type: 'doughnut',\r\n data: {\r\n labels: ['Reached', 'Target'],\r\n datasets: [\r\n {\r\n data: [50, 50],\r\n backgroundColor: ['primary', 'gray-300'],\r\n borderWidth: [0, 0, 0, 0],\r\n },\r\n ],\r\n },\r\n options: {\r\n rotation: -90,\r\n circumference: '180',\r\n cutout: '80%',\r\n hover: { mode: null },\r\n plugins: {\r\n legend: {\r\n display: false,\r\n },\r\n tooltip: {\r\n enabled: false,\r\n },\r\n },\r\n },\r\n };\r\n const options = window._.merge(defaultOptions, userOptions);\r\n const mergedDatasets = options.data.datasets[0];\r\n\r\n mergedDatasets.backgroundColor = [\r\n utils.getColor(mergedDatasets.backgroundColor[0]),\r\n utils.getColor(mergedDatasets.backgroundColor[1]),\r\n ];\r\n\r\n return options;\r\n };\r\n\r\n chartJsInit($chartHalfDoughnut, getOptions);\r\n }\r\n });\r\n};\r\n\r\nexport default chartHalfDoughnutInit;\r\n","import utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Line */\r\n/* -------------------------------------------------------------------------- */\r\nconst chartLine = () => {\r\n const line = document.getElementById('chartjs-line-chart');\r\n\r\n const getOptions = () => ({\r\n type: 'bar',\r\n data: {\r\n labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July'],\r\n datasets: [\r\n {\r\n type: 'line',\r\n label: 'Dataset 1',\r\n borderColor: utils.getColor('primary'),\r\n borderWidth: 2,\r\n fill: false,\r\n data: [55, 80, 60, 22, 50, 40, 90],\r\n tension: 0.3\r\n }\r\n ]\r\n },\r\n options: {\r\n plugins: {\r\n tooltip: chartJsDefaultTooltip()\r\n },\r\n scales: {\r\n x: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n },\r\n y: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n chartJsInit(line, getOptions);\r\n};\r\n\r\nexport default chartLine;\r\n","import utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Pie */\r\n/* -------------------------------------------------------------------------- */\r\nconst chartPie = () => {\r\n const pie = document.getElementById('chartjs-pie-chart');\r\n const getOptions = () => ({\r\n type: 'pie',\r\n data: {\r\n datasets: [\r\n {\r\n data: [5, 3, 2, 1, 1],\r\n backgroundColor: [\r\n utils.rgbaColor(utils.getColor('facebook'), 0.75),\r\n utils.rgbaColor(utils.getColor('youtube'), 0.75),\r\n utils.rgbaColor(utils.getColor('twitter'), 0.75),\r\n utils.rgbaColor(utils.getColor('linkedin'), 0.75),\r\n utils.rgbaColor(utils.getColor('github'), 0.75)\r\n ],\r\n borderWidth: 1,\r\n borderColor: utils.getGrays()['100']\r\n }\r\n ],\r\n\r\n labels: ['Facebook', 'Youtube', 'Twitter', 'Linkedin', 'GitHub']\r\n },\r\n options: {\r\n plugins: {\r\n tooltip: chartJsDefaultTooltip()\r\n },\r\n maintainAspectRatio: false\r\n }\r\n });\r\n\r\n chartJsInit(pie, getOptions);\r\n};\r\n\r\nexport default chartPie;\r\n","import utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Polar */\r\n/* -------------------------------------------------------------------------- */\r\nconst chartPolar = () => {\r\n const polar = document.getElementById('chartjs-polar-chart');\r\n\r\n const getOptions = () => ({\r\n type: 'polarArea',\r\n data: {\r\n datasets: [\r\n {\r\n data: [10, 20, 50, 40, 30],\r\n backgroundColor: [\r\n utils.rgbaColor(utils.getColor('facebook'), 0.5),\r\n utils.rgbaColor(utils.getColor('youtube'), 0.5),\r\n utils.rgbaColor(utils.getColor('twitter'), 0.5),\r\n utils.rgbaColor(utils.getColor('linkedin'), 0.5),\r\n utils.rgbaColor(utils.getColor('success'), 0.5)\r\n ],\r\n borderWidth: 1,\r\n borderColor: utils.getGrays()['400']\r\n }\r\n ],\r\n\r\n labels: ['Facebook', 'Youtube', 'Twitter', 'Linkedin', 'Medium']\r\n },\r\n options: {\r\n plugins: {\r\n tooltip: chartJsDefaultTooltip()\r\n },\r\n maintainAspectRatio: false,\r\n scales: {\r\n r: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n chartJsInit(polar, getOptions);\r\n};\r\n\r\nexport default chartPolar;\r\n","import utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Radar */\r\n/* -------------------------------------------------------------------------- */\r\nconst chartRadar = () => {\r\n const radar = document.getElementById('chartjs-radar-chart');\r\n\r\n const getOptions = () => ({\r\n type: 'radar',\r\n data: {\r\n labels: ['English', 'Maths', 'Physics', 'Chemistry', 'Biology', 'History'],\r\n datasets: [\r\n {\r\n label: 'Student A',\r\n backgroundColor: utils.rgbaColor(utils.getColor('success'), 0.5),\r\n data: [65, 75, 70, 80, 60, 80],\r\n borderWidth: 1\r\n },\r\n {\r\n label: 'Student B',\r\n backgroundColor: utils.rgbaColor(utils.getColor('primary'), 0.5),\r\n data: [54, 65, 60, 70, 70, 75],\r\n borderWidth: 1\r\n }\r\n ]\r\n },\r\n options: {\r\n plugins: {\r\n tooltip: chartJsDefaultTooltip()\r\n },\r\n maintainAspectRatio: false,\r\n scales: {\r\n r: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n chartJsInit(radar, getOptions);\r\n};\r\n\r\nexport default chartRadar;\r\n","import utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Scatter */\r\n/* -------------------------------------------------------------------------- */\r\nconst chartScatter = () => {\r\n const scatter = document.getElementById('chartjs-scatter-chart');\r\n\r\n const getOptions = () => ({\r\n type: 'scatter',\r\n data: {\r\n datasets: [\r\n {\r\n label: 'Dataset one',\r\n data: [\r\n {\r\n x: -98,\r\n y: 42\r\n },\r\n {\r\n x: -85,\r\n y: -29\r\n },\r\n {\r\n x: -87,\r\n y: -70\r\n },\r\n {\r\n x: -53,\r\n y: 28\r\n },\r\n {\r\n x: -29,\r\n y: 4\r\n },\r\n {\r\n x: -2,\r\n y: -42\r\n },\r\n {\r\n x: 5,\r\n y: 3\r\n },\r\n {\r\n x: 39,\r\n y: 19\r\n },\r\n {\r\n x: 49,\r\n y: 79\r\n },\r\n {\r\n x: 83,\r\n y: -9\r\n },\r\n {\r\n x: 93,\r\n y: 12\r\n }\r\n ],\r\n pointBackgroundColor: utils.getColor('primary'),\r\n borderColor: utils.getColor('primary'),\r\n borderWidth: 1\r\n },\r\n {\r\n label: 'Dataset Two',\r\n data: [\r\n {\r\n x: 53,\r\n y: 12\r\n },\r\n {\r\n x: -78,\r\n y: 42\r\n },\r\n {\r\n x: -65,\r\n y: -39\r\n },\r\n {\r\n x: -57,\r\n y: -20\r\n },\r\n {\r\n x: 57,\r\n y: 28\r\n },\r\n {\r\n x: -35,\r\n y: 75\r\n },\r\n {\r\n x: -29,\r\n y: -43\r\n },\r\n {\r\n x: 15,\r\n y: 31\r\n },\r\n {\r\n x: 97,\r\n y: 19\r\n },\r\n {\r\n x: 49,\r\n y: 69\r\n },\r\n {\r\n x: 33,\r\n y: -57\r\n }\r\n ],\r\n pointBackgroundColor: utils.getColor('warning'),\r\n borderColor: utils.getColor('warning'),\r\n borderWidth: 1,\r\n borderRadius: '50%'\r\n }\r\n ]\r\n },\r\n options: {\r\n plugins: {\r\n tooltip: chartJsDefaultTooltip()\r\n },\r\n scales: {\r\n x: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n },\r\n y: {\r\n grid: {\r\n color: utils.rgbaColor(utils.getGrays()['black'], 0.1)\r\n }\r\n }\r\n },\r\n animation: {\r\n duration: 2000\r\n }\r\n }\r\n });\r\n\r\n chartJsInit(scatter, getOptions);\r\n};\r\n\r\nexport default chartScatter;\r\n","import utils from '../../utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* ChartJs Initialization */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst chartJsInit = (chartEl, config) => {\r\n if (!chartEl) return;\r\n\r\n const ctx = chartEl.getContext('2d');\r\n let chart = new window.Chart(ctx, config());\r\n\r\n const themeController = document.body;\r\n themeController.addEventListener(\r\n 'clickControl',\r\n ({ detail: { control } }) => {\r\n if (control === 'theme') {\r\n chart.destroy();\r\n chart = new window.Chart(ctx, config());\r\n }\r\n return null;\r\n }\r\n );\r\n};\r\n\r\nconst chartJsDefaultTooltip = () => ({\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n borderWidth: 1,\r\n titleColor: utils.getGrays()['black'],\r\n callbacks: {\r\n labelTextColor() {\r\n return utils.getGrays()['black'];\r\n },\r\n },\r\n});\r\n\r\nconst getBubbleDataset = (count, rmin, rmax, min, max) => {\r\n const arr = Array.from(Array(count).keys());\r\n return arr.map(() => ({\r\n x: utils.getRandomNumber(min, max),\r\n y: utils.getRandomNumber(min, max),\r\n r: utils.getRandomNumber(rmin, rmax),\r\n }));\r\n};\r\n\r\nexport default { chartJsDefaultTooltip, chartJsInit, getBubbleDataset };\r\n","/* eslint-disable */\r\nimport utils from '../../utils';\r\nimport { chartJsDefaultTooltip, chartJsInit } from './chartjs-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Chart Scatter */\r\n/* -------------------------------------------------------------------------- */\r\nconst productShareDoughnutInit = () => {\r\n const marketShareDoughnutElement = document.getElementById(\r\n 'marketShareDoughnut'\r\n );\r\n\r\n const getOptions = () => ({\r\n type: 'doughnut',\r\n data: {\r\n labels: ['Flacon', 'Sparrow'],\r\n datasets: [\r\n {\r\n data: [50, 88],\r\n backgroundColor: [utils.getColor('primary'), utils.getColor('gray-300')],\r\n borderColor: [utils.getColor('primary'), utils.getColor('gray-300')],\r\n },\r\n ],\r\n },\r\n options: {\r\n tooltips: chartJsDefaultTooltip(),\r\n rotation: -90,\r\n circumference: '180',\r\n cutout: '80%',\r\n plugins: {\r\n legend: {\r\n display: false,\r\n },\r\n },\r\n },\r\n });\r\n\r\n chartJsInit(marketShareDoughnutElement, getOptions);\r\n};\r\n\r\nexport default productShareDoughnutInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Active Users */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst activeUsersChartReportInit = () => {\r\n const $echartsActiveUsersChart = document.querySelector(\r\n '.echart-active-users-report'\r\n );\r\n\r\n if ($echartsActiveUsersChart) {\r\n const userOptions = utils.getData($echartsActiveUsersChart, 'options');\r\n const chart = window.echarts.init($echartsActiveUsersChart);\r\n\r\n const tooltipFormatter = params => {\r\n return `\r\n
    \r\n

    ${window\r\n .dayjs(params[0].axisValue)\r\n .format('MMM DD, YYYY')}

    \r\n
    \r\n
    ${\r\n params[0].value\r\n }
    \r\n
    ${\r\n params[1].value\r\n }
    \r\n
    ${\r\n params[2].value\r\n }
    \r\n
    \r\n
    \r\n `;\r\n };\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColor('primary'),\r\n utils.getColor('success'),\r\n utils.getColor('info'),\r\n ],\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n formatter: tooltipFormatter,\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: utils\r\n .getPastDates(30)\r\n .map(date => window.dayjs(date).format('DD MMM, YYYY')),\r\n boundaryGap: false,\r\n silent: true,\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n },\r\n },\r\n splitLine: { show: false },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n },\r\n },\r\n axisTick: {\r\n show: true,\r\n length: 20,\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n },\r\n\r\n interval: 5,\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: value => window.dayjs(value).format('MMM DD'),\r\n align: 'left',\r\n fontSize: 11,\r\n padding: [0, 0, 0, 5],\r\n interval: 5,\r\n },\r\n },\r\n yAxis: {\r\n type: 'value',\r\n position: 'right',\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n },\r\n },\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()['600'],\r\n formatter: value => `${Math.round((value / 1000) * 10) / 10}k`,\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false },\r\n },\r\n series: [\r\n {\r\n type: 'line',\r\n data: [\r\n 4164, 4652, 4817, 4841, 4920, 5439, 5486, 5498, 5512, 5538, 5841,\r\n 5877, 6086, 6146, 6199, 6431, 6704, 7939, 8127, 8296, 8322, 8389,\r\n 8411, 8502, 8868, 8977, 9273, 9325, 9345, 9430,\r\n ],\r\n showSymbol: false,\r\n symbol: 'circle',\r\n itemStyle: {\r\n borderColor: utils.getColors().primary,\r\n borderWidth: 2,\r\n },\r\n lineStyle: {\r\n color: utils.getColor('primary'),\r\n },\r\n symbolSize: 2,\r\n },\r\n {\r\n type: 'line',\r\n data: [\r\n 2164, 2292, 2386, 2430, 2528, 3045, 3255, 3295, 3481, 3604, 3688,\r\n 3840, 3932, 3949, 4003, 4298, 4424, 4869, 4922, 4973, 5155, 5267,\r\n 5566, 5689, 5692, 5758, 5773, 5799, 5960, 6000,\r\n ],\r\n showSymbol: false,\r\n symbol: 'circle',\r\n itemStyle: {\r\n borderColor: utils.getColors().success,\r\n borderWidth: 2,\r\n },\r\n lineStyle: {\r\n color: utils.getColor('success'),\r\n },\r\n symbolSize: 2,\r\n },\r\n {\r\n type: 'line',\r\n data: [\r\n 1069, 1089, 1125, 1141, 1162, 1179, 1185, 1216, 1274, 1322, 1346,\r\n 1395, 1439, 1564, 1581, 1590, 1656, 1815, 1868, 2010, 2133, 2179,\r\n 2264, 2265, 2278, 2343, 2354, 2456, 2472, 2480,\r\n ],\r\n showSymbol: false,\r\n symbol: 'circle',\r\n itemStyle: {\r\n borderColor: utils.getColors().info,\r\n borderWidth: 2,\r\n },\r\n lineStyle: {\r\n color: utils.getColor('info'),\r\n },\r\n symbolSize: 2,\r\n },\r\n ],\r\n grid: { right: '30px', left: '5px', bottom: '20px', top: '20px' },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default activeUsersChartReportInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption, getPosition } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Market Share */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst assignmentScoresInit = () => {\r\n const $echartAssignmentScores = document.querySelector(\r\n '.echart-assignment-scores'\r\n );\r\n\r\n if ($echartAssignmentScores) {\r\n const userOptions = utils.getData($echartAssignmentScores, 'options');\r\n const chart = window.echarts.init($echartAssignmentScores);\r\n\r\n const data = [\r\n { value: 12, name: '90-100%' },\r\n { value: 16, name: '70-90%' },\r\n { value: 12, name: '40-70%' },\r\n { value: 2, name: '0-40%' },\r\n ];\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColors().success,\r\n utils.getColors().primary,\r\n utils.getColors().info,\r\n utils.getColors().warning,\r\n ],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter(params) {\r\n return `${params.data.name}: ${params.data.value} courses`;\r\n },\r\n },\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n legend: { show: false },\r\n series: [\r\n {\r\n type: 'pie',\r\n radius: ['85%', '60%'],\r\n avoidLabelOverlap: false,\r\n hoverAnimation: false,\r\n itemStyle: {\r\n borderWidth: 2,\r\n borderColor: utils.getColor('gray-100'),\r\n },\r\n label: {\r\n normal: {\r\n show: false,\r\n position: 'center',\r\n textStyle: {\r\n fontSize: '20',\r\n fontWeight: '500',\r\n color: utils.getGrays()['700'],\r\n },\r\n },\r\n emphasis: {\r\n show: false,\r\n },\r\n },\r\n labelLine: { normal: { show: false } },\r\n data,\r\n },\r\n ],\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default assignmentScoresInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Audience Chart */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst audienceChartInit = () => {\r\n const data = {\r\n dates: utils.getPastDates(7),\r\n dataset: {\r\n users: [\r\n [504, 333, 400, 606, 451, 685, 404],\r\n [237, 229, 707, 575, 420, 536, 258],\r\n ],\r\n sessions: [\r\n [322, 694, 235, 537, 791, 292, 806],\r\n [584, 661, 214, 286, 526, 707, 627],\r\n ],\r\n rate: [\r\n [789, 749, 412, 697, 633, 254, 472],\r\n [276, 739, 525, 394, 643, 653, 719],\r\n ],\r\n duration: [\r\n [625, 269, 479, 654, 549, 305, 671],\r\n [499, 670, 550, 222, 696, 695, 469],\r\n ],\r\n },\r\n };\r\n const tooltipFormatter = params => {\r\n const percentage =\r\n ((params[0].value - params[1].value) / params[1].value) * 100;\r\n const perTemp = `\r\n
    \r\n \r\n
    ${Math.abs(percentage).toFixed(\r\n 2\r\n )} %
    \r\n
    \r\n `;\r\n const currentDate = new Date(params[0].axisValue);\r\n const prevDate = new Date(new Date().setDate(currentDate.getDate() - 7));\r\n return `
    \r\n

    ${window\r\n .dayjs(params[0].axisValue)\r\n .format('MMM DD')} vs ${window.dayjs(prevDate).format('MMM DD')}

    \r\n
    \r\n

    \r\n Users: ${\r\n params[0].data\r\n }\r\n

    \r\n ${perTemp}\r\n
    \r\n
    `;\r\n };\r\n\r\n const getDefaultOptions = (data1, data2) => () => ({\r\n color: utils.getGrays().white,\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n formatter: tooltipFormatter,\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: data.dates,\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: value => window.dayjs(value).format('MMM DD'),\r\n align: 'left',\r\n fontSize: 11,\r\n padding: [0, 0, 0, 5],\r\n showMaxLabel: false,\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n },\r\n },\r\n axisTick: {\r\n show: true,\r\n length: 20,\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n },\r\n },\r\n boundaryGap: false,\r\n },\r\n yAxis: {\r\n position: 'right',\r\n axisPointer: { type: 'none' },\r\n axisTick: 'none',\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n },\r\n },\r\n axisLine: { show: false },\r\n axisLabel: { color: utils.getGrays()['600'] },\r\n },\r\n series: [\r\n {\r\n type: 'line',\r\n data: data1,\r\n showSymbol: false,\r\n symbol: 'circle',\r\n itemStyle: {\r\n borderColor: utils.getColors().primary,\r\n borderWidth: 2,\r\n },\r\n lineStyle: {\r\n color: utils.getColor('primary'),\r\n },\r\n areaStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 0,\r\n y2: 1,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color: utils.rgbaColor(utils.getColors().primary, 0.2),\r\n },\r\n {\r\n offset: 1,\r\n color: utils.rgbaColor(utils.getColors().primary, 0),\r\n },\r\n ],\r\n },\r\n },\r\n },\r\n {\r\n type: 'line',\r\n data: data2,\r\n symbol: 'none',\r\n lineStyle: {\r\n type: 'dashed',\r\n width: 1,\r\n color: utils.getColor('info'),\r\n },\r\n },\r\n ],\r\n grid: { right: '40px', left: '5px', bottom: '10%', top: '3%' },\r\n });\r\n\r\n const initChart = (el, options) => {\r\n const userOptions = utils.getData(el, 'options');\r\n const chart = window.echarts.init(el);\r\n echartSetOption(chart, userOptions, options);\r\n };\r\n\r\n const tab = document.querySelector('#audience-chart-tab');\r\n\r\n if (tab) {\r\n initChart(\r\n document.querySelector('.echart-audience'),\r\n getDefaultOptions(data.dataset.users[0], data.dataset.users[1])\r\n );\r\n\r\n const triggerTabList = Array.from(\r\n tab.querySelectorAll('[data-bs-toggle=\"tab\"]')\r\n );\r\n triggerTabList.forEach(function (triggerEl) {\r\n triggerEl.addEventListener('shown.bs.tab', function () {\r\n const key = triggerEl.href.split('#').pop();\r\n const $echartAudience = document\r\n .getElementById(key)\r\n .querySelector('.echart-audience');\r\n\r\n initChart(\r\n $echartAudience,\r\n getDefaultOptions(data.dataset[key][0], data.dataset[key][1])\r\n );\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default audienceChartInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Total Sales E-commerce */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst avgEnrollmentRateInit = () => {\r\n const $echartsLineAvgEnrollmentLms = document.querySelector(\r\n '.echart-avg-enrollment-rate'\r\n );\r\n\r\n function getFormatter(params) {\r\n return params\r\n .map(\r\n ({ seriesName, value, borderColor }) =>\r\n `\r\n \r\n ${seriesName} : ${value}\r\n `\r\n )\r\n .join('
    ');\r\n }\r\n if ($echartsLineAvgEnrollmentLms) {\r\n const userOptions = utils.getData($echartsLineAvgEnrollmentLms, 'options');\r\n const onSaleCourseRate = document.querySelector(\r\n `#${userOptions.optionOne}`\r\n );\r\n const regularPaidCourseRate = document.querySelector(\r\n `#${userOptions.optionTwo}`\r\n );\r\n\r\n const chart = window.echarts.init($echartsLineAvgEnrollmentLms);\r\n const getDefaultOptions = () => ({\r\n color: utils.getGrays()['100'],\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n formatter(params) {\r\n return getFormatter(params);\r\n },\r\n transitionDuration: 0,\r\n },\r\n legend: {\r\n show: false,\r\n },\r\n xAxis: [\r\n {\r\n type: 'category',\r\n position: 'bottom',\r\n data: [\r\n 'launch',\r\n 'week 1',\r\n 'week 2',\r\n 'week 3',\r\n 'week 4',\r\n 'week 5',\r\n 'week 6',\r\n 'week 7',\r\n 'week 8',\r\n 'week 9',\r\n 'week 10',\r\n 'week 11',\r\n 'week 12',\r\n ],\r\n boundaryGap: false,\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n type: 'line',\r\n },\r\n },\r\n splitLine: { show: false },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n type: 'line',\r\n },\r\n },\r\n\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getColor('gray-500'),\r\n formatter(value) {\r\n return value;\r\n },\r\n interval: 3,\r\n margin: 15,\r\n showMinLabel: true,\r\n showMaxLabel: false,\r\n align: 'center',\r\n },\r\n },\r\n {\r\n type: 'category',\r\n position: 'bottom',\r\n data: [\r\n 'launch',\r\n 'week 1',\r\n 'week 2',\r\n 'week 3',\r\n 'week 4',\r\n 'week 5',\r\n 'week 6',\r\n 'week 7',\r\n 'week 8',\r\n 'week 9',\r\n 'week 10',\r\n 'week 11',\r\n 'week 12',\r\n ],\r\n boundaryGap: false,\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n type: 'line',\r\n },\r\n },\r\n splitLine: { show: false },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n type: 'line',\r\n },\r\n },\r\n\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getColor('gray-500'),\r\n formatter(value) {\r\n return value;\r\n },\r\n interval: 200,\r\n margin: 15,\r\n showMaxLabel: true,\r\n showMinLabel: false,\r\n align: 'right',\r\n },\r\n },\r\n ],\r\n yAxis: {\r\n type: 'value',\r\n splitNumber: 3,\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getColor('gray-200'),\r\n type: 'line',\r\n },\r\n },\r\n boundaryGap: false,\r\n axisLabel: {\r\n showMinLabel: false,\r\n show: true,\r\n color: utils.getColor('gray-400'),\r\n formatter: (value) => `${Math.round((value / 1000) * 10) / 10}k`,\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false },\r\n },\r\n\r\n series: [\r\n {\r\n name: 'On Sale Course',\r\n type: 'line',\r\n data: [\r\n 2000, 2800, 2200, 3001, 600, 600, 2000, 2000, 700, 1000, 200, 900,\r\n 1200,\r\n ],\r\n lineStyle: { color: utils.getColor('primary') },\r\n itemStyle: {\r\n borderColor: utils.getColor('primary'),\r\n borderWidth: 2,\r\n },\r\n symbol: 'circle',\r\n symbolSize: 10,\r\n hoverAnimation: true,\r\n },\r\n\r\n {\r\n name: 'Regular Paid Course',\r\n type: 'line',\r\n data: [\r\n 1700, 1200, 500, 700, 1500, 1100, 700, 1100, 2600, 2050, 1050, 600,\r\n 700,\r\n ],\r\n lineStyle: { color: utils.getColor('warning'), type: 'dashed' },\r\n itemStyle: {\r\n borderColor: utils.getColor('warning'),\r\n borderWidth: 2,\r\n },\r\n symbol: 'circle',\r\n symbolSize: 10,\r\n hoverAnimation: true,\r\n areaStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 0,\r\n y2: 1,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color: utils.rgbaColor(utils.getColor('warning'), 0.4),\r\n },\r\n {\r\n offset: 1,\r\n color: utils.rgbaColor(utils.getColor('warning'), 0),\r\n },\r\n ],\r\n },\r\n },\r\n },\r\n ],\r\n grid: {\r\n right: '10px',\r\n left: '30px',\r\n bottom: '15%',\r\n top: '5%',\r\n },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n onSaleCourseRate.addEventListener('click', () => {\r\n onSaleCourseRate.classList.toggle('opacity-50');\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'On Sale Course',\r\n });\r\n });\r\n\r\n regularPaidCourseRate.addEventListener('click', () => {\r\n regularPaidCourseRate.classList.toggle('opacity-50');\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'Regular Paid Course',\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default avgEnrollmentRateInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Bandwidth Saved */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst bandwidthSavedInit = () => {\r\n const $echartsBandwidthSaved = document.querySelector(\r\n '.echart-bandwidth-saved'\r\n );\r\n\r\n if ($echartsBandwidthSaved) {\r\n const userOptions = utils.getData($echartsBandwidthSaved, 'options');\r\n const chart = window.echarts.init($echartsBandwidthSaved);\r\n\r\n const getDefaultOptions = () => ({\r\n series: [\r\n {\r\n type: 'gauge',\r\n startAngle: 90,\r\n endAngle: -270,\r\n radius: '90%',\r\n pointer: {\r\n show: false,\r\n },\r\n progress: {\r\n show: true,\r\n overlap: false,\r\n roundCap: true,\r\n clip: false,\r\n itemStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 1,\r\n y2: 0,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color: '#1970e2',\r\n },\r\n {\r\n offset: 1,\r\n color: '#4695ff',\r\n },\r\n ],\r\n },\r\n },\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n width: 8,\r\n color: [[1, utils.getColor('gray-200')]],\r\n },\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisTick: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n data: [\r\n {\r\n value: 93,\r\n detail: {\r\n offsetCenter: ['7%', '4%'],\r\n },\r\n },\r\n ],\r\n detail: {\r\n width: 50,\r\n height: 14,\r\n fontSize: 28,\r\n fontWeight: 500,\r\n fontFamily: 'poppins',\r\n color: utils.getColor('gray-500'),\r\n formatter: '{value}%',\r\n valueAnimation: true,\r\n },\r\n animationDuration: 3000,\r\n },\r\n ],\r\n });\r\n\r\n const initChart = () => {\r\n if (utils.isScrolledIntoView($echartsBandwidthSaved)) {\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n window.removeEventListener('scroll', initChart);\r\n }\r\n };\r\n\r\n window.addEventListener('scroll', initChart);\r\n }\r\n};\r\n\r\nexport default bandwidthSavedInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption, getPosition } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echart Bar Member info */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst basicEchartsInit = () => {\r\n const $echartBasicCharts = document.querySelectorAll('[data-echarts]');\r\n\r\n $echartBasicCharts.forEach(($echartBasicChart) => {\r\n const userOptions = utils.getData($echartBasicChart, 'echarts');\r\n const chart = window.echarts.init($echartBasicChart);\r\n const getDefaultOptions = () => ({\r\n color: utils.getColors().primary,\r\n tooltip: {\r\n trigger: 'item',\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n },\r\n xAxis: {\r\n type: 'category',\r\n show: false,\r\n boundaryGap: false,\r\n },\r\n yAxis: {\r\n show: false,\r\n type: 'value',\r\n boundaryGap: false,\r\n },\r\n series: [\r\n {\r\n type: 'bar',\r\n symbol: 'none',\r\n areaStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 0,\r\n y2: 1,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color: utils.rgbaColor(utils.getColor('primary'), 0.25),\r\n },\r\n {\r\n offset: 1,\r\n color: utils.rgbaColor(utils.getColor('primary'), 0),\r\n },\r\n ],\r\n },\r\n },\r\n },\r\n ],\r\n grid: {\r\n right: '0',\r\n left: '0',\r\n bottom: '0',\r\n top: '0',\r\n },\r\n });\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n });\r\n};\r\n\r\nexport default basicEchartsInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Bounce Rate */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst bounceRateChartInit = () => {\r\n const $echartsBounceRateChart = document.querySelector('.echart-bounce-rate');\r\n\r\n const tooltipFormatter = params => {\r\n return `
    \r\n

    ${window\r\n .dayjs(params[0].axisValue)\r\n .format('DD, MMMM')}

    \r\n
    \r\n

    \r\n Rate : ${params[0].value}%\r\n

    \r\n
    \r\n
    `;\r\n };\r\n\r\n const dataset = {\r\n week: [41, 45, 37, 44, 35, 39, 43],\r\n month: [\r\n 40, 37, 42, 44, 36, 39, 37, 43, 38, 35, 43, 39, 42, 36, 37, 36, 42, 44,\r\n 34, 41, 37, 41, 40, 40, 43, 34, 41, 35, 44, 41, 40,\r\n ],\r\n };\r\n\r\n if ($echartsBounceRateChart) {\r\n const userOptions = utils.getData($echartsBounceRateChart, 'options');\r\n const chart = window.echarts.init($echartsBounceRateChart);\r\n\r\n const getDefaultOptions = () => ({\r\n color: utils.getGrays().white,\r\n title: {\r\n text: 'Bounce Rate',\r\n padding: [5, 0, 0, 0],\r\n textStyle: {\r\n color: utils.getGrays()['900'],\r\n fontSize: 13,\r\n fontWeight: 600,\r\n },\r\n },\r\n tooltip: {\r\n trigger: 'axis',\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n formatter: tooltipFormatter,\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: utils\r\n .getPastDates(30)\r\n .map(date => window.dayjs(date).format('DD MMM, YYYY')),\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n },\r\n },\r\n splitLine: { show: false },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['400'],\r\n },\r\n },\r\n axisTick: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: value => window.dayjs(value).format('MMM DD'),\r\n fontSize: 11,\r\n },\r\n },\r\n yAxis: {\r\n type: 'value',\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n },\r\n },\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()['600'],\r\n formatter: value => `${value}%`,\r\n margin: 15,\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false },\r\n },\r\n series: [\r\n {\r\n type: 'line',\r\n data: [\r\n 40, 37, 42, 44, 36, 39, 37, 43, 38, 35, 43, 39, 42, 36, 37, 36, 42,\r\n 44, 34, 41, 37, 41, 40, 40, 43, 34, 41, 35, 44, 41, 40,\r\n ],\r\n showSymbol: false,\r\n symbol: 'circle',\r\n itemStyle: {\r\n borderColor: utils.getColors().primary,\r\n borderWidth: 2,\r\n },\r\n lineStyle: {\r\n color: utils.getColor('primary'),\r\n },\r\n symbolSize: 2,\r\n },\r\n ],\r\n grid: { right: '10px', left: '40px', bottom: '10%', top: '13%' },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n const selectMenu = document.querySelector(\r\n \"[data-target='.echart-bounce-rate']\"\r\n );\r\n\r\n if (selectMenu) {\r\n selectMenu.addEventListener('change', e => {\r\n const value = e.currentTarget.value;\r\n chart.setOption({\r\n xAxis: {\r\n data: utils\r\n .getPastDates(value)\r\n .map(date => window.dayjs(date).format('DD MMM, YYYY')),\r\n },\r\n series: [{ data: dataset[value] }],\r\n });\r\n });\r\n }\r\n }\r\n};\r\n\r\nexport default bounceRateChartInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Browsed Courses */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst browsedCoursesInit = () => {\r\n const $echartsBrowsedCourses = document.querySelector(\r\n '.echart-browsed-courses'\r\n );\r\n\r\n const months = [\r\n 'Jan',\r\n 'Feb',\r\n 'Mar',\r\n 'Apr',\r\n 'May',\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\r\n const tooltipFormatter = (params) => `\r\n
    \r\n

    \r\n ${\r\n window.dayjs(params[0].axisValue).isValid()\r\n ? window.dayjs(params[0].axisValue).format('MMMM YYYY')\r\n : params[0].axisValue\r\n }\r\n

    \r\n ${params\r\n .map(\r\n ({ seriesName, value, borderColor }) =>\r\n `\r\n \r\n ${seriesName} : ${value}\r\n `\r\n )\r\n .join('
    ')}\r\n
    `;\r\n\r\n if ($echartsBrowsedCourses) {\r\n const userOptions = utils.getData($echartsBrowsedCourses, 'options');\r\n const newCourseBrowsedEl = document.querySelector(\r\n `#${userOptions.optionOne}`\r\n );\r\n const paidCourseBrowsedEl = document.querySelector(\r\n `#${userOptions.optionTwo}`\r\n );\r\n const chart = window.echarts.init($echartsBrowsedCourses);\r\n\r\n const getDefaultOptions = () => ({\r\n color: utils.getGrays()['100'],\r\n legend: {\r\n data: ['newCourseBrowsed', 'paidCourseBrowsed'],\r\n show: false,\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: [\r\n '2020-01-01',\r\n '2020-02-01',\r\n '2020-03-01',\r\n '2020-04-01',\r\n '2020-05-01',\r\n '2020-06-01',\r\n '2020-07-01',\r\n '2020-08-01',\r\n '2020-09-01',\r\n '2020-10-01',\r\n '2020-11-01',\r\n '2020-12-01',\r\n '2021-01-01',\r\n '2021-02-01',\r\n '2021-03-01',\r\n '2021-04-01',\r\n '2021-05-01',\r\n '2021-06-01',\r\n '2021-07-01',\r\n '2021-08-01',\r\n '2021-09-01',\r\n '2021-10-01',\r\n '2021-11-01',\r\n '2021-12-01',\r\n ],\r\n axisLine: {\r\n show: false,\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisTick: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: (value) => {\r\n const date = new Date(value);\r\n return `${months[date.getMonth()]}`;\r\n },\r\n interval: 2,\r\n },\r\n },\r\n yAxis: {\r\n type: 'value',\r\n show: false,\r\n },\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter(params) {\r\n return tooltipFormatter(params);\r\n },\r\n },\r\n\r\n series: [\r\n {\r\n name: 'Total',\r\n type: 'bar',\r\n barWidth: '50%',\r\n z: -1,\r\n data: [\r\n 600, 832, 901, 934, 1290, 1330, 1320, 1250, 1190, 1345, 1009, 1320,\r\n 600, 832, 901, 934, 1290, 1330, 1320, 1250, 1190, 1345, 1009, 1320,\r\n ],\r\n itemStyle: {\r\n emphasis: {\r\n color: utils.getSubtleColors().info,\r\n barBorderRadius: [5, 5, 0, 0],\r\n borderWidth: 1,\r\n borderColor: utils.getGrays()[300],\r\n },\r\n normal: {\r\n color: utils.getSubtleColors().primary,\r\n barBorderRadius: [5, 5, 0, 0],\r\n borderWidth: 1,\r\n borderColor: utils.getGrays()[300],\r\n },\r\n },\r\n },\r\n {\r\n name: 'Paid',\r\n type: 'bar',\r\n barWidth: '50%',\r\n barGap: '-100%',\r\n data: [\r\n 320, 420, 800, 100, 1000, 930, 720, 1020, 800, 320, 450, 150, 320,\r\n 420, 800, 100, 1000, 930, 720, 1020, 800, 320, 450, 150,\r\n ],\r\n itemStyle: {\r\n normal: {\r\n barBorderRadius: [5, 5, 0, 0],\r\n color: utils.getColors().primary,\r\n borderWidth: 1,\r\n borderColor: utils.getColors().primary,\r\n },\r\n },\r\n },\r\n ],\r\n\r\n grid: {\r\n right: '0px',\r\n left: '0px',\r\n bottom: '10%',\r\n top: '15%',\r\n },\r\n });\r\n\r\n const initChart = () => {\r\n if (utils.isScrolledIntoView($echartsBrowsedCourses)) {\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n window.removeEventListener('scroll', initChart);\r\n }\r\n };\r\n\r\n window.addEventListener('scroll', initChart);\r\n\r\n newCourseBrowsedEl.addEventListener('click', () => {\r\n newCourseBrowsedEl.classList.toggle('opacity-50');\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'Total',\r\n });\r\n });\r\n\r\n paidCourseBrowsedEl.addEventListener('click', () => {\r\n paidCourseBrowsedEl.classList.toggle('opacity-50');\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'Paid',\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default browsedCoursesInit;\r\n","import utils from \"../../utils\";\r\nimport { getPosition, echartSetOption } from \"./echarts-utils\";\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Candle Chart */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst candleChartInit = () => {\r\n const ECHART_CANDLE_CHART = \".echart-candle-chart\";\r\n const ECHART_ZOOM_IN = \"[data-zoom='in']\";\r\n const ECHART_ZOOM_OUT = \"[data-zoom='out']\";\r\n\r\n const $echartsCandleChart = document.querySelector(ECHART_CANDLE_CHART);\r\n\r\n\r\n\r\n if ($echartsCandleChart) {\r\n const userOptions = utils.getData($echartsCandleChart, \"options\");\r\n const chart = window.echarts.init($echartsCandleChart);\r\n\r\n const $echartsZoomIn = document\r\n .getElementById($echartsCandleChart.dataset.actionTarget)\r\n .querySelector(ECHART_ZOOM_IN);\r\n const $echartsZoomOut = document\r\n .getElementById($echartsCandleChart.dataset.actionTarget)\r\n .querySelector(ECHART_ZOOM_OUT);\r\n\r\n let warning = utils.getColors()[\"warning\"];\r\n let primary = utils.getColors()[\"primary\"];\r\n\r\n const splitData = (rawData) => {\r\n let categoryData = [];\r\n let values = [];\r\n\r\n rawData.forEach((item) => {\r\n categoryData.push(item.splice(0, 1)[0]);\r\n values.push(item);\r\n });\r\n return { categoryData, values };\r\n };\r\n\r\n const data = splitData([\r\n [\"2013/1/24\", 2320.26, 2320.26, 2287.3, 2362.94],\r\n [\"2013/1/25\", 2300, 2291.3, 2288.26, 2308.38],\r\n [\"2013/1/28\", 2295.35, 2346.5, 2295.35, 2346.92],\r\n [\"2013/1/29\", 2347.22, 2358.98, 2337.35, 2363.8],\r\n [\"2013/1/30\", 2360.75, 2382.48, 2347.89, 2383.76],\r\n [\"2013/1/31\", 2383.43, 2385.42, 2371.23, 2391.82],\r\n [\"2013/2/1\", 2377.41, 2419.02, 2369.57, 2421.15],\r\n [\"2013/2/4\", 2425.92, 2428.15, 2417.58, 2440.38],\r\n [\"2013/2/5\", 2411, 2433.13, 2403.3, 2437.42],\r\n [\"2013/2/6\", 2432.68, 2434.48, 2427.7, 2441.73],\r\n [\"2013/2/7\", 2430.69, 2418.53, 2394.22, 2433.89],\r\n [\"2013/2/8\", 2416.62, 2432.4, 2414.4, 2443.03],\r\n [\"2013/2/18\", 2441.91, 2421.56, 2415.43, 2444.8],\r\n [\"2013/2/19\", 2420.26, 2382.91, 2373.53, 2427.07],\r\n [\"2013/2/20\", 2383.49, 2397.18, 2370.61, 2397.94],\r\n [\"2013/2/21\", 2378.82, 2325.95, 2309.17, 2378.82],\r\n [\"2013/2/22\", 2322.94, 2314.16, 2308.76, 2330.88],\r\n [\"2013/2/25\", 2320.62, 2325.82, 2315.01, 2338.78],\r\n [\"2013/2/26\", 2313.74, 2293.34, 2289.89, 2340.71],\r\n [\"2013/2/27\", 2297.77, 2313.22, 2292.03, 2324.63],\r\n [\"2013/2/28\", 2322.32, 2365.59, 2308.92, 2366.16],\r\n [\"2013/3/1\", 2364.54, 2359.51, 2330.86, 2369.65],\r\n [\"2013/3/4\", 2332.08, 2273.4, 2259.25, 2333.54],\r\n [\"2013/3/5\", 2274.81, 2326.31, 2270.1, 2328.14],\r\n [\"2013/3/6\", 2333.61, 2347.18, 2321.6, 2351.44],\r\n [\"2013/3/7\", 2340.44, 2324.29, 2304.27, 2352.02],\r\n [\"2013/3/8\", 2326.42, 2318.61, 2314.59, 2333.67],\r\n [\"2013/3/11\", 2314.68, 2310.59, 2296.58, 2320.96],\r\n [\"2013/3/12\", 2309.16, 2286.6, 2264.83, 2333.29],\r\n [\"2013/3/13\", 2282.17, 2263.97, 2253.25, 2286.33],\r\n [\"2013/3/14\", 2255.77, 2270.28, 2253.31, 2276.22],\r\n [\"2013/3/15\", 2269.31, 2278.4, 2250, 2312.08],\r\n [\"2013/3/18\", 2267.29, 2240.02, 2239.21, 2276.05],\r\n [\"2013/3/19\", 2244.26, 2257.43, 2232.02, 2261.31],\r\n [\"2013/3/20\", 2257.74, 2317.37, 2257.42, 2317.86],\r\n [\"2013/3/21\", 2318.21, 2324.24, 2311.6, 2330.81],\r\n [\"2013/3/22\", 2321.4, 2328.28, 2314.97, 2332],\r\n [\"2013/3/25\", 2334.74, 2326.72, 2319.91, 2344.89],\r\n [\"2013/3/26\", 2318.58, 2297.67, 2281.12, 2319.99],\r\n [\"2013/3/27\", 2299.38, 2301.26, 2289, 2323.48],\r\n [\"2013/3/28\", 2273.55, 2236.3, 2232.91, 2273.55],\r\n [\"2013/3/29\", 2238.49, 2236.62, 2228.81, 2246.87],\r\n [\"2013/4/1\", 2229.46, 2234.4, 2227.31, 2243.95],\r\n [\"2013/4/2\", 2234.9, 2227.74, 2220.44, 2253.42],\r\n [\"2013/4/3\", 2232.69, 2225.29, 2217.25, 2241.34],\r\n [\"2013/4/8\", 2196.24, 2211.59, 2180.67, 2212.59],\r\n [\"2013/4/9\", 2215.47, 2225.77, 2215.47, 2234.73],\r\n [\"2013/4/10\", 2224.93, 2226.13, 2212.56, 2233.04],\r\n [\"2013/4/11\", 2236.98, 2219.55, 2217.26, 2242.48],\r\n [\"2013/4/12\", 2218.09, 2206.78, 2204.44, 2226.26],\r\n ]);\r\n\r\n let zoomStart = 0;\r\n let zoomEnd = 70;\r\n\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: \"axis\",\r\n // axisPointer: {\r\n // type: \"cross\",\r\n // },\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()[\"100\"],\r\n borderColor: utils.getGrays()[\"300\"],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n },\r\n xAxis: {\r\n type: \"category\",\r\n data: data.categoryData,\r\n scale: true,\r\n splitLine: { show: false },\r\n splitNumber: 10,\r\n min: \"dataMin\",\r\n max: \"dataMax\",\r\n boundaryGap: true,\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getGrays()[\"300\"],\r\n type: \"dashed\",\r\n },\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()[\"300\"],\r\n type: \"solid\",\r\n },\r\n },\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getGrays()[\"600\"],\r\n formatter: function (value) {\r\n return new Date(value).toLocaleString(\"en-US\", {\r\n month: \"short\",\r\n day: \"numeric\",\r\n });\r\n },\r\n margin: 15,\r\n fontWeight: 500,\r\n },\r\n },\r\n yAxis: {\r\n scale: true,\r\n position: \"right\",\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()[\"200\"],\r\n type: \"dashed\",\r\n },\r\n },\r\n boundaryGap: false,\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()[\"600\"],\r\n margin: 15,\r\n fontWeight: 500,\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false },\r\n },\r\n dataZoom: [\r\n {\r\n type: \"inside\",\r\n start: zoomStart,\r\n end: zoomEnd,\r\n },\r\n ],\r\n\r\n series: [\r\n {\r\n name: \"candlestick\",\r\n type: \"candlestick\",\r\n data: data.values,\r\n itemStyle: {\r\n color: warning,\r\n color0: primary,\r\n borderColor: warning,\r\n borderColor0: primary,\r\n },\r\n },\r\n ],\r\n grid: { right: \"70px\", left: \"20px\", bottom: \"15%\", top: \"20px\" },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n const dispatchZoomAction = () => {\r\n chart.dispatchAction({\r\n type: \"dataZoom\",\r\n start: zoomStart,\r\n end: zoomEnd,\r\n });\r\n };\r\n\r\n $echartsZoomIn.addEventListener(\"click\", () => {\r\n if (zoomEnd > 10) {\r\n zoomEnd -= 10;\r\n }\r\n\r\n if (zoomEnd <= 10) {\r\n $echartsZoomIn.disabled = true;\r\n }\r\n\r\n if (zoomEnd > 0) {\r\n $echartsZoomOut.disabled = false;\r\n dispatchZoomAction();\r\n }\r\n });\r\n\r\n $echartsZoomOut.addEventListener(\"click\", () => {\r\n if (zoomEnd < 100) {\r\n zoomEnd += 10;\r\n }\r\n\r\n if (zoomEnd >= 100) {\r\n $echartsZoomOut.disabled = true;\r\n }\r\n\r\n if (zoomEnd > 0) {\r\n $echartsZoomIn.disabled = false;\r\n dispatchZoomAction();\r\n }\r\n });\r\n\r\n chart.on(\"dataZoom\", function (params) {\r\n if (params.batch) {\r\n zoomStart = params.batch[0].start;\r\n zoomEnd = params.batch[0].end;\r\n }\r\n });\r\n }\r\n};\r\n\r\nexport default candleChartInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption, tooltipFormatter } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Total Sales */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst closedVsGoalInit = () => {\r\n const ECHART_LINE_TOTAL_SALES = '.echart-closed-vs-goal';\r\n\r\n const $echartsLineTotalSales = document.querySelector(ECHART_LINE_TOTAL_SALES);\r\n const months = [\r\n 'Jan',\r\n 'Feb',\r\n 'Mar',\r\n 'Apr',\r\n 'May',\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\r\n if ($echartsLineTotalSales) {\r\n // Get options from data attribute\r\n const userOptions = utils.getData($echartsLineTotalSales, 'options');\r\n const chart = window.echarts.init($echartsLineTotalSales);\r\n\r\n const getDefaultOptions = () => ({\r\n color: [utils.getColors().primary, utils.getColors().warning],\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n formatter: tooltipFormatter,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n }\r\n },\r\n\r\n legend: {\r\n left: 'left',\r\n data: ['Closed Amount', 'Revenue Date'],\r\n itemWidth: 10,\r\n itemHeight: 10,\r\n borderRadius: 0,\r\n icon: 'circle',\r\n inactiveColor: utils.getGrays()['400'],\r\n textStyle: { color: utils.getGrays()['700'] },\r\n itemGap: 20\r\n },\r\n xAxis: {\r\n type: 'category',\r\n name: 'Closed Date',\r\n nameGap: 50,\r\n nameLocation: 'center',\r\n offset: 0,\r\n nameTextStyle: {\r\n color: utils.getGrays()['700']\r\n },\r\n data: [\r\n '2019-06-15',\r\n '2019-06-22',\r\n '2019-06-29',\r\n '2019-07-06',\r\n '2019-07-13',\r\n '2019-07-20',\r\n '2019-07-27',\r\n '2019-07-12',\r\n '2019-07-03'\r\n ],\r\n boundaryGap: false,\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed'\r\n }\r\n },\r\n splitLine: { show: false },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.rgbaColor('#000', 0.01),\r\n type: 'dashed'\r\n }\r\n },\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getGrays()['400'],\r\n formatter: function (value) {\r\n var date = new Date(value);\r\n return `${date.getDate()} ${months[date.getMonth()]} , 21`;\r\n },\r\n margin: 20\r\n }\r\n },\r\n yAxis: {\r\n type: 'value',\r\n name: 'Closed Amount',\r\n nameGap: 85,\r\n nameLocation: 'middle',\r\n nameTextStyle: {\r\n color: utils.getGrays()['700']\r\n },\r\n splitNumber: 3,\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200']\r\n }\r\n },\r\n boundaryGap: false,\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()['400'],\r\n formatter: function (value) {\r\n return `$${value}`;\r\n },\r\n margin: 15\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false }\r\n },\r\n series: [\r\n {\r\n type: 'line',\r\n name: 'Closed Amount',\r\n data: [0, 5000, 18000, 40000, 58000, 65000, 90000, 110000, 140000],\r\n symbolSize: 5,\r\n symbol: 'circle',\r\n smooth: false,\r\n hoverAnimation: true,\r\n lineStyle: { color: utils.rgbaColor(utils.getColor('primary')) },\r\n itemStyle: {\r\n borderColor: utils.rgbaColor(utils.getColor('primary'), 0.6),\r\n borderWidth: 2\r\n }\r\n },\r\n {\r\n type: 'line',\r\n name: 'Revenue Date',\r\n data: [0, 10000, 24000, 35000, 45000, 53000, 57000, 68000, 79000],\r\n symbolSize: 5,\r\n symbol: 'circle',\r\n smooth: false,\r\n hoverAnimation: true,\r\n lineStyle: { color: utils.rgbaColor(utils.getColor('warning')) },\r\n itemStyle: {\r\n borderColor: utils.rgbaColor(utils.getColor('warning'), 0.6),\r\n borderWidth: 2\r\n }\r\n }\r\n ],\r\n grid: { right: '25px', left: '100px', bottom: '60px', top: '35px' }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default closedVsGoalInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Course Enrollment */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst courseEnrollmentsInit = () => {\r\n const $echartBarCourseEnrollments = document.querySelector(\r\n '.echart-bar-course-enrollments'\r\n );\r\n\r\n const data = [\r\n ['course', 'Free Course', 'Paid Course', 'On sale Course'],\r\n ['Sun', 4300, 8500, 5000],\r\n ['Mon', 8300, 7300, 4500],\r\n ['Tue', 8600, 6200, 3600],\r\n ['Wed', 7200, 5300, 4500],\r\n ['Thu', 8000, 5000, 2600],\r\n ['Fri', 5000, 7000, 8800],\r\n ['Sat', 8000, 9000, 6000],\r\n ];\r\n\r\n if ($echartBarCourseEnrollments) {\r\n const userOptions = utils.getData($echartBarCourseEnrollments, 'options');\r\n const chart = window.echarts.init($echartBarCourseEnrollments);\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.rgbaColor(utils.getColors().info, 0.6),\r\n utils.getColors().primary,\r\n utils.rgbaColor(utils.getColors().warning, 0.4),\r\n ],\r\n dataset: { source: data },\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays().primary,\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter: (params) =>\r\n `
    ${\r\n params.seriesName\r\n }
    ${params.name}: ${\r\n params.value[params.componentIndex + 1]\r\n }
    `,\r\n },\r\n legend: {\r\n data: ['Free Course', 'Paid Course', 'On sale Course'],\r\n left: 'left',\r\n itemWidth: 10,\r\n itemHeight: 10,\r\n borderRadius: 0,\r\n icon: 'circle',\r\n inactiveColor: utils.getGrays()['400'],\r\n textStyle: { color: utils.getGrays()['700'] },\r\n },\r\n xAxis: {\r\n type: 'category',\r\n axisLabel: { color: utils.getGrays()['400'] },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'line',\r\n },\r\n },\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n type: 'line',\r\n width: 0.5,\r\n },\r\n },\r\n axisTick: { show: false },\r\n boundaryGap: true,\r\n },\r\n yAxis: {\r\n axisPointer: { type: 'none' },\r\n axisTick: 'none',\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n type: 'dashed',\r\n },\r\n },\r\n axisLine: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['400'],\r\n formatter: (value) => `${Math.round((value / 1000) * 10) / 10}k`,\r\n },\r\n },\r\n series: [\r\n {\r\n type: 'bar',\r\n barWidth: '15%',\r\n barGap: '30%',\r\n label: { normal: { show: false } },\r\n z: 10,\r\n emphasis: {\r\n focus: 'series',\r\n },\r\n itemStyle: {\r\n normal: {\r\n barBorderRadius: [2, 2, 0, 0],\r\n },\r\n },\r\n },\r\n {\r\n type: 'bar',\r\n barWidth: '15%',\r\n barGap: '30%',\r\n label: { normal: { show: false } },\r\n z: 10,\r\n emphasis: {\r\n focus: 'series',\r\n },\r\n itemStyle: {\r\n normal: {\r\n barBorderRadius: [2, 2, 0, 0],\r\n },\r\n },\r\n },\r\n {\r\n type: 'bar',\r\n barWidth: '15%',\r\n barGap: '30%',\r\n label: { normal: { show: false } },\r\n z: 10,\r\n emphasis: {\r\n focus: 'series',\r\n },\r\n itemStyle: {\r\n normal: {\r\n barBorderRadius: [2, 2, 0, 0],\r\n },\r\n },\r\n },\r\n ],\r\n grid: {\r\n right: '1px',\r\n left: '30px',\r\n bottom: '10%',\r\n top: '20%',\r\n },\r\n });\r\n\r\n const initChart = () => {\r\n if (utils.isScrolledIntoView($echartBarCourseEnrollments)) {\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n window.removeEventListener('scroll', initChart);\r\n }\r\n };\r\n\r\n window.addEventListener('scroll', initChart);\r\n }\r\n};\r\n\r\nexport default courseEnrollmentsInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Pie Chart */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst courseStatusInit = () => {\r\n const $echartsCourseStatus = document.querySelector('.echart-course-status');\r\n\r\n const data = [\r\n {\r\n value: 13,\r\n name: 'Completed',\r\n itemStyle: {\r\n color: utils.getColor('primary'),\r\n },\r\n },\r\n {\r\n value: 20,\r\n name: 'On going',\r\n itemStyle: {\r\n color: utils.getColor('info'),\r\n },\r\n },\r\n {\r\n value: 10,\r\n name: 'Droped',\r\n itemStyle: {\r\n color: utils.getColor('warning'),\r\n },\r\n },\r\n {\r\n value: 7,\r\n name: 'Refunded',\r\n itemStyle: {\r\n color: utils.getColor('success'),\r\n },\r\n },\r\n ];\r\n\r\n if ($echartsCourseStatus) {\r\n const userOptions = utils.getData($echartsCourseStatus, 'options');\r\n const chart = window.echarts.init($echartsCourseStatus);\r\n\r\n const getDefaultOptions = () => ({\r\n legend: {\r\n show: false,\r\n },\r\n series: [\r\n {\r\n type: 'pie',\r\n radius: '70%',\r\n itemStyle: {\r\n borderWidth: 2,\r\n borderColor: utils.getColor('gray-100'),\r\n },\r\n label: {\r\n show: false,\r\n },\r\n center: ['50%', '50%'],\r\n data,\r\n },\r\n ],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n },\r\n });\r\n\r\n const initChart = () => {\r\n if (utils.isScrolledIntoView($echartsCourseStatus)) {\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n window.removeEventListener('scroll', initChart);\r\n }\r\n };\r\n\r\n window.addEventListener('scroll', initChart);\r\n }\r\n};\r\n\r\nexport default courseStatusInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Audience Chart */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst revenueChartInit = () => {\r\n const data = {\r\n dates: utils.getDates(\r\n new Date('5-6-2019'),\r\n new Date('5-6-2021'),\r\n 1000 * 60 * 60 * 24 * 30\r\n ),\r\n dataset: {\r\n revenue: [\r\n [\r\n 645, 500, 550, 550, 473, 405, 286, 601, 743, 450, 604, 815, 855, 722,\r\n 700, 896, 866, 952, 719, 558, 737, 885, 972, 650, 600,\r\n ],\r\n [\r\n 440, 250, 270, 400, 175, 180, 200, 400, 600, 380, 340, 550, 650, 450,\r\n 400, 688, 650, 721, 500, 300, 445, 680, 568, 400, 371,\r\n ],\r\n ],\r\n users: [\r\n [\r\n 545, 500, 650, 727, 773, 705, 686, 501, 643, 580, 604, 615, 755, 722,\r\n 727, 816, 836, 952, 719, 758, 937, 785, 872, 850, 800,\r\n ],\r\n [\r\n 340, 360, 230, 250, 410, 430, 450, 200, 220, 540, 500, 250, 355, 320,\r\n 500, 630, 680, 500, 520, 550, 750, 720, 700, 780, 750,\r\n ],\r\n ],\r\n deals: [\r\n [\r\n 545, 400, 450, 627, 473, 450, 460, 780, 770, 800, 504, 550, 500, 530,\r\n 727, 716, 736, 820, 719, 758, 737, 885, 872, 850, 800,\r\n ],\r\n [\r\n 245, 300, 450, 427, 273, 250, 260, 580, 570, 500, 402, 450, 400, 330,\r\n 527, 516, 536, 620, 519, 558, 537, 483, 472, 250, 300,\r\n ],\r\n ],\r\n profit: [\r\n [\r\n 545, 400, 450, 627, 673, 605, 686, 501, 843, 518, 504, 715, 955, 622,\r\n 627, 716, 736, 952, 619, 558, 937, 785, 872, 550, 400,\r\n ],\r\n [\r\n 340, 360, 330, 300, 410, 380, 450, 400, 420, 240, 200, 250, 355, 320,\r\n 500, 630, 680, 400, 420, 450, 650, 620, 700, 450, 340,\r\n ],\r\n ],\r\n },\r\n };\r\n\r\n const tooltipFormatter = params => {\r\n return `
    \r\n
    \r\n
    ${params[0].axisValue}
    \r\n
    \r\n
    \r\n
    \r\n Revenue: \r\n $${params[0].data}
    \r\n
    \r\n Revenue Goal: \r\n $${params[1].data}
    \r\n
    \r\n
    `;\r\n };\r\n\r\n const getDefaultOptions = (data1, data2) => () => ({\r\n color: utils.getGrays().white,\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: 0,\r\n backgroundColor: 'transparent',\r\n borderWidth: 0,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n formatter: tooltipFormatter,\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: utils.getPastDates(25).map(date => window.dayjs(date).format('DD MMM, YYYY')),\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: value => window.dayjs(value).format('MMM DD'),\r\n align: 'left',\r\n fontSize: 11,\r\n padding: [0, 0, 0, 5],\r\n showMaxLabel: false,\r\n },\r\n axisLine: {\r\n show: false,\r\n },\r\n axisTick: {\r\n show: false,\r\n },\r\n boundaryGap: true,\r\n },\r\n yAxis: {\r\n position: 'right',\r\n axisPointer: { type: 'none' },\r\n axisTick: 'none',\r\n splitLine: {\r\n show: false,\r\n },\r\n axisLine: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n },\r\n series: [\r\n {\r\n type: 'bar',\r\n name: 'Revenue',\r\n data: data1,\r\n lineStyle: {\r\n color: utils.getColor('primary'),\r\n },\r\n itemStyle: {\r\n barBorderRadius: [4, 4, 0, 0],\r\n color: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n borderWidth: 1,\r\n },\r\n emphasis: {\r\n itemStyle: {\r\n color: utils.getColor('primary'),\r\n },\r\n },\r\n },\r\n {\r\n type: 'line',\r\n name: 'Revenue Goal',\r\n data: data2,\r\n symbol: 'circle',\r\n symbolSize: 6,\r\n animation: false,\r\n itemStyle: {\r\n color: utils.getColor('warning'),\r\n },\r\n lineStyle: {\r\n type: 'dashed',\r\n width: 2,\r\n color: utils.getColor('warning'),\r\n },\r\n },\r\n ],\r\n grid: { right: 5, left: 5, bottom: '8%', top: '5%' },\r\n });\r\n const initChart = (el, options) => {\r\n const userOptions = utils.getData(el, 'options');\r\n const chart = window.echarts.init(el);\r\n echartSetOption(chart, userOptions, options);\r\n };\r\n const chartKeys = ['revenue', 'users', 'deals', 'profit'];\r\n chartKeys.forEach(key => {\r\n const el = document.querySelector(`.echart-crm-${key}`);\r\n el && \r\n initChart(\r\n el, \r\n getDefaultOptions(data.dataset[key][0], data.dataset[key][1])\r\n );\r\n });\r\n};\r\n\r\nexport default revenueChartInit;","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n\r\nconst echartsCustomerSatisfactionInit = () => {\r\n const $echartCustomerSatisfaction = document.querySelector('.echart-customer-setisfaction');\r\n\r\n if ($echartCustomerSatisfaction) {\r\n // Get options from data attribute\r\n const userOptions = utils.getData($echartCustomerSatisfaction, 'options');\r\n const chart = window.echarts.init($echartCustomerSatisfaction);\r\n\r\n const getDefaultOptions = () => ({\r\n legend: {\r\n left: 'center',\r\n bottom: 22,\r\n itemWidth: 12,\r\n itemHeight: 12,\r\n borderRadius: 0,\r\n icon: 'circle',\r\n inactiveColor: utils.getGrays()['400'],\r\n inactiveBorderColor: \"transparent\",\r\n textStyle: {\r\n color: utils.getGrays()['600'],\r\n fontSize: 12,\r\n fontFamily: \"Poppins\",\r\n fontWeight: \"500\"\r\n },\r\n itemGap: 16,\r\n },\r\n series: [\r\n {\r\n type: 'pie',\r\n radius: '70%',\r\n label: {\r\n show: false\r\n },\r\n center: ['50%', '45%'],\r\n itemStyle: {\r\n borderWidth: 2,\r\n borderColor: localStorage.getItem('theme') === 'dark' ? '#121E2D' : utils.getGrays()['100'],\r\n },\r\n data: [\r\n {\r\n value: 1100,\r\n name: 'Positive',\r\n itemStyle: {\r\n color: utils.getColor('primary')\r\n }\r\n },\r\n {\r\n value: 550,\r\n name: 'Nagative',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('primary'), 0.50),\r\n }\r\n }\r\n ],\r\n }\r\n ],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n axisPointer: {\r\n type: 'none'\r\n }\r\n },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n \r\n }\r\n};\r\n\r\nexport default echartsCustomerSatisfactionInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Bounce Rate */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst dealStorageFunnelInit = () => {\r\n const $echartDealStorageFunnel = document.querySelector('.echart-deal-storage-funnel');\r\n \r\n if ($echartDealStorageFunnel) {\r\n const userOptions = utils.getData($echartDealStorageFunnel, 'options');\r\n const { data, dataAxis1, dataAxis2 } = userOptions; \r\n const chart = window.echarts.init($echartDealStorageFunnel);\r\n\r\n const getDefaultOptions = () => ({\r\n yAxis: [\r\n {\r\n data: dataAxis1,\r\n axisLabel: {\r\n inside: true,\r\n textStyle: {\r\n color: utils.getGrays()['700'],\r\n fontWeight: 500,\r\n fontSize: 11,\r\n fontFamily: 'poppins',\r\n }, \r\n },\r\n axisTick: {\r\n show: false\r\n },\r\n axisLine: {\r\n show: false\r\n },\r\n z: 10\r\n },\r\n {\r\n data: dataAxis2,\r\n axisLabel: {\r\n inside: false,\r\n textStyle: {\r\n color: utils.getColors().primary,\r\n fontWeight: 500,\r\n fontSize: 11,\r\n fontFamily: 'poppins',\r\n \r\n },\r\n borderRadius: 5,\r\n backgroundColor: utils.getSubtleColors().primary,\r\n padding: [6,16,6,16],\r\n width: 115\r\n },\r\n axisTick: {\r\n show: false\r\n },\r\n axisLine: {\r\n show: false\r\n },\r\n z: 10\r\n },\r\n ],\r\n xAxis: {\r\n type: 'value',\r\n min: 0,\r\n max: 35,\r\n axisLine: {\r\n show: false\r\n },\r\n splitLine: {\r\n show: false\r\n },\r\n inverse: true,\r\n axisTick: {\r\n show: false\r\n },\r\n axisLabel: {\r\n show: false,\r\n }\r\n },\r\n\r\n series: [\r\n {\r\n type: 'bar',\r\n showBackground: true,\r\n barWidth: 25,\r\n label: {\r\n show: true,\r\n formatter: '{c} ',\r\n position: 'insideLeft',\r\n },\r\n backgroundStyle: {\r\n color: utils.getGrays()['200'],\r\n borderRadius: 5\r\n },\r\n itemStyle: {\r\n color: utils.getColors().primary,\r\n borderRadius: 5 \r\n },\r\n data: data\r\n }\r\n ],\r\n grid: { right: '65px', left: '0', bottom: '0', top: '0' },\r\n });\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n }\r\n};\r\n\r\nexport default dealStorageFunnelInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n\r\nconst echartsDistributionOfPerformanceInit = () => {\r\n const $distributionOfPerformance = document.querySelector('.echart-distribution-of-performance');\r\n\r\n if ($distributionOfPerformance) {\r\n const userOptions = utils.getData($distributionOfPerformance, 'options');\r\n const chart = window.echarts.init($distributionOfPerformance);\r\n\r\n let xAxisData = [\"Mar 01\", \"Mar 02\", \"Mar 03\", \"Mar 04\", \"Mar 05\", \"Mar 06\", \"Mar 07\", \"Mar 08\", \"Mar 09\", \"Mar 10\", \"Mar 11\", \"Mar 12\"];\r\n let data1 = [50, 25, 35, 30, 45, 35, 38, 30, 35, 30, 35, 38];\r\n let data2 = [45, 50, 40, 35, 50, 40, 44, 35, 40, 45, 40, 44];\r\n\r\n const emphasisStyle = {\r\n itemStyle: {\r\n shadowColor: utils.rgbaColor(utils.getColor('dark'), 0.3)\r\n }\r\n };\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColor('primary'),\r\n localStorage.getItem('theme') === 'dark' ? '#236EA1' : '#7DD7FE',\r\n ],\r\n legend: {\r\n data: ['Agent Support', 'Group Support'],\r\n icon: 'circle',\r\n itemWidth: 10,\r\n itemHeight: 10,\r\n padding: [0, 0, 0, 0],\r\n textStyle: {\r\n color: utils.getGrays()['700'],\r\n fontWeight: \"500\",\r\n fontSize: \"13px\"\r\n },\r\n left: 0,\r\n itemGap: 16,\r\n },\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getGrays()['900']},\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n axisPointer: {\r\n type: 'none'\r\n },\r\n \r\n },\r\n xAxis: {\r\n data: xAxisData,\r\n splitLine: { show: false, },\r\n splitArea: { show: false, },\r\n\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n },\r\n\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n }\r\n },\r\n axisTick: {\r\n show: false,\r\n }\r\n },\r\n yAxis: {\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: \"dashed\"\r\n }\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600']\r\n },\r\n },\r\n series: [\r\n {\r\n name: 'Agent Support',\r\n type: 'bar',\r\n stack: 'one',\r\n emphasis: emphasisStyle,\r\n data: data1\r\n },\r\n {\r\n name: 'Group Support',\r\n type: 'bar',\r\n stack: 'one',\r\n emphasis: emphasisStyle,\r\n data: data2,\r\n itemStyle: {\r\n barBorderRadius: [3, 3, 0, 0]\r\n }\r\n },\r\n ],\r\n barWidth: \"15px\",\r\n grid: {\r\n top: '15%',\r\n bottom: 0,\r\n left: 0,\r\n right: 0,\r\n containLabel: true\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default echartsDistributionOfPerformanceInit;\r\n","/* eslint-disable */\r\nconst getPosition = (pos, params, dom, rect, size) => ({\r\n top: pos[1] - size.contentSize[1] - 10,\r\n left: pos[0] - size.contentSize[0] / 2\r\n});\r\n\r\nconst echartSetOption = (chart, userOptions, getDefaultOptions) => {\r\n const themeController = document.body;\r\n // Merge user options with lodash\r\n chart.setOption(window._.merge(getDefaultOptions(), userOptions));\r\n\r\n themeController.addEventListener('clickControl', ({ detail: { control } }) => {\r\n if (control === 'theme') {\r\n chart.setOption(window._.merge(getDefaultOptions(), userOptions));\r\n }\r\n });\r\n};\r\n\r\nconst tooltipFormatter = params => {\r\n let tooltipItem = ``;\r\n params.forEach(el => {\r\n tooltipItem =\r\n tooltipItem +\r\n `
    \r\n
    \r\n ${el.seriesName} : ${typeof el.value === 'object' ? el.value[1] : el.value}\r\n
    \r\n
    `;\r\n });\r\n return `
    \r\n

    \r\n ${window.dayjs(params[0].axisValue).isValid()\r\n ? window.dayjs(params[0].axisValue).format('MMMM DD')\r\n : params[0].axisValue\r\n }\r\n

    \r\n ${tooltipItem}\r\n
    `;\r\n};\r\n\r\nexport default { getPosition, echartSetOption, tooltipFormatter };\r\n","import utils from '../../utils';\r\n\r\nconst resizeEcharts = () => {\r\n const $echarts = document.querySelectorAll('[data-echart-responsive]');\r\n if (!!$echarts.length) {\r\n $echarts.forEach(item => {\r\n if (!!utils.getData(item, 'echart-responsive')) {\r\n if (\r\n !(\r\n item.closest('.tab-pane') &&\r\n window.getComputedStyle(item.closest('.tab-pane')).display === 'none'\r\n )\r\n ) {\r\n window.echarts.init(item).resize();\r\n }\r\n }\r\n });\r\n }\r\n};\r\n\r\nutils.resize(() => resizeEcharts());\r\n\r\nconst navbarVerticalToggle = document.querySelector('.navbar-vertical-toggle');\r\nnavbarVerticalToggle &&\r\n navbarVerticalToggle.addEventListener('navbar.vertical.toggle', () => resizeEcharts());\r\n\r\nconst echartTabs = document.querySelectorAll('[data-tab-has-echarts]');\r\nechartTabs &&\r\n echartTabs.forEach(tab => {\r\n tab.addEventListener('shown.bs.tab', e => {\r\n const el = e.target;\r\n const { hash } = el;\r\n const id = hash ? hash : el.dataset.bsTarget;\r\n const content = document.getElementById(id.substring(1));\r\n const chart = content?.querySelector('[data-echart-tab]');\r\n chart && window.echarts.init(chart).resize();\r\n });\r\n });\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Gross Revenue */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst grossRevenueChartInit = () => {\r\n const ECHART_GROSS_REVENUE = '.echart-gross-revenue-chart';\r\n\r\n const $echartsGrossRevenue = document.querySelector(ECHART_GROSS_REVENUE);\r\n\r\n const months = [\r\n 'Jan',\r\n 'Feb',\r\n 'Mar',\r\n 'Apr',\r\n 'May',\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\r\n if ($echartsGrossRevenue) {\r\n // Get options from data attribute\r\n const userOptions = utils.getData($echartsGrossRevenue, 'options');\r\n const chart = window.echarts.init($echartsGrossRevenue);\r\n\r\n\r\n const SELECT_MONTH = `#${userOptions.monthSelect}`;\r\n const LEGEND_MONTH_TARGET = userOptions.target;\r\n const LEGEND_CURRENT_MONTH = `#${userOptions.optionOne}`;\r\n const LEGEND_PREV_MONTH = `#${userOptions.optionTwo}`;\r\n\r\n const $legendCurrentMonth = document\r\n .getElementById(LEGEND_MONTH_TARGET)\r\n .querySelector(LEGEND_CURRENT_MONTH);\r\n const $legendPrevMonth = document\r\n .getElementById(LEGEND_MONTH_TARGET)\r\n .querySelector(LEGEND_PREV_MONTH);\r\n\r\n const dates = month => {\r\n return utils.getDates(\r\n window.dayjs().month(month).date(1), \r\n window.dayjs().month(Number(month) + 1).date(0),\r\n 1000 * 60 * 60 * 24 * 3\r\n );\r\n }\r\n\r\n const monthsnumber = [\r\n [20, 40, 20, 80, 50, 80, 120, 80, 50, 120, 110, 110],\r\n [60, 80, 60, 80, 65, 130, 120, 100, 30, 40, 30, 70],\r\n [100, 70, 80, 50, 120, 100, 130, 140, 90, 100, 40, 50],\r\n [80, 50, 60, 40, 60, 120, 100, 130, 60, 80, 50, 60],\r\n [70, 80, 100, 70, 90, 60, 80, 130, 40, 60, 50, 80],\r\n [90, 40, 80, 80, 100, 140, 100, 130, 90, 60, 70, 50],\r\n [80, 60, 80, 60, 40, 100, 120, 100, 30, 40, 30, 70],\r\n [20, 40, 20, 50, 70, 60, 110, 80, 90, 30, 50, 50],\r\n [60, 70, 30, 40, 80, 140, 80, 140, 120, 130, 100, 110],\r\n [90, 90, 40, 60, 40, 110, 90, 110, 60, 80, 60, 70],\r\n [50, 80, 50, 80, 50, 80, 120, 80, 50, 120, 110, 110],\r\n [60, 90, 60, 70, 40, 70, 100, 140, 30, 40, 30, 70],\r\n [20, 40, 20, 50, 30, 80, 120, 100, 30, 40, 30, 70],\r\n ];\r\n\r\n const tooltipFormatter = params => {\r\n const currentDate = window.dayjs(params[0].axisValue);\r\n let tooltipItem = ``\r\n params.forEach(el => {\r\n tooltipItem = tooltipItem +`
    \r\n ${currentDate.format('MMM DD')} : ${el.value}\r\n
    `\r\n });\r\n return `
    \r\n ${tooltipItem}\r\n
    `;\r\n };\r\n const getDefaultOptions = () => ({\r\n title: {\r\n text: 'Sales over time',\r\n textStyle: {\r\n fontWeight: 500,\r\n fontSize: 13,\r\n fontFamily: 'poppins',\r\n },\r\n },\r\n legend: {\r\n show: false,\r\n data: ['currentMonth', 'prevMonth'],\r\n },\r\n color: utils.getGrays().white,\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n formatter: tooltipFormatter,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: dates(0),\r\n boundaryGap: false,\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed',\r\n },\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'solid',\r\n },\r\n },\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getGrays()['400'],\r\n formatter: function (value) {\r\n var date = new Date(value);\r\n return `${months[date.getMonth()].substring(\r\n 0,\r\n 3\r\n )} ${date.getDate()}`;\r\n },\r\n margin: 15,\r\n },\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed',\r\n },\r\n },\r\n },\r\n yAxis: {\r\n type: 'value',\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n },\r\n },\r\n boundaryGap: false,\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()['400'],\r\n margin: 15,\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false },\r\n },\r\n series: [\r\n {\r\n name: 'prevMonth',\r\n type: 'line',\r\n data: monthsnumber[0],\r\n lineStyle: { color: utils.getGrays()['300'] },\r\n itemStyle: {\r\n borderColor: utils.getGrays()['300'],\r\n borderWidth: 2,\r\n },\r\n symbol: 'none',\r\n smooth: false,\r\n hoverAnimation: true,\r\n },\r\n {\r\n name: 'currentMonth',\r\n type: 'line',\r\n data: monthsnumber[1],\r\n lineStyle: { color: utils.getColors().primary },\r\n itemStyle: {\r\n borderColor: utils.getColors().primary,\r\n borderWidth: 2,\r\n },\r\n symbol: 'none',\r\n smooth: false,\r\n hoverAnimation: true,\r\n },\r\n ],\r\n grid: { right: '8px', left: '40px', bottom: '15%', top: '20%' },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n // Change chart options accordiong to the selected month\r\n const monthSelect = document.querySelector(SELECT_MONTH);\r\n\r\n let month = 0;\r\n let currentMonthData = monthsnumber[Number(month) + 1];\r\n let prevMonthData = monthsnumber[monthSelect.selectedIndex];\r\n\r\n monthSelect.addEventListener('change', (e) => {\r\n month = e.currentTarget.value;\r\n currentMonthData = monthsnumber[Number(month) + 1];\r\n prevMonthData = monthsnumber[month];\r\n\r\n $legendCurrentMonth.querySelector('.text').innerText = months[month];\r\n $legendPrevMonth.querySelector('.text').innerText = months[month - 1]\r\n ? months[month - 1]\r\n : 'Dec';\r\n\r\n chart.setOption({\r\n xAxis: {\r\n data: dates(month)\r\n },\r\n series: [\r\n {\r\n data: currentMonthData,\r\n },\r\n {\r\n data: prevMonthData,\r\n },\r\n ],\r\n });\r\n });\r\n\r\n $legendCurrentMonth.addEventListener('click', () => {\r\n $legendCurrentMonth.classList.toggle('opacity-50');\r\n\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'currentMonth',\r\n });\r\n });\r\n\r\n $legendPrevMonth.addEventListener('click', () => {\r\n $legendPrevMonth.classList.toggle('opacity-50');\r\n\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'prevMonth',\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default grossRevenueChartInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption, tooltipFormatter } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Traffic Channels */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst leadConversionInit = () => {\r\n const $leadConversion = document.querySelector('.echart-lead-conversion');\r\n\r\n if ($leadConversion) {\r\n const userOptions = utils.getData($leadConversion, 'options');\r\n const chart = window.echarts.init($leadConversion);\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.rgbaColor(utils.getColors().primary, 0.7),\r\n utils.rgbaColor(utils.getColors().info, 0.6),\r\n utils.rgbaColor(utils.getColors().secondary, 0.2),\r\n utils.rgbaColor(utils.getColors().warning, 0.6)\r\n ],\r\n legend: {\r\n data: ['Campaigns', 'Lead', 'Opportunity', 'Deal'],\r\n left: '0%',\r\n icon: 'circle',\r\n inactiveColor: utils.getGrays()['400'],\r\n textStyle: { color: utils.getGrays()['700'] },\r\n itemGap: 10\r\n },\r\n yAxis: {\r\n type: 'category',\r\n data: [\r\n 'kerry Ingram',\r\n 'Bradie Pitter',\r\n 'Harrington',\r\n 'Ashley Shaw',\r\n 'Jenny Horas',\r\n 'Chris Pratt'\r\n ],\r\n axisLine: {\r\n show: false,\r\n },\r\n boundaryGap: false,\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200']\r\n }\r\n },\r\n axisTick: {\r\n show: false\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600']\r\n }\r\n },\r\n xAxis: {\r\n type: 'value',\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200']\r\n }\r\n },\r\n axisLine: {\r\n show: false\r\n },\r\n axisTick: {\r\n show: false\r\n },\r\n axisLabel: {\r\n show: false\r\n }\r\n },\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7,10],\r\n axisPointer: {\r\n type: 'none'\r\n },\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n formatter: tooltipFormatter\r\n },\r\n\r\n series: [\r\n {\r\n name: 'Campaigns',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [1405, 1300, 1620, 1430, 1500, 1520],\r\n barWidth: '20%'\r\n },\r\n {\r\n name: 'Lead',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [320, 302, 301, 334, 340, 390],\r\n barWidth: '20%'\r\n },\r\n {\r\n name: 'Opportunity',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [220, 182, 351, 234, 290, 300],\r\n barWidth: '20%'\r\n },\r\n {\r\n name: 'Deal',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [120, 182, 191, 134, 190, 170],\r\n barWidth: '20%'\r\n }\r\n ],\r\n grid: {\r\n right: 5,\r\n left: 5,\r\n bottom: 8,\r\n top: 60,\r\n containLabel: true\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default leadConversionInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Line Payment */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst linePaymentChartInit = () => {\r\n const $echartsLinePaymentChart = document.querySelector(\r\n '.echart-line-payment'\r\n );\r\n\r\n const dataset = {\r\n all: [4, 1, 6, 2, 7, 12, 4, 6, 5, 4, 5, 10],\r\n successful: [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5, 8],\r\n failed: [1, 0, 2, 1, 2, 1, 1, 0, 0, 1, 0, 2],\r\n };\r\n const labels = [\r\n '9:00 AM',\r\n '10:00 AM',\r\n '11:00 AM',\r\n '12:00 PM',\r\n '1:00 PM',\r\n '2:00 PM',\r\n '3:00 PM',\r\n '4:00 PM',\r\n '5:00 PM',\r\n '6:00 PM',\r\n '7:00 PM',\r\n '8:00 PM',\r\n ];\r\n\r\n if ($echartsLinePaymentChart) {\r\n const userOptions = utils.getData($echartsLinePaymentChart, 'options');\r\n const chart = window.echarts.init($echartsLinePaymentChart);\r\n\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: 'axis',\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter: params => `${params[0].axisValue} - ${params[0].value} USD`,\r\n textStyle: {\r\n fontWeight: 500,\r\n fontSize: 12,\r\n color: utils.getColors().dark,\r\n },\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: labels,\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: utils.rgbaColor('#fff', 0.1),\r\n },\r\n interval: 0,\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.rgbaColor('#fff', 0.1),\r\n },\r\n },\r\n axisTick: {\r\n show: true,\r\n length: 10,\r\n lineStyle: {\r\n color: utils.rgbaColor('#fff', 0.1),\r\n },\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['400'],\r\n fontWeight: 600,\r\n formatter: value => value.substring(0, value.length - 3),\r\n fontSize: 12,\r\n interval: window.innerWidth < 768 ? 'auto' : 0,\r\n margin: 15,\r\n },\r\n boundaryGap: false,\r\n },\r\n yAxis: {\r\n type: 'value',\r\n axisPointer: { show: false },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false },\r\n },\r\n series: [\r\n {\r\n type: 'line',\r\n smooth: true,\r\n data: dataset.successful.map(d => (d * 3.14).toFixed(2)),\r\n symbol: 'emptyCircle',\r\n itemStyle: {\r\n color:\r\n localStorage.getItem('theme') === 'light'\r\n ? utils.getGrays()['white']\r\n : utils.getColors().primary,\r\n },\r\n lineStyle: {\r\n color:\r\n localStorage.getItem('theme') === 'light'\r\n ? utils.rgbaColor(utils.getGrays()['white'], 0.8)\r\n : utils.getColors().primary,\r\n },\r\n areaStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 0,\r\n y2: 1,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color:\r\n localStorage.getItem('theme') === 'light'\r\n ? 'rgba(255, 255, 255, 0.5)'\r\n : utils.rgbaColor(utils.getColors().primary, 0.5),\r\n },\r\n {\r\n offset: 1,\r\n color:\r\n localStorage.getItem('theme') === 'light'\r\n ? 'rgba(255, 255, 255, 0)'\r\n : utils.rgbaColor(utils.getColors().primary, 0),\r\n },\r\n ],\r\n },\r\n },\r\n emphasis: {\r\n lineStyle: {\r\n width: 2,\r\n },\r\n },\r\n },\r\n ],\r\n grid: { right: 15, left: 15, bottom: '15%', top: 0 },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n utils.resize(() => {\r\n if (window.innerWidth < 768) {\r\n chart.setOption({\r\n xAxis: {\r\n axisLabel: {\r\n interval: 'auto',\r\n },\r\n },\r\n });\r\n }\r\n });\r\n\r\n const selectMenu = document.querySelector('#dashboard-chart-select');\r\n\r\n if (selectMenu) {\r\n selectMenu.addEventListener('change', e => {\r\n const value = e.currentTarget.value;\r\n chart.setOption({\r\n series: [{ data: dataset[value].map(d => (d * 3.14).toFixed(2)) }],\r\n });\r\n });\r\n }\r\n }\r\n};\r\n\r\nexport default linePaymentChartInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Session By Country Map */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst locationBySessionInit = () => {\r\n const $locationBySessionMap = document.querySelector('.echart-location-by-session-map');\r\n\r\n const data = [\r\n { name: 'Afghanistan', value: 28397.812 },\r\n { name: 'Angola', value: 19549.124 },\r\n { name: 'Albania', value: 3150.143 },\r\n { name: 'United Arab Emirates', value: 8441.537 },\r\n { name: 'Argentina', value: 40374.224 },\r\n { name: 'Armenia', value: 2963.496 },\r\n { name: 'French Southern and Antarctic Lands', value: 268.065 },\r\n { name: 'Australia', value: 22404.488 },\r\n { name: 'Austria', value: 8401.924 },\r\n { name: 'Azerbaijan', value: 9094.718 },\r\n { name: 'Burundi', value: 9232.753 },\r\n { name: 'Belgium', value: 10941.288 },\r\n { name: 'Benin', value: 9509.798 },\r\n { name: 'Burkina Faso', value: 15540.284 },\r\n { name: 'Bangladesh', value: 151125.475 },\r\n { name: 'Bulgaria', value: 7389.175 },\r\n { name: 'The Bahamas', value: 66402.316 },\r\n { name: 'Bosnia and Herzegovina', value: 3845.929 },\r\n { name: 'Belarus', value: 9491.07 },\r\n { name: 'Belize', value: 308.595 },\r\n { name: 'Bermuda', value: 64.951 },\r\n { name: 'Bolivia', value: 716.939 },\r\n { name: 'Brazil', value: 195210.154 },\r\n { name: 'Brunei', value: 27.223 },\r\n { name: 'Bhutan', value: 716.939 },\r\n { name: 'Botswana', value: 1969.341 },\r\n { name: 'Central African Rep.', value: 4349.921 },\r\n { name: 'Canada', value: 34126.24 },\r\n { name: 'Switzerland', value: 7830.534 },\r\n { name: 'Chile', value: 17150.76 },\r\n { name: 'China', value: 1359821.465 },\r\n { name: \"Côte d'Ivoire\", value: 60508.978 },\r\n { name: 'Cameroon', value: 20624.343 },\r\n { name: 'Dem. Rep. Congo', value: 62191.161 },\r\n { name: 'Congo', value: 3573.024 },\r\n { name: 'Colombia', value: 46444.798 },\r\n { name: 'Costa Rica', value: 4669.685 },\r\n { name: 'Cuba', value: 11281.768 },\r\n { name: 'Northern Cyprus', value: 1.468 },\r\n { name: 'Cyprus', value: 1103.685 },\r\n { name: 'Czech Republic', value: 10553.701 },\r\n { name: 'Germany', value: 83017.404 },\r\n { name: 'Djibouti', value: 834.036 },\r\n { name: 'Denmark', value: 5550.959 },\r\n { name: 'Dominican Republic', value: 10016.797 },\r\n { name: 'Algeria', value: 37062.82 },\r\n { name: 'Ecuador', value: 15001.072 },\r\n { name: 'Egypt', value: 78075.705 },\r\n { name: 'Eritrea', value: 5741.159 },\r\n { name: 'Spain', value: 46182.038 },\r\n { name: 'Estonia', value: 1298.533 },\r\n { name: 'Ethiopia', value: 87095.281 },\r\n { name: 'Finland', value: 5367.693 },\r\n { name: 'Fiji', value: 860.559 },\r\n { name: 'Falkland Islands', value: 49.581 },\r\n { name: 'France', value: 63230.866 },\r\n { name: 'Gabon', value: 1556.222 },\r\n { name: 'United Kingdom', value: 62066.35 },\r\n { name: 'Georgia', value: 4388.674 },\r\n { name: 'Ghana', value: 24262.901 },\r\n { name: 'Eq. Guinea', value: 10876.033 },\r\n { name: 'Guinea', value: 10876.033 },\r\n { name: 'Gambia', value: 1680.64 },\r\n { name: 'Guinea Bissau', value: 10876.033 },\r\n { name: 'Equatorial Guinea', value: 696.167 },\r\n { name: 'Greece', value: 11109.999 },\r\n { name: 'Greenland', value: 56.546 },\r\n { name: 'Guatemala', value: 14341.576 },\r\n { name: 'French Guiana', value: 231.169 },\r\n { name: 'Guyana', value: 786.126 },\r\n { name: 'Honduras', value: 7621.204 },\r\n { name: 'Croatia', value: 4338.027 },\r\n { name: 'Haiti', value: 9896.4 },\r\n { name: 'Hungary', value: 10014.633 },\r\n { name: 'Indonesia', value: 240676.485 },\r\n { name: 'India', value: 1205624.648 },\r\n { name: 'Ireland', value: 4467.561 },\r\n { name: 'Iran', value: 240676.485 },\r\n { name: 'Iraq', value: 30962.38 },\r\n { name: 'Iceland', value: 318.042 },\r\n { name: 'Israel', value: 7420.368 },\r\n { name: 'Italy', value: 60508.978 },\r\n { name: 'Jamaica', value: 2741.485 },\r\n { name: 'Jordan', value: 6454.554 },\r\n { name: 'Japan', value: 127352.833 },\r\n { name: 'Kazakhstan', value: 15921.127 },\r\n { name: 'Kenya', value: 40909.194 },\r\n { name: 'Kyrgyzstan', value: 5334.223 },\r\n { name: 'Cambodia', value: 14364.931 },\r\n { name: 'South Korea', value: 51452.352 },\r\n { name: 'Kosovo', value: 97.743 },\r\n { name: 'Kuwait', value: 2991.58 },\r\n { name: 'Laos', value: 6395.713 },\r\n { name: 'Lebanon', value: 4341.092 },\r\n { name: 'Liberia', value: 3957.99 },\r\n { name: 'Libya', value: 6040.612 },\r\n { name: 'Sri Lanka', value: 20758.779 },\r\n { name: 'Lesotho', value: 2008.921 },\r\n { name: 'Lithuania', value: 3068.457 },\r\n { name: 'Luxembourg', value: 507.885 },\r\n { name: 'Latvia', value: 2090.519 },\r\n { name: 'Morocco', value: 31642.36 },\r\n { name: 'Moldova', value: 103.619 },\r\n { name: 'Madagascar', value: 21079.532 },\r\n { name: 'Mexico', value: 117886.404 },\r\n { name: 'Macedonia', value: 507.885 },\r\n { name: 'Mali', value: 13985.961 },\r\n { name: 'Myanmar', value: 51931.231 },\r\n { name: 'Montenegro', value: 620.078 },\r\n { name: 'Mongolia', value: 2712.738 },\r\n { name: 'Mozambique', value: 23967.265 },\r\n { name: 'Mauritania', value: 3609.42 },\r\n { name: 'Malawi', value: 15013.694 },\r\n { name: 'Malaysia', value: 28275.835 },\r\n { name: 'Namibia', value: 2178.967 },\r\n { name: 'New Caledonia', value: 246.379 },\r\n { name: 'Niger', value: 15893.746 },\r\n { name: 'Nigeria', value: 159707.78 },\r\n { name: 'Nicaragua', value: 5822.209 },\r\n { name: 'Netherlands', value: 16615.243 },\r\n { name: 'Norway', value: 4891.251 },\r\n { name: 'Nepal', value: 26846.016 },\r\n { name: 'New Zealand', value: 4368.136 },\r\n { name: 'Oman', value: 2802.768 },\r\n { name: 'Pakistan', value: 173149.306 },\r\n { name: 'Panama', value: 3678.128 },\r\n { name: 'Peru', value: 29262.83 },\r\n { name: 'Philippines', value: 93444.322 },\r\n { name: 'Papua New Guinea', value: 6858.945 },\r\n { name: 'Poland', value: 38198.754 },\r\n { name: 'Puerto Rico', value: 3709.671 },\r\n { name: 'North Korea', value: 1.468 },\r\n { name: 'Portugal', value: 10589.792 },\r\n { name: 'Paraguay', value: 6459.721 },\r\n { name: 'Qatar', value: 1749.713 },\r\n { name: 'Romania', value: 21861.476 },\r\n { name: 'Russia', value: 21861.476 },\r\n { name: 'Rwanda', value: 10836.732 },\r\n { name: 'Western Sahara', value: 514.648 },\r\n { name: 'Saudi Arabia', value: 27258.387 },\r\n { name: 'Sudan', value: 35652.002 },\r\n { name: 'S. Sudan', value: 9940.929 },\r\n { name: 'Senegal', value: 12950.564 },\r\n { name: 'Solomon Islands', value: 526.447 },\r\n { name: 'Sierra Leone', value: 5751.976 },\r\n { name: 'El Salvador', value: 6218.195 },\r\n { name: 'Somaliland', value: 9636.173 },\r\n { name: 'Somalia', value: 9636.173 },\r\n { name: 'Republic of Serbia', value: 3573.024 },\r\n { name: 'Suriname', value: 524.96 },\r\n { name: 'Slovakia', value: 5433.437 },\r\n { name: 'Slovenia', value: 2054.232 },\r\n { name: 'Sweden', value: 9382.297 },\r\n { name: 'Swaziland', value: 1193.148 },\r\n { name: 'Syria', value: 7830.534 },\r\n { name: 'Chad', value: 11720.781 },\r\n { name: 'Togo', value: 6306.014 },\r\n { name: 'Thailand', value: 66402.316 },\r\n { name: 'Tajikistan', value: 7627.326 },\r\n { name: 'Turkmenistan', value: 5041.995 },\r\n { name: 'East Timor', value: 10016.797 },\r\n { name: 'Trinidad and Tobago', value: 1328.095 },\r\n { name: 'Tunisia', value: 10631.83 },\r\n { name: 'Turkey', value: 72137.546 },\r\n { name: 'Tanzania', value: 44973.33 },\r\n { name: 'Uganda', value: 33987.213 },\r\n { name: 'Ukraine', value: 46050.22 },\r\n { name: 'Uruguay', value: 3371.982 },\r\n { name: 'United States', value: 312247.116 },\r\n { name: 'Uzbekistan', value: 27769.27 },\r\n { name: 'Venezuela', value: 236.299 },\r\n { name: 'Vietnam', value: 89047.397 },\r\n { name: 'Vanuatu', value: 236.299 },\r\n { name: 'West Bank', value: 13.565 },\r\n { name: 'Yemen', value: 22763.008 },\r\n { name: 'South Africa', value: 51452.352 },\r\n { name: 'Zambia', value: 13216.985 },\r\n { name: 'Zimbabwe', value: 13076.978 }\r\n ];\r\n\r\n const total = 6961500;\r\n\r\n const maxZoomLevel = 5;\r\n const minZoomLevel = 1;\r\n\r\n if ($locationBySessionMap) {\r\n const userOptions = utils.getData($locationBySessionMap, 'options');\r\n const chart = window.echarts.init($locationBySessionMap);\r\n\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter: params =>\r\n `${params.data?.name} : ${((params.data?.value / total) * 100).toFixed(\r\n 2\r\n )}%`\r\n },\r\n\r\n visualMap: {\r\n show: false,\r\n min: 800,\r\n max: 50000,\r\n inRange: {\r\n color: [\r\n utils.getColors().primary,\r\n utils.rgbaColor(utils.getColors().primary, 0.8),\r\n utils.rgbaColor(utils.getColors().primary, 0.6),\r\n utils.rgbaColor(utils.getColors().primary, 0.4),\r\n utils.rgbaColor(utils.getColors().primary, 0.2)\r\n ].reverse()\r\n }\r\n },\r\n series: [\r\n {\r\n type: 'map',\r\n map: 'world',\r\n data,\r\n roam: 'move',\r\n\r\n scaleLimit: {\r\n min: minZoomLevel,\r\n max: maxZoomLevel\r\n },\r\n left: 0,\r\n right: 0,\r\n label: {\r\n show: false\r\n },\r\n itemStyle: {\r\n borderColor: utils.getGrays()['300']\r\n },\r\n emphasis: {\r\n label: {\r\n show: false\r\n },\r\n itemStyle: {\r\n areaColor: utils.getColor('warning')\r\n }\r\n }\r\n }\r\n ]\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n let zoomLevel = 1;\r\n\r\n document.querySelector('.location-by-session-map-reset')?.addEventListener('click', () => {\r\n zoomLevel = 1;\r\n chart.dispatchAction({\r\n type: 'restore'\r\n });\r\n chart.setOption({\r\n series: {\r\n zoom: 1\r\n }\r\n });\r\n });\r\n\r\n document.querySelector('.location-by-session-map-zoom')?.addEventListener('click', () => {\r\n if (zoomLevel < maxZoomLevel) {\r\n zoomLevel += 1;\r\n }\r\n chart.setOption({\r\n series: {\r\n zoom: zoomLevel\r\n }\r\n });\r\n });\r\n\r\n document.querySelector('.location-by-session-map-zoomOut')?.addEventListener('click', () => {\r\n if (zoomLevel > minZoomLevel) {\r\n zoomLevel -= 1;\r\n }\r\n chart.setOption({\r\n series: {\r\n zoom: zoomLevel\r\n }\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default locationBySessionInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption, getPosition } from './echarts-utils';\r\n/* -------------------------------------------------------------------------- */\r\n/* Product Share */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst marketShareEcommerceInit = () => {\r\n const ECHART_PRODUCT_SHARE = '.echart-product-share';\r\n const $echartProductShare = document.querySelector(ECHART_PRODUCT_SHARE);\r\n\r\n if ($echartProductShare) {\r\n const userOptions = utils.getData($echartProductShare, 'options');\r\n const chart = window.echarts.init($echartProductShare);\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColors().primary,\r\n utils.getColors().info,\r\n utils.getColors().warning,\r\n ],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter(params) {\r\n return `${params.data.name}: ${params.percent}%`;\r\n },\r\n },\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n legend: { show: false },\r\n series: [\r\n {\r\n type: 'pie',\r\n radius: ['100%', '80%'],\r\n avoidLabelOverlap: false,\r\n hoverAnimation: false,\r\n itemStyle: {\r\n borderWidth: 2,\r\n borderColor: utils.getColor('gray-100'),\r\n },\r\n label: {\r\n normal: {\r\n show: false,\r\n position: 'center',\r\n textStyle: {\r\n fontSize: '20',\r\n fontWeight: '500',\r\n color: utils.getGrays()['700'],\r\n },\r\n },\r\n emphasis: {\r\n show: false,\r\n },\r\n },\r\n labelLine: { normal: { show: false } },\r\n data: [\r\n { value: 5300000, name: 'Falcon' },\r\n { value: 1900000, name: 'Sparrow' },\r\n { value: 2000000, name: 'Phoenix' },\r\n ],\r\n },\r\n ],\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default marketShareEcommerceInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption, getPosition } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Market Share */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst marketShareInit = () => {\r\n const ECHART_MARKET_SHARE = '.echart-market-share';\r\n const $echartMarketShare = document.querySelector(ECHART_MARKET_SHARE);\r\n\r\n if ($echartMarketShare) {\r\n const userOptions = utils.getData($echartMarketShare, 'options');\r\n const chart = window.echarts.init($echartMarketShare);\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColors().primary,\r\n utils.getColors().info,\r\n utils.getGrays()[300],\r\n ],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter(params) {\r\n return `${params.data.name}: ${params.percent}%`;\r\n },\r\n },\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n legend: { show: false },\r\n series: [\r\n {\r\n type: 'pie',\r\n radius: ['100%', '87%'],\r\n avoidLabelOverlap: false,\r\n hoverAnimation: false,\r\n itemStyle: {\r\n borderWidth: 2,\r\n borderColor: utils.getColor('gray-100'),\r\n },\r\n label: {\r\n normal: {\r\n show: false,\r\n position: 'center',\r\n textStyle: {\r\n fontSize: '20',\r\n fontWeight: '500',\r\n color: utils.getGrays()['100'],\r\n },\r\n },\r\n emphasis: {\r\n show: false,\r\n },\r\n },\r\n labelLine: { normal: { show: false } },\r\n data: [\r\n { value: 5300000, name: 'Samsung' },\r\n { value: 1900000, name: 'Huawei' },\r\n { value: 2000000, name: 'Apple' },\r\n ],\r\n },\r\n ],\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default marketShareInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Bandwidth Saved */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst marketingExpensesInit = () => {\r\n const $echartsMarketingExp = document.querySelector(\r\n '.echart-marketing-expenses'\r\n );\r\n\r\n if ($echartsMarketingExp) {\r\n const userOptions = utils.getData($echartsMarketingExp, 'options');\r\n const chart = window.echarts.init($echartsMarketingExp);\r\n\r\n const marketingExpenses = [\r\n {\r\n value: 412600,\r\n name: 'Offline Marketing',\r\n itemStyle: { color: utils.getColor('primary') },\r\n label: {\r\n rich: {\r\n per: {\r\n color: '#1C4F93',\r\n },\r\n },\r\n },\r\n },\r\n {\r\n value: 641500,\r\n name: 'Digital Marketing',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('info'), 0.35),\r\n },\r\n label: {\r\n rich: {\r\n per: {\r\n color: '#1978A2',\r\n },\r\n },\r\n },\r\n },\r\n ];\r\n\r\n const detailedExpenses = [\r\n {\r\n value: 91600,\r\n name: 'Event Sponsorship',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('primary'), 0.4),\r\n },\r\n },\r\n {\r\n value: 183000,\r\n name: 'Outrich Event',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('primary'), 0.6),\r\n },\r\n },\r\n {\r\n value: 138000,\r\n name: 'Ad Campaign',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('primary'), 0.8),\r\n },\r\n },\r\n {\r\n value: 183000,\r\n name: 'Social Media',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('info'), 0.2),\r\n },\r\n },\r\n {\r\n value: 45900,\r\n name: 'Google Ads',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('info'), 0.35),\r\n },\r\n },\r\n {\r\n value: 138000,\r\n name: 'Influencer Marketing',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('info'), 0.5),\r\n },\r\n },\r\n {\r\n value: 183000,\r\n name: 'Email Marketing',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('info'), 0.7),\r\n },\r\n },\r\n {\r\n value: 91600,\r\n name: 'Generate Backlinks',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColor('info'), 0.8),\r\n },\r\n },\r\n ];\r\n\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: 'item',\r\n backgroundColor: utils.getGrays()['100'],\r\n textStyle: { color: utils.getColors().dark },\r\n formatter: '{b}
    {c} ({d}%)',\r\n },\r\n series: [\r\n {\r\n name: 'Marketing Expenses',\r\n type: 'pie',\r\n selectedMode: 'single',\r\n radius: ['45%', '60%'],\r\n label: {\r\n show: false,\r\n },\r\n labelLine: {\r\n show: false,\r\n },\r\n itemStyle: {\r\n borderColor: utils.getColor('gray-100'),\r\n borderWidth: 2,\r\n },\r\n\r\n data: detailedExpenses,\r\n },\r\n {\r\n name: 'Marketing Expenses',\r\n type: 'pie',\r\n radius: ['70%', '75%'],\r\n barWidth: 10,\r\n labelLine: {\r\n length: 0,\r\n show: false,\r\n },\r\n label: {\r\n formatter: '{per|{d}%}',\r\n rich: {\r\n per: {\r\n fontSize: 14,\r\n fontWeight: 'bold',\r\n lineHeight: 33,\r\n },\r\n },\r\n },\r\n data: marketingExpenses,\r\n },\r\n ],\r\n });\r\n\r\n const initChart = () => {\r\n if (utils.isScrolledIntoView($echartsMarketingExp)) {\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n window.removeEventListener('scroll', initChart);\r\n }\r\n };\r\n\r\n window.addEventListener('scroll', initChart);\r\n }\r\n};\r\n\r\nexport default marketingExpensesInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption, getPosition } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Market Share */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst mostLeadsInit = () => {\r\n const ECHART_MOST_LEADS = '.echart-most-leads';\r\n const $echartMostLeads = document.querySelector(ECHART_MOST_LEADS);\r\n\r\n if ($echartMostLeads) {\r\n const userOptions = utils.getData($echartMostLeads, 'options');\r\n const chart = window.echarts.init($echartMostLeads);\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColors().primary,\r\n utils.rgbaColor(utils.getColors().primary, 0.5),\r\n utils.getColors().warning,\r\n utils.getColors().info,\r\n ],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter(params) {\r\n return `${params.data.name}: ${params.percent}%`;\r\n },\r\n },\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n legend: { show: false },\r\n series: [\r\n {\r\n type: 'pie',\r\n radius: ['100%', '67%'],\r\n avoidLabelOverlap: false,\r\n hoverAnimation: false,\r\n itemStyle: {\r\n borderWidth: 2,\r\n borderColor: utils.getColor('gray-100'),\r\n },\r\n label: {\r\n normal: {\r\n show: false,\r\n position: 'center',\r\n textStyle: {\r\n fontSize: '20',\r\n fontWeight: '500',\r\n color: utils.getGrays()['700'],\r\n },\r\n },\r\n emphasis: {\r\n show: false,\r\n },\r\n },\r\n labelLine: { normal: { show: false } },\r\n data: [\r\n { value: 60, name: 'Social' },\r\n { value: 30, name: 'Other' },\r\n { value: 10, name: 'Call' },\r\n { value: 120, name: 'Email' },\r\n ],\r\n },\r\n ],\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default mostLeadsInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n\r\nconst echartsNumberOfTicketsInit = () => {\r\n const $numberOfTickets = document.querySelector('.echart-number-of-tickets');\r\n\r\n if ($numberOfTickets) {\r\n const userOptions = utils.getData($numberOfTickets, 'options');\r\n const chart = window.echarts.init($numberOfTickets);\r\n const numberOfTicketsLegend = document.querySelectorAll(\"[data-number-of-tickets]\")\r\n\r\n let xAxisData = [\"Mar 01\", \"Mar 02\", \"Mar 03\", \"Mar 04\", \"Mar 05\", \"Mar 06\"];\r\n let data1 = [45, 35, 55, 55, 55, 45];\r\n let data2 = [58, 42, 65, 65, 65, 30];\r\n let data3 = [38, 25, 42, 42, 42, 45];\r\n let data4 = [62, 45, 75, 75, 75, 55];\r\n\r\n const emphasisStyle = {\r\n itemStyle: {\r\n shadowColor: utils.rgbaColor(utils.getColor('dark'), 0.3),\r\n borderRadius: [5, 5, 5, 5]\r\n }\r\n };\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColor('primary'),\r\n localStorage.getItem('theme') === 'dark' ? '#1E4C88' : '#94BCF1',\r\n localStorage.getItem('theme') === 'dark' ? '#1A3A64' : '#C0D8F7',\r\n localStorage.getItem('theme') === 'dark' ? '#225FAE' : '#6AA3ED',\r\n ],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getGrays()['900']},\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n axisPointer: {\r\n type: 'none'\r\n }\r\n },\r\n legend: {\r\n data: ['On Hold Tickets', 'Open Tickets', 'Due Tickets', 'Unassigned Tickets'],\r\n show: false\r\n },\r\n xAxis: {\r\n data: xAxisData,\r\n splitLine: { show: false, },\r\n splitArea: { show: false, },\r\n\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: \"dashed\"\r\n }\r\n },\r\n axisTick: {\r\n show: false,\r\n }\r\n },\r\n yAxis: {\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: \"dashed\"\r\n }\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n },\r\n },\r\n series: [\r\n {\r\n name: 'On Hold Tickets',\r\n type: 'bar',\r\n stack: 'one',\r\n emphasis: emphasisStyle,\r\n data: data1,\r\n },\r\n {\r\n name: 'Open Tickets',\r\n type: 'bar',\r\n stack: 'two',\r\n emphasis: emphasisStyle,\r\n data: data2\r\n },\r\n {\r\n name: 'Due Tickets',\r\n type: 'bar',\r\n stack: 'three',\r\n emphasis: emphasisStyle,\r\n data: data3\r\n },\r\n {\r\n name: 'Unassigned Tickets',\r\n type: 'bar',\r\n stack: 'four',\r\n emphasis: emphasisStyle,\r\n data: data4\r\n },\r\n ],\r\n itemStyle: {\r\n borderRadius: [3, 3, 0, 0]\r\n },\r\n\r\n barWidth: \"12px\",\r\n grid: {\r\n top: '10%',\r\n bottom: 0,\r\n left: 0,\r\n right: 0,\r\n containLabel: true\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n numberOfTicketsLegend.forEach(el => {\r\n el.addEventListener('change', () => {\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: utils.getData(el, 'number-of-tickets')\r\n })\r\n })\r\n })\r\n\r\n }\r\n};\r\n\r\nexport default echartsNumberOfTicketsInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Real Time Users */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst realTimeUsersChartInit = () => {\r\n const $echartsRealTimeUsers = document.querySelector(\r\n '.echart-real-time-users'\r\n );\r\n\r\n if ($echartsRealTimeUsers) {\r\n const userOptions = utils.getData($echartsRealTimeUsers, 'options');\r\n const chart = window.echarts.init($echartsRealTimeUsers);\r\n\r\n const data = [\r\n 921, 950, 916, 913, 909, 962, 926, 936, 977, 976, 999, 981, 998, 1000,\r\n 900, 906, 973, 911, 994, 982, 917, 972, 952, 963, 991,\r\n ];\r\n const axisData = [\r\n 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21,\r\n 22, 23, 24, 25,\r\n ];\r\n\r\n const tooltipFormatter = params => {\r\n return `\r\n
    \r\n
    \r\n Users : ${params[0].value}\r\n
    \r\n
    \r\n `;\r\n };\r\n\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n formatter: tooltipFormatter,\r\n },\r\n xAxis: {\r\n type: 'category',\r\n\r\n axisLabel: {\r\n show: false,\r\n },\r\n axisTick: {\r\n show: false,\r\n },\r\n axisLine: {\r\n show: false,\r\n },\r\n boundaryGap: [0.2, 0.2],\r\n data: axisData,\r\n },\r\n yAxis: {\r\n type: 'value',\r\n scale: true,\r\n boundaryGap: false,\r\n axisLabel: {\r\n show: false,\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n min: 500,\r\n max: 1100,\r\n },\r\n series: [\r\n {\r\n type: 'bar',\r\n barCategoryGap: '12%',\r\n data,\r\n itemStyle: {\r\n color: utils.rgbaColor('#fff', 0.3),\r\n },\r\n },\r\n ],\r\n grid: { right: '0px', left: '0px', bottom: 0, top: 0 },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n const userCounterDom = document.querySelector('.real-time-user');\r\n\r\n setInterval(() => {\r\n const rndData = utils.getRandomNumber(900, 1000);\r\n data.shift();\r\n data.push(rndData);\r\n axisData.shift();\r\n axisData.push(utils.getRandomNumber(100, 500));\r\n userCounterDom.innerHTML = rndData;\r\n\r\n chart.setOption({\r\n xAxis: {\r\n data: axisData,\r\n },\r\n series: [\r\n {\r\n data,\r\n },\r\n ],\r\n });\r\n }, 2000);\r\n }\r\n};\r\n\r\nexport default realTimeUsersChartInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n\r\nconst echartsReceivedTicketsInit = () => {\r\n const $receivedTickets = document.querySelector('.echart-received-tickets');\r\n\r\n if ($receivedTickets) {\r\n const userOptions = utils.getData($receivedTickets, 'options');\r\n const chart = window.echarts.init($receivedTickets);\r\n\r\n let xAxisData = [\"Apr 01\", \"Apr 02\", \"Apr 03\", \"Apr 04\", \"Apr 05\", \"Apr 06\", \"Apr 07\", \"Apr 08\", \"Apr 09\", \"Apr 10\"];\r\n let data1 = [28, 35, 28, 25, 21, 32, 25, 30, 23, 37];\r\n let data2 = [20, 27, 21, 15, 17, 22, 18, 20, 15, 27];\r\n let data3 = [15, 21, 23, 21, 12, 14, 13, 15, 10, 19];\r\n\r\n const emphasisStyle = {\r\n itemStyle: {\r\n shadowColor: utils.rgbaColor(utils.getColor('dark'), 0.3)\r\n }\r\n };\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColor('primary'),\r\n utils.getColor('info'),\r\n utils.getGrays()['300']\r\n ],\r\n legend: {\r\n data: ['All Received Tickets', 'New Received Tickets', 'Total Received Load Tickets'],\r\n icon: 'circle',\r\n itemWidth: 10,\r\n itemHeight: 10,\r\n padding: [0, 0, 0, 0],\r\n textStyle: {\r\n color: utils.getGrays()['700'],\r\n fontWeight: \"500\",\r\n fontSize: \"13px\"\r\n },\r\n left: 0,\r\n itemGap: 16,\r\n },\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getGrays()['900']},\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n axisPointer: {\r\n type: 'none'\r\n }\r\n },\r\n xAxis: {\r\n data: xAxisData,\r\n splitLine: { show: false, },\r\n splitArea: { show: false, },\r\n\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n },\r\n\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: \"dashed\"\r\n }\r\n },\r\n axisTick: {\r\n show: false,\r\n }\r\n },\r\n yAxis: {\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: \"dashed\"\r\n }\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n },\r\n },\r\n series: [\r\n {\r\n name: 'All Received Tickets',\r\n type: 'bar',\r\n stack: 'one',\r\n emphasis: emphasisStyle,\r\n data: data1\r\n },\r\n {\r\n name: 'New Received Tickets',\r\n type: 'bar',\r\n stack: 'two',\r\n emphasis: emphasisStyle,\r\n data: data2,\r\n },\r\n {\r\n name: 'Total Received Load Tickets',\r\n type: 'bar',\r\n stack: 'three',\r\n emphasis: emphasisStyle,\r\n data: data3,\r\n },\r\n ],\r\n itemStyle: {\r\n borderRadius: [3, 3, 0, 0]\r\n },\r\n\r\n barWidth: \"13.03px\",\r\n grid: {\r\n top: '13%',\r\n bottom: 0,\r\n left: 0,\r\n right: 0,\r\n containLabel: true\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default echartsReceivedTicketsInit;\r\n","import utils from \"../../utils\";\r\nimport { getPosition, echartSetOption } from \"./echarts-utils\";\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echart Bar Report For This Week */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst reportForThisWeekInit = () => {\r\n const ECHART_BAR_REPORT_FOR_THIS_WEEK = \".echart-bar-report-for-this-week\";\r\n const $echartBarReportForThisWeek = document.querySelector(\r\n ECHART_BAR_REPORT_FOR_THIS_WEEK\r\n );\r\n\r\n if ($echartBarReportForThisWeek) {\r\n const selectChart = utils.getData($echartBarReportForThisWeek, \"chart\");\r\n const legendThisWeek = document.getElementById(selectChart?.option1);\r\n const legendLastWeek = document.getElementById(selectChart?.option2);\r\n\r\n const data = [\r\n [\"product\", \"This Week\", \"Last Week\"],\r\n [\"Sun\", 43, 85],\r\n [\"Mon\", 83, 73],\r\n [\"Tue\", 86, 62],\r\n [\"Wed\", 72, 53],\r\n [\"Thu\", 80, 50],\r\n [\"Fri\", 50, 70],\r\n [\"Sat\", 80, 90],\r\n ];\r\n const userOptions = utils.getData($echartBarReportForThisWeek, \"options\");\r\n const chart = window.echarts.init($echartBarReportForThisWeek);\r\n\r\n const getDefaultOptions = () => ({\r\n color: [utils.getColors().primary, utils.getGrays()[\"300\"]],\r\n dataset: { source: data },\r\n tooltip: {\r\n trigger: \"item\",\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()[\"100\"],\r\n borderColor: utils.getGrays()[\"300\"],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n formatter: function (params) {\r\n return `
    ${\r\n params.seriesName\r\n }
    ${params.name}: ${\r\n params.value[params.componentIndex + 1]\r\n }
    `;\r\n },\r\n },\r\n legend: {\r\n show: false,\r\n },\r\n xAxis: {\r\n type: \"category\",\r\n axisLabel: { color: utils.getGrays()[\"400\"] },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()[\"300\"],\r\n type: \"dashed\",\r\n },\r\n },\r\n axisTick: false,\r\n boundaryGap: true,\r\n },\r\n yAxis: {\r\n axisPointer: { type: \"none\" },\r\n axisTick: \"none\",\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()[\"300\"],\r\n type: \"dashed\",\r\n },\r\n },\r\n axisLine: { show: false },\r\n\r\n axisLabel: {\r\n color: utils.getGrays()[\"400\"],\r\n formatter: (value) => `${value} hr`,\r\n },\r\n },\r\n series: [\r\n {\r\n type: \"bar\",\r\n name: \"\",\r\n barWidth: \"12%\",\r\n barGap: \"30%\",\r\n label: { normal: { show: false } },\r\n z: 10,\r\n itemStyle: {\r\n normal: {\r\n barBorderRadius: [10, 10, 0, 0],\r\n color: utils.getColors().primary,\r\n },\r\n },\r\n },\r\n {\r\n type: \"bar\",\r\n barWidth: \"12%\",\r\n barGap: \"30%\",\r\n label: { normal: { show: false } },\r\n itemStyle: {\r\n normal: {\r\n barBorderRadius: [4, 4, 0, 0],\r\n color: utils.getGrays()[300],\r\n },\r\n },\r\n },\r\n ],\r\n grid: { right: \"0\", left: \"40px\", bottom: \"10%\", top: \"15%\" },\r\n });\r\n\r\n legendLastWeek &&\r\n legendLastWeek.addEventListener(\"click\", () => {\r\n legendLastWeek.classList.toggle(\"opacity-50\");\r\n chart.dispatchAction({\r\n type: \"legendToggleSelect\",\r\n name: \"Last Week\",\r\n });\r\n });\r\n\r\n legendThisWeek &&\r\n legendThisWeek.addEventListener(\"click\", () => {\r\n legendThisWeek.classList.toggle(\"opacity-50\");\r\n chart.dispatchAction({\r\n type: \"legendToggleSelect\",\r\n name: \"This Week\",\r\n });\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default reportForThisWeekInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption, tooltipFormatter } from './echarts-utils';\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Line Returing Customer Rate */\r\n/* -------------------------------------------------------------------------- */\r\nconst returningCustomerRateInit = () => {\r\n const ECHART_LINE_RETURNING_CUSTOMER_RATE = '.echart-line-returning-customer-rate';\r\n const $echartsLineReturningCustomerRate = document.querySelector(\r\n ECHART_LINE_RETURNING_CUSTOMER_RATE\r\n );\r\n const months = [\r\n 'Jan',\r\n 'Feb',\r\n 'Mar',\r\n 'Apr',\r\n 'May',\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\r\n if ($echartsLineReturningCustomerRate) {\r\n // Get options from data attribute\r\n const userOptions = utils.getData($echartsLineReturningCustomerRate, 'options');\r\n const LEGEND_MONTH_TARGET = userOptions.target;\r\n const SELECT_MONTH = `#${userOptions.monthSelect}`;\r\n const LEGEND_NEW_MONTH = `#${userOptions.optionOne}`;\r\n const LEGEND_RETURNING_MONTH = `#${userOptions.optionTwo}`;\r\n const $legendNewMonth = document\r\n .getElementById(LEGEND_MONTH_TARGET)\r\n .querySelector(LEGEND_NEW_MONTH);\r\n const $legendReturningMonth = document\r\n .getElementById(LEGEND_MONTH_TARGET)\r\n .querySelector(LEGEND_RETURNING_MONTH);\r\n const chart = window.echarts.init($echartsLineReturningCustomerRate);\r\n\r\n const monthNumbers = [\r\n [20, 40, 20, 80, 50, 80, 120, 80, 50, 120, 110, 110],\r\n [60, 80, 60, 80, 65, 130, 120, 100, 30, 40, 30, 70],\r\n [100, 70, 80, 50, 120, 100, 130, 140, 90, 100, 40, 50],\r\n [80, 50, 60, 40, 60, 120, 100, 130, 60, 80, 50, 60],\r\n [70, 80, 100, 70, 90, 60, 80, 130, 40, 60, 50, 80],\r\n [90, 40, 80, 80, 100, 140, 100, 130, 90, 60, 70, 50],\r\n [80, 60, 80, 60, 40, 100, 120, 100, 30, 40, 30, 70],\r\n [20, 40, 20, 50, 70, 60, 110, 80, 90, 30, 50, 50],\r\n [60, 70, 30, 40, 80, 140, 80, 140, 120, 130, 100, 110],\r\n [90, 90, 40, 60, 40, 110, 90, 110, 60, 80, 60, 70],\r\n [50, 80, 50, 80, 50, 80, 120, 80, 50, 120, 110, 110],\r\n [60, 90, 60, 70, 40, 70, 100, 140, 30, 40, 30, 70],\r\n [20, 40, 20, 50, 30, 80, 120, 100, 30, 40, 30, 70]\r\n ];\r\n const dates = month => {\r\n return utils.getDates(\r\n window.dayjs().month(month).date(1),\r\n window\r\n .dayjs()\r\n .month(Number(month) + 1)\r\n .date(0),\r\n 1000 * 60 * 60 * 24 * 3\r\n );\r\n };\r\n const getDefaultOptions = () => ({\r\n title: {\r\n text: 'Customers',\r\n textStyle: {\r\n fontWeight: 500,\r\n fontSize: 13,\r\n fontFamily: 'poppins',\r\n color: utils.getColor('gray-900')\r\n }\r\n },\r\n legend: {\r\n show: false,\r\n data: ['New', 'Returning']\r\n },\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n formatter: tooltipFormatter\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: dates(0),\r\n boundaryGap: false,\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getColor('gray-300'),\r\n type: 'dashed'\r\n }\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getColor('gray-300'),\r\n type: 'solid'\r\n }\r\n },\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getColor('gray-400'),\r\n formatter(value) {\r\n const date = new Date(value);\r\n if (date.getDate() === 1) {\r\n return `${months[date.getMonth()].substring(0, 3)} ${date.getDate()}`;\r\n }\r\n return `${date.getDate()}`;\r\n },\r\n margin: 15\r\n },\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed'\r\n }\r\n }\r\n },\r\n yAxis: {\r\n type: 'value',\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300']\r\n }\r\n },\r\n boundaryGap: false,\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()['400'],\r\n margin: 15\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false }\r\n },\r\n series: [\r\n {\r\n name: 'New',\r\n type: 'line',\r\n data: monthNumbers[1],\r\n lineStyle: { color: utils.getColors().primary },\r\n itemStyle: {\r\n borderColor: utils.getColors().primary,\r\n borderWidth: 2\r\n },\r\n areaStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 0,\r\n y2: 1,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color: utils.rgbaColor(utils.getColor('primary'), 0.2)\r\n },\r\n {\r\n offset: 1,\r\n color: utils.rgbaColor(utils.getColor('primary'), 0.01)\r\n }\r\n ]\r\n }\r\n },\r\n symbol: 'none',\r\n smooth: false,\r\n hoverAnimation: true\r\n },\r\n {\r\n name: 'Returning',\r\n type: 'line',\r\n data: monthNumbers[0],\r\n lineStyle: { color: utils.getColor('warning') },\r\n itemStyle: {\r\n borderColor: utils.getColor('warning'),\r\n borderWidth: 2\r\n },\r\n areaStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 0,\r\n y2: 1,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color: utils.rgbaColor(utils.getColor('warning'), 0.2)\r\n },\r\n {\r\n offset: 1,\r\n color: utils.rgbaColor(utils.getColor('warning'), 0.01)\r\n }\r\n ]\r\n }\r\n },\r\n symbol: 'none',\r\n smooth: false,\r\n hoverAnimation: true\r\n }\r\n ],\r\n grid: { right: '7px', left: '35px', bottom: '8%', top: '15%' }\r\n });\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n // Change chart options accordiong to the selected month\r\n const monthSelect = document.querySelector(SELECT_MONTH);\r\n\r\n monthSelect.addEventListener('change', e => {\r\n const month = e.currentTarget.value;\r\n const dataNewMonth = monthNumbers[Number(month) + 1];\r\n const dataReturningMonth = monthNumbers[month];\r\n chart.setOption({\r\n xAxis: {\r\n data: dates(month)\r\n },\r\n series: [\r\n {\r\n data: dataNewMonth\r\n },\r\n {\r\n data: dataReturningMonth\r\n }\r\n ]\r\n });\r\n });\r\n $legendNewMonth.addEventListener('click', () => {\r\n $legendNewMonth.classList.toggle('opacity-50');\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'New'\r\n });\r\n });\r\n $legendReturningMonth.addEventListener('click', () => {\r\n $legendReturningMonth.classList.toggle('opacity-50');\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'Returning'\r\n });\r\n });\r\n }\r\n};\r\nexport default returningCustomerRateInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Sales Pos Location */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst salesByPosLocationInit = () => {\r\n const ECHART_RADAR_SALES_BY_POS_LOCATION = '.echart-radar-sales-by-pos-location';\r\n\r\n const $echartsRadarSalesByPosLocation = document.querySelector(\r\n ECHART_RADAR_SALES_BY_POS_LOCATION\r\n );\r\n function getformatter(params) {\r\n //const indicators = ['Marketing','Sales', 'Dev', 'Support', 'Tech', 'Admin']\r\n return ` ${params.name} \r\n
    \r\n Marketing: ${params.value[0]}
    \r\n Sales: ${params.value[1]}
    \r\n Dev: ${params.value[2]}
    \r\n Support: ${params.value[3]}
    \r\n Tech: ${params.value[4]}
    \r\n Admin: ${params.value[5]}
    \r\n
    `;\r\n }\r\n\r\n if ($echartsRadarSalesByPosLocation) {\r\n // Get options from data attribute\r\n const userOptions = utils.getData($echartsRadarSalesByPosLocation, 'options');\r\n const chart = window.echarts.init($echartsRadarSalesByPosLocation);\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getColor('gray-100'),\r\n borderColor: utils.getColor('gray-300'),\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter: getformatter\r\n },\r\n radar: {\r\n splitNumber: 7,\r\n radius: '75%',\r\n axisLine: {\r\n show: true,\r\n symbol: 'circle',\r\n symbolSize: [13, 13],\r\n lineStyle: {\r\n color: {\r\n type: 'radial',\r\n x: 0.5,\r\n y: 0.5,\r\n r: 0.5,\r\n colorStops: [\r\n {\r\n offset: 0.7,\r\n color: utils.getColor('gray-100')\r\n },\r\n {\r\n offset: 1,\r\n color: utils.getColor('gray-400')\r\n }\r\n ]\r\n }\r\n }\r\n },\r\n splitArea: {\r\n show: false\r\n },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getColor('gray-300')\r\n }\r\n },\r\n name: {\r\n textStyle: {\r\n color: utils.getColor('gray-600'),\r\n fontWeight: 500\r\n }\r\n },\r\n indicator: [\r\n { name: 'Marketing', max: 70 },\r\n { name: 'Admin', max: 70 },\r\n { name: 'Tech', max: 70 },\r\n { name: 'Support', max: 70 },\r\n { name: 'Dev', max: 70 },\r\n { name: 'Sales', max: 70 }\r\n ]\r\n },\r\n series: [\r\n {\r\n name: 'Budget vs spending',\r\n type: 'radar',\r\n symbol: 'pin',\r\n data: [\r\n {\r\n value: [20, 50, 60, 50, 60, 60],\r\n name: 'Budget',\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColors().warning, 0.5)\r\n },\r\n areaStyle: {\r\n color: utils.rgbaColor(utils.getColors().warning, 0.24)\r\n },\r\n symbol: 'circle',\r\n symbolSize: 8\r\n },\r\n {\r\n value: [40, 60, 30, 15, 60, 35],\r\n name: 'Spending',\r\n areaStyle: {\r\n color: [utils.rgbaColor(utils.getColors().primary, 0.24)]\r\n },\r\n symbol: 'circle',\r\n symbolSize: 8,\r\n itemStyle: {\r\n color: utils.rgbaColor(utils.getColors().primary)\r\n }\r\n }\r\n ]\r\n }\r\n ],\r\n grid: {\r\n top: 0,\r\n bottom: '100px'\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default salesByPosLocationInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n\r\nconst echartsSatisfactionSurveyInit = () => {\r\n const $satisfactionSurvey = document.querySelector('.echart-satisfaction-survey');\r\n\r\n if ($satisfactionSurvey) {\r\n const userOptions = utils.getData($satisfactionSurvey, 'options');\r\n const chart = window.echarts.init($satisfactionSurvey);\r\n\r\n let xAxisData = [\"05 April\", \"06 April\", \"07 April\", \"08 April\", \"09 April\", \"10 April\", \"11 April\", \"12 April\", \"13 April\", \"14 April\", \"15 April\"];\r\n let data1 = [98, 105, 65, 110, 75, 55, 95, 75, 90, 45, 70];\r\n let data2 = [80, 60, 78, 58, 65, 65, 75, 110, 40, 60, 60];\r\n\r\n const emphasisStyle1 = {\r\n itemStyle: {\r\n shadowColor: utils.rgbaColor(utils.getColor('dark'), 0.3),\r\n color: utils.rgbaColor(utils.getColor('primary'), 0.8)\r\n }\r\n };\r\n const emphasisStyle2 = {\r\n itemStyle: {\r\n shadowColor: utils.rgbaColor(utils.getColor('dark'), 0.3),\r\n color: utils.getGrays()['300']\r\n }\r\n };\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColor('primary'),\r\n utils.getGrays()['200']\r\n ],\r\n legend: {\r\n data: ['Satisfied', 'Dissatisfied'],\r\n icon: 'circle',\r\n itemWidth: 10,\r\n itemHeight: 10,\r\n padding: [0, 0, 0, 0],\r\n textStyle: {\r\n color: utils.getGrays()['700'],\r\n fontWeight: \"500\",\r\n fontSize: \"13px\"\r\n },\r\n left: 0,\r\n itemGap: 16,\r\n },\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getGrays()['900']},\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n axisPointer: {\r\n type: 'none'\r\n }\r\n },\r\n xAxis: {\r\n data: xAxisData,\r\n splitLine: { show: false, },\r\n splitArea: { show: false, },\r\n\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n },\r\n\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n }\r\n },\r\n axisTick: {\r\n show: false,\r\n }\r\n },\r\n yAxis: {\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: \"dashed\"\r\n }\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n },\r\n },\r\n series: [\r\n {\r\n name: 'Satisfied',\r\n type: 'bar',\r\n stack: 'one',\r\n emphasis: emphasisStyle1,\r\n data: data1\r\n },\r\n {\r\n name: 'Dissatisfied',\r\n type: 'bar',\r\n stack: 'two',\r\n emphasis: emphasisStyle2,\r\n data: data2,\r\n },\r\n ],\r\n itemStyle: {\r\n borderRadius: [3, 3, 0, 0]\r\n },\r\n\r\n barWidth: \"13.03px\",\r\n grid: {\r\n top: '13%',\r\n bottom: 0,\r\n left: 0,\r\n right: 0,\r\n containLabel: true\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default echartsSatisfactionSurveyInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption, getPosition } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Session By Device */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst sessionByBrowserChartInit = () => {\r\n const $sessionByBroswser = document.querySelector(\r\n '.echart-session-by-browser'\r\n );\r\n\r\n if ($sessionByBroswser) {\r\n const userOptions = utils.getData($sessionByBroswser, 'options');\r\n const chart = window.echarts.init($sessionByBroswser);\r\n\r\n const dataset = {\r\n week: [\r\n { value: 50.3, name: 'Chrome' },\r\n { value: 20.6, name: 'Safari' },\r\n { value: 30.1, name: 'Mozilla' },\r\n ],\r\n month: [\r\n { value: 35.1, name: 'Chrome' },\r\n { value: 25.6, name: 'Safari' },\r\n { value: 40.3, name: 'Mozilla' },\r\n ],\r\n year: [\r\n { value: 26.1, name: 'Chrome' },\r\n { value: 10.6, name: 'Safari' },\r\n { value: 64.3, name: 'Mozilla' },\r\n ],\r\n };\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColors().primary,\r\n utils.getColors().success,\r\n utils.getColors().info,\r\n ],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter: params =>\r\n `${params.data.name}: ${params.data.value}%`,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n },\r\n\r\n legend: { show: false },\r\n series: [\r\n {\r\n type: 'pie',\r\n radius: ['100%', '65%'],\r\n avoidLabelOverlap: false,\r\n hoverAnimation: false,\r\n itemStyle: {\r\n borderWidth: 2,\r\n borderColor: utils.getColor('gray-100'),\r\n },\r\n label: {\r\n normal: {\r\n show: false,\r\n },\r\n emphasis: {\r\n show: false,\r\n },\r\n },\r\n labelLine: { normal: { show: false } },\r\n data: dataset.week,\r\n },\r\n ],\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n const selectMenu = document.querySelector(\r\n \"[data-target='.echart-session-by-browser']\"\r\n );\r\n\r\n if (selectMenu) {\r\n selectMenu.addEventListener('change', e => {\r\n const { value } = e.currentTarget;\r\n chart.setOption({\r\n series: [{ data: dataset[value] }],\r\n });\r\n });\r\n }\r\n }\r\n};\r\n\r\nexport default sessionByBrowserChartInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Session By Country Map */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst sessionByCountryMapInit = () => {\r\n const $sessionByCountryMap = document.querySelector('.echart-session-by-country-map');\r\n\r\n const data = [\r\n { name: 'Afghanistan', value: 28397.812 },\r\n { name: 'Angola', value: 19549.124 },\r\n { name: 'Albania', value: 3150.143 },\r\n { name: 'United Arab Emirates', value: 8441.537 },\r\n { name: 'Argentina', value: 40374.224 },\r\n { name: 'Armenia', value: 2963.496 },\r\n { name: 'French Southern and Antarctic Lands', value: 268.065 },\r\n { name: 'Australia', value: 22404.488 },\r\n { name: 'Austria', value: 8401.924 },\r\n { name: 'Azerbaijan', value: 9094.718 },\r\n { name: 'Burundi', value: 9232.753 },\r\n { name: 'Belgium', value: 10941.288 },\r\n { name: 'Benin', value: 9509.798 },\r\n { name: 'Burkina Faso', value: 15540.284 },\r\n { name: 'Bangladesh', value: 151125.475 },\r\n { name: 'Bulgaria', value: 7389.175 },\r\n { name: 'The Bahamas', value: 66402.316 },\r\n { name: 'Bosnia and Herzegovina', value: 3845.929 },\r\n { name: 'Belarus', value: 9491.07 },\r\n { name: 'Belize', value: 308.595 },\r\n { name: 'Bermuda', value: 64.951 },\r\n { name: 'Bolivia', value: 716.939 },\r\n { name: 'Brazil', value: 195210.154 },\r\n { name: 'Brunei', value: 27.223 },\r\n { name: 'Bhutan', value: 716.939 },\r\n { name: 'Botswana', value: 1969.341 },\r\n { name: 'Central African Rep.', value: 4349.921 },\r\n { name: 'Canada', value: 34126.24 },\r\n { name: 'Switzerland', value: 7830.534 },\r\n { name: 'Chile', value: 17150.76 },\r\n { name: 'China', value: 1359821.465 },\r\n { name: \"Côte d'Ivoire\", value: 60508.978 },\r\n { name: 'Cameroon', value: 20624.343 },\r\n { name: 'Dem. Rep. Congo', value: 62191.161 },\r\n { name: 'Congo', value: 3573.024 },\r\n { name: 'Colombia', value: 46444.798 },\r\n { name: 'Costa Rica', value: 4669.685 },\r\n { name: 'Cuba', value: 11281.768 },\r\n { name: 'Northern Cyprus', value: 1.468 },\r\n { name: 'Cyprus', value: 1103.685 },\r\n { name: 'Czech Republic', value: 10553.701 },\r\n { name: 'Germany', value: 83017.404 },\r\n { name: 'Djibouti', value: 834.036 },\r\n { name: 'Denmark', value: 5550.959 },\r\n { name: 'Dominican Republic', value: 10016.797 },\r\n { name: 'Algeria', value: 37062.82 },\r\n { name: 'Ecuador', value: 15001.072 },\r\n { name: 'Egypt', value: 78075.705 },\r\n { name: 'Eritrea', value: 5741.159 },\r\n { name: 'Spain', value: 46182.038 },\r\n { name: 'Estonia', value: 1298.533 },\r\n { name: 'Ethiopia', value: 87095.281 },\r\n { name: 'Finland', value: 5367.693 },\r\n { name: 'Fiji', value: 860.559 },\r\n { name: 'Falkland Islands', value: 49.581 },\r\n { name: 'France', value: 63230.866 },\r\n { name: 'Gabon', value: 1556.222 },\r\n { name: 'United Kingdom', value: 62066.35 },\r\n { name: 'Georgia', value: 4388.674 },\r\n { name: 'Ghana', value: 24262.901 },\r\n { name: 'Eq. Guinea', value: 10876.033 },\r\n { name: 'Guinea', value: 10876.033 },\r\n { name: 'Gambia', value: 1680.64 },\r\n { name: 'Guinea Bissau', value: 10876.033 },\r\n { name: 'Equatorial Guinea', value: 696.167 },\r\n { name: 'Greece', value: 11109.999 },\r\n { name: 'Greenland', value: 56.546 },\r\n { name: 'Guatemala', value: 14341.576 },\r\n { name: 'French Guiana', value: 231.169 },\r\n { name: 'Guyana', value: 786.126 },\r\n { name: 'Honduras', value: 7621.204 },\r\n { name: 'Croatia', value: 4338.027 },\r\n { name: 'Haiti', value: 9896.4 },\r\n { name: 'Hungary', value: 10014.633 },\r\n { name: 'Indonesia', value: 240676.485 },\r\n { name: 'India', value: 1205624.648 },\r\n { name: 'Ireland', value: 4467.561 },\r\n { name: 'Iran', value: 240676.485 },\r\n { name: 'Iraq', value: 30962.38 },\r\n { name: 'Iceland', value: 318.042 },\r\n { name: 'Israel', value: 7420.368 },\r\n { name: 'Italy', value: 60508.978 },\r\n { name: 'Jamaica', value: 2741.485 },\r\n { name: 'Jordan', value: 6454.554 },\r\n { name: 'Japan', value: 127352.833 },\r\n { name: 'Kazakhstan', value: 15921.127 },\r\n { name: 'Kenya', value: 40909.194 },\r\n { name: 'Kyrgyzstan', value: 5334.223 },\r\n { name: 'Cambodia', value: 14364.931 },\r\n { name: 'South Korea', value: 51452.352 },\r\n { name: 'Kosovo', value: 97.743 },\r\n { name: 'Kuwait', value: 2991.58 },\r\n { name: 'Laos', value: 6395.713 },\r\n { name: 'Lebanon', value: 4341.092 },\r\n { name: 'Liberia', value: 3957.99 },\r\n { name: 'Libya', value: 6040.612 },\r\n { name: 'Sri Lanka', value: 20758.779 },\r\n { name: 'Lesotho', value: 2008.921 },\r\n { name: 'Lithuania', value: 3068.457 },\r\n { name: 'Luxembourg', value: 507.885 },\r\n { name: 'Latvia', value: 2090.519 },\r\n { name: 'Morocco', value: 31642.36 },\r\n { name: 'Moldova', value: 103.619 },\r\n { name: 'Madagascar', value: 21079.532 },\r\n { name: 'Mexico', value: 117886.404 },\r\n { name: 'Macedonia', value: 507.885 },\r\n { name: 'Mali', value: 13985.961 },\r\n { name: 'Myanmar', value: 51931.231 },\r\n { name: 'Montenegro', value: 620.078 },\r\n { name: 'Mongolia', value: 2712.738 },\r\n { name: 'Mozambique', value: 23967.265 },\r\n { name: 'Mauritania', value: 3609.42 },\r\n { name: 'Malawi', value: 15013.694 },\r\n { name: 'Malaysia', value: 28275.835 },\r\n { name: 'Namibia', value: 2178.967 },\r\n { name: 'New Caledonia', value: 246.379 },\r\n { name: 'Niger', value: 15893.746 },\r\n { name: 'Nigeria', value: 159707.78 },\r\n { name: 'Nicaragua', value: 5822.209 },\r\n { name: 'Netherlands', value: 16615.243 },\r\n { name: 'Norway', value: 4891.251 },\r\n { name: 'Nepal', value: 26846.016 },\r\n { name: 'New Zealand', value: 4368.136 },\r\n { name: 'Oman', value: 2802.768 },\r\n { name: 'Pakistan', value: 173149.306 },\r\n { name: 'Panama', value: 3678.128 },\r\n { name: 'Peru', value: 29262.83 },\r\n { name: 'Philippines', value: 93444.322 },\r\n { name: 'Papua New Guinea', value: 6858.945 },\r\n { name: 'Poland', value: 38198.754 },\r\n { name: 'Puerto Rico', value: 3709.671 },\r\n { name: 'North Korea', value: 1.468 },\r\n { name: 'Portugal', value: 10589.792 },\r\n { name: 'Paraguay', value: 6459.721 },\r\n { name: 'Qatar', value: 1749.713 },\r\n { name: 'Romania', value: 21861.476 },\r\n { name: 'Russia', value: 21861.476 },\r\n { name: 'Rwanda', value: 10836.732 },\r\n { name: 'Western Sahara', value: 514.648 },\r\n { name: 'Saudi Arabia', value: 27258.387 },\r\n { name: 'Sudan', value: 35652.002 },\r\n { name: 'S. Sudan', value: 9940.929 },\r\n { name: 'Senegal', value: 12950.564 },\r\n { name: 'Solomon Islands', value: 526.447 },\r\n { name: 'Sierra Leone', value: 5751.976 },\r\n { name: 'El Salvador', value: 6218.195 },\r\n { name: 'Somaliland', value: 9636.173 },\r\n { name: 'Somalia', value: 9636.173 },\r\n { name: 'Republic of Serbia', value: 3573.024 },\r\n { name: 'Suriname', value: 524.96 },\r\n { name: 'Slovakia', value: 5433.437 },\r\n { name: 'Slovenia', value: 2054.232 },\r\n { name: 'Sweden', value: 9382.297 },\r\n { name: 'Swaziland', value: 1193.148 },\r\n { name: 'Syria', value: 7830.534 },\r\n { name: 'Chad', value: 11720.781 },\r\n { name: 'Togo', value: 6306.014 },\r\n { name: 'Thailand', value: 66402.316 },\r\n { name: 'Tajikistan', value: 7627.326 },\r\n { name: 'Turkmenistan', value: 5041.995 },\r\n { name: 'East Timor', value: 10016.797 },\r\n { name: 'Trinidad and Tobago', value: 1328.095 },\r\n { name: 'Tunisia', value: 10631.83 },\r\n { name: 'Turkey', value: 72137.546 },\r\n { name: 'Tanzania', value: 44973.33 },\r\n { name: 'Uganda', value: 33987.213 },\r\n { name: 'Ukraine', value: 46050.22 },\r\n { name: 'Uruguay', value: 3371.982 },\r\n { name: 'United States', value: 312247.116 },\r\n { name: 'Uzbekistan', value: 27769.27 },\r\n { name: 'Venezuela', value: 236.299 },\r\n { name: 'Vietnam', value: 89047.397 },\r\n { name: 'Vanuatu', value: 236.299 },\r\n { name: 'West Bank', value: 13.565 },\r\n { name: 'Yemen', value: 22763.008 },\r\n { name: 'South Africa', value: 51452.352 },\r\n { name: 'Zambia', value: 13216.985 },\r\n { name: 'Zimbabwe', value: 13076.978 }\r\n ];\r\n\r\n const total = 6961500;\r\n\r\n if ($sessionByCountryMap) {\r\n const userOptions = utils.getData($sessionByCountryMap, 'options');\r\n const chart = window.echarts.init($sessionByCountryMap);\r\n\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter: params =>\r\n `${params.data?.name} : ${((params.data?.value / total) * 100).toFixed(\r\n 2\r\n )}%`\r\n },\r\n toolbox: {\r\n show: false,\r\n feature: {\r\n restore: {}\r\n }\r\n },\r\n visualMap: {\r\n show: false,\r\n min: 800,\r\n max: 50000,\r\n inRange: {\r\n color: [\r\n utils.getColors().primary,\r\n utils.rgbaColor(utils.getColors().primary, 0.8),\r\n utils.rgbaColor(utils.getColors().primary, 0.6),\r\n utils.rgbaColor(utils.getColors().primary, 0.4),\r\n utils.rgbaColor(utils.getColors().primary, 0.2)\r\n ].reverse()\r\n }\r\n },\r\n series: [\r\n {\r\n type: 'map',\r\n map: 'world',\r\n data,\r\n roam: true,\r\n scaleLimit: {\r\n min: 1,\r\n max: 5\r\n },\r\n left: 0,\r\n right: 0,\r\n label: {\r\n show: false\r\n },\r\n itemStyle: {\r\n borderColor: utils.getGrays()['300']\r\n },\r\n emphasis: {\r\n label: {\r\n show: false\r\n },\r\n itemStyle: {\r\n areaColor: utils.getColor('warning')\r\n }\r\n }\r\n }\r\n ]\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n document.querySelector('.session-by-country-map-reset')?.addEventListener('click', () => {\r\n chart.dispatchAction({\r\n type: 'restore'\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default sessionByCountryMapInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Session By Country */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst sessionByCountryChartInit = () => {\r\n const $sessionByCountry = document.querySelector(\r\n '.echart-session-by-country'\r\n );\r\n\r\n const data = [\r\n ['CHINA', 'INDIA', 'USA', 'IRAN', 'BRAZIL', 'PAKISTAN'],\r\n [19.53, 17.32, 4.49, 3.46, 2.8, 1.7],\r\n ];\r\n\r\n if ($sessionByCountry) {\r\n const userOptions = utils.getData($sessionByCountry, 'options');\r\n const chart = window.echarts.init($sessionByCountry);\r\n\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n // formatter: tooltipFormatter\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: data[0],\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: value => value.substring(0, 3),\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['400'],\r\n },\r\n },\r\n axisTick: {\r\n show: true,\r\n // length: 8,\r\n alignWithLabel: true,\r\n lineStyle: {\r\n color: utils.getGrays()['200'],\r\n },\r\n },\r\n },\r\n yAxis: {\r\n type: 'value',\r\n // inverse: true,\r\n axisTick: {\r\n show: false,\r\n },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed',\r\n },\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: value => `${value}%`,\r\n fontWeight: 500,\r\n padding: [3, 0, 0, 0],\r\n margin: 12,\r\n },\r\n axisLine: {\r\n show: false,\r\n },\r\n },\r\n series: [\r\n {\r\n type: 'bar',\r\n data: data[1],\r\n itemStyle: {\r\n barBorderRadius: [3, 3, 0, 0],\r\n color: utils.getColors().primary,\r\n },\r\n barWidth: 15,\r\n },\r\n ],\r\n grid: { right: '12px', left: '40px', bottom: '10%', top: '16px' },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default sessionByCountryChartInit;\r\n","import basicEchartsInit from './basic-echarts';\r\n\r\nconst echartTicketPriority = () => {\r\n const $paginationBtnNext = document.querySelector(\r\n '[data-list-pagination-chart=\"next\"]'\r\n );\r\n const $paginationBtnPrev = document.querySelector(\r\n '[data-list-pagination-chart=\"prev\"]'\r\n );\r\n const $paginationContainer = document.querySelector(\r\n '[data-list-pagination-chart]'\r\n );\r\n if ($paginationBtnNext) {\r\n $paginationBtnNext.addEventListener('click', () => {\r\n basicEchartsInit();\r\n });\r\n }\r\n if ($paginationBtnPrev) {\r\n $paginationBtnPrev.addEventListener('click', () => {\r\n basicEchartsInit();\r\n });\r\n }\r\n if ($paginationContainer) {\r\n $paginationContainer.addEventListener('click', e => {\r\n if (e.target.tagName === 'BUTTON') {\r\n setTimeout(() => {\r\n basicEchartsInit();\r\n });\r\n }\r\n });\r\n }\r\n};\r\n\r\nexport default echartTicketPriority;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption, tooltipFormatter } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Traffic Channels */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst ticketVolumeChartInit = () => {\r\n const $ticketVolume = document.querySelector('.echart-ticket-volume');\r\n\r\n if ($ticketVolume) {\r\n const userOptions = utils.getData($ticketVolume, 'options');\r\n const chart = window.echarts.init($ticketVolume);\r\n const ticketVolumeLegend = document.querySelectorAll(\"[data-ticket-volume]\")\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColors().primary,\r\n localStorage.getItem('theme') === 'dark' ? '#235FAD' : '#6AA2EC',\r\n localStorage.getItem('theme') === 'dark' ? '#1C4477' : '#AACAF4',\r\n localStorage.getItem('theme') === 'dark' ? '#152C48' : '#DFEBFB',\r\n ],\r\n legend: {\r\n data: ['On Hold Tickets', 'Open Tickets', 'Due Tickets', 'Unassigned Tickets'],\r\n show: false\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: utils.getPastDates(10),\r\n axisLine: {\r\n show: false\r\n },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300']\r\n }\r\n },\r\n axisTick: {\r\n show: false\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: value => window.dayjs(value).format('MMM DD'),\r\n }\r\n },\r\n yAxis: {\r\n type: 'value',\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300']\r\n }\r\n },\r\n axisLine: {\r\n show: false\r\n },\r\n axisTick: {\r\n show: false\r\n },\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()['600'],\r\n }\r\n },\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n axisPointer: {\r\n type: 'none'\r\n },\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n formatter: tooltipFormatter\r\n },\r\n\r\n series: [\r\n {\r\n name: 'On Hold Tickets',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [8, 6, 5, 12, 9, 6, 9, 6, 4, 7],\r\n emphasis:{ \r\n itemStyle: {\r\n color: utils.getColor('primary'),\r\n }\r\n },\r\n },\r\n {\r\n name: 'Open Tickets',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [15, 10, 7, 7, 5, 6, 15, 10, 7, 12],\r\n emphasis:{ \r\n itemStyle: {\r\n color: localStorage.getItem('theme') === 'dark' ? '#2567BD' : '#5595E9',\r\n }\r\n },\r\n },\r\n {\r\n name: 'Due Tickets',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [5, 4, 4, 6, 6, 8, 7, 4, 3, 5],\r\n emphasis:{ \r\n itemStyle: {\r\n color: localStorage.getItem('theme') === 'dark' ? '#205396' : '#7FB0EF',\r\n }\r\n },\r\n },\r\n {\r\n name: 'Unassigned Tickets',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [6, 3, 6, 4, 12, 7, 5, 3, 2, 4],\r\n itemStyle: {\r\n barBorderRadius: [2, 2, 0, 0]\r\n },\r\n emphasis:{ \r\n itemStyle: {\r\n color: localStorage.getItem('theme') === 'dark' ? '#1A3F6F' : '#AACAF4',\r\n }\r\n },\r\n },\r\n ],\r\n\r\n grid: {\r\n right: '0px',\r\n left: '23px',\r\n bottom: '6%',\r\n top: '10%'\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n ticketVolumeLegend.forEach(el => {\r\n el.addEventListener('change', () => {\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: utils.getData(el, 'ticket-volume')\r\n })\r\n })\r\n })\r\n\r\n }\r\n};\r\n\r\nexport default ticketVolumeChartInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Audience Chart */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst topCustomersChartInit = () => {\r\n const data = {\r\n hours: [\"1H\", \"2H\", \"3H\", \"4H\", \"5H\", \"6H\", \"7H\", \"8H\", \"9H\", \"10H\"],\r\n dataset: {\r\n monday: [\r\n [18, 50, 45, 80, 45, 60, 55, 82, 61, 50],\r\n ],\r\n tuesday: [\r\n [50, 45, 32, 74, 45, 55, 85, 30, 25, 50],\r\n ],\r\n wednesday: [\r\n [88, 70, 75, 54, 45, 44, 25, 65, 11, 20],\r\n ],\r\n thursday: [\r\n [20, 30, 40, 50, 70, 80, 85, 40, 30, 20],\r\n ],\r\n friday: [\r\n [18, 50, 45, 75, 45, 80, 85, 65, 61, 50],\r\n ],\r\n saturday: [\r\n [25, 50, 45, 75, 80, 44, 55, 85, 61, 45],\r\n ],\r\n sunday: [\r\n [11, 50, 45, 78, 45, 54, 80, 90, 50, 65],\r\n ],\r\n },\r\n };\r\n\r\n const getDefaultOptions = (data1) => () => ({\r\n color: utils.getGrays()['100'],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n axisPointer: {\r\n type: 'none',\r\n },\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: data.hours,\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n margin: 15,\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed',\r\n },\r\n },\r\n axisTick: {\r\n show: false,\r\n },\r\n boundaryGap: false,\r\n },\r\n yAxis: {\r\n type: 'value',\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed',\r\n },\r\n },\r\n boundaryGap: false,\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()['600'],\r\n margin: 25,\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false },\r\n },\r\n series: [\r\n {\r\n type: 'line',\r\n data: data1,\r\n symbol: \"circle\",\r\n symbolSize: 10,\r\n itemStyle: {\r\n borderColor: utils.getColors().primary,\r\n borderWidth: 2,\r\n },\r\n lineStyle: { color: utils.getColors().primary },\r\n areaStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 0,\r\n y2: 1,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color: utils.rgbaColor(utils.getColors().primary, 0.1),\r\n },\r\n {\r\n offset: 1,\r\n color: utils.rgbaColor(utils.getColors().primary, 0),\r\n },\r\n ],\r\n },\r\n },\r\n },\r\n ],\r\n grid: { right: '12px', left: '46px', bottom: '12%', top: '3%' },\r\n });\r\n\r\n const initChart = (el, options) => {\r\n const userOptions = utils.getData(el, 'options');\r\n const chart = window.echarts.init(el);\r\n echartSetOption(chart, userOptions, options);\r\n };\r\n\r\n const tab = document.querySelector('#top-customers-chart-tab');\r\n\r\n if (tab) {\r\n initChart(\r\n document.querySelector('.echart-top-customers'),\r\n getDefaultOptions(data.dataset.monday[0])\r\n );\r\n\r\n const triggerTabList = Array.from(\r\n tab.querySelectorAll('[data-bs-toggle=\"tab\"]')\r\n );\r\n triggerTabList.forEach(function (triggerEl) {\r\n triggerEl.addEventListener('shown.bs.tab', function () {\r\n const key = triggerEl.href.split('#').pop();\r\n const $echartTopCustomers = document\r\n .getElementById(key)\r\n .querySelector('.echart-top-customers');\r\n\r\n initChart(\r\n $echartTopCustomers,\r\n getDefaultOptions(data.dataset[key][0])\r\n );\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default topCustomersChartInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Top Products */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst topProductsInit = () => {\r\n const ECHART_BAR_TOP_PRODUCTS = '.echart-bar-top-products';\r\n const $echartBarTopProducts = document.querySelector(ECHART_BAR_TOP_PRODUCTS);\r\n\r\n if ($echartBarTopProducts) {\r\n const data = [\r\n ['product', '2019', '2018'],\r\n ['Boots4', 43, 85],\r\n ['Reign Pro', 83, 73],\r\n ['Slick', 86, 62],\r\n ['Falcon', 72, 53],\r\n ['Sparrow', 80, 50],\r\n ['Hideway', 50, 70],\r\n ['Freya', 80, 90],\r\n ];\r\n const userOptions = utils.getData($echartBarTopProducts, 'options');\r\n const chart = window.echarts.init($echartBarTopProducts);\r\n\r\n const getDefaultOptions = () => ({\r\n color: [utils.getColors().primary, utils.getGrays()['300']],\r\n dataset: { source: data },\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n formatter: function (params) {\r\n return `
    ${\r\n params.seriesName\r\n }
    ${params.name}: ${\r\n params.value[params.componentIndex + 1]\r\n }
    `;\r\n },\r\n },\r\n legend: {\r\n data: ['2019', '2018'],\r\n left: 'left',\r\n itemWidth: 10,\r\n itemHeight: 10,\r\n borderRadius: 0,\r\n icon: 'circle',\r\n inactiveColor: utils.getGrays()['400'],\r\n textStyle: { color: utils.getGrays()['700'] },\r\n },\r\n xAxis: {\r\n type: 'category',\r\n axisLabel: { color: utils.getGrays()['400'] },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed',\r\n },\r\n },\r\n axisTick: false,\r\n boundaryGap: true,\r\n },\r\n yAxis: {\r\n axisPointer: { type: 'none' },\r\n axisTick: 'none',\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed',\r\n },\r\n },\r\n axisLine: { show: false },\r\n axisLabel: { color: utils.getGrays()['400'] },\r\n },\r\n series: [\r\n {\r\n type: 'bar',\r\n barWidth: '10px',\r\n barGap: '30%',\r\n label: { normal: { show: false } },\r\n z: 10,\r\n itemStyle: {\r\n normal: {\r\n barBorderRadius: [10, 10, 0, 0],\r\n color: utils.getColors().primary,\r\n },\r\n },\r\n },\r\n {\r\n type: 'bar',\r\n barWidth: '10px',\r\n barGap: '30%',\r\n label: { normal: { show: false } },\r\n itemStyle: {\r\n normal: {\r\n barBorderRadius: [4, 4, 0, 0],\r\n color: utils.getGrays()[300],\r\n },\r\n },\r\n },\r\n ],\r\n grid: { right: '0', left: '30px', bottom: '10%', top: '20%' },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default topProductsInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Total Order */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst totalOrderInit = () => {\r\n\tconst ECHART_LINE_TOTAL_ORDER = '.echart-line-total-order';\r\n\r\n\t//\r\n\t// ─── TOTAL ORDER CHART ──────────────────────────────────────────────────────────\r\n\t//\r\n\tconst $echartLineTotalOrder = document.querySelector(ECHART_LINE_TOTAL_ORDER);\r\n\tif ($echartLineTotalOrder) {\r\n\t\t// Get options from data attribute\r\n\t\tconst userOptions = utils.getData($echartLineTotalOrder, 'options');\r\n\t\tconst chart = window.echarts.init($echartLineTotalOrder);\r\n\r\n\t\t// Default options\r\n\t\tconst getDefaultOptions = () => ({\r\n\t\t\ttooltip: {\r\n\t\t\t\ttriggerOn: 'mousemove',\r\n\t\t\t\ttrigger: 'axis',\r\n\t\t\t\tpadding: [7, 10],\r\n\t\t\t\tformatter: '{b0}: {c0}',\r\n\t\t\t\tbackgroundColor: utils.getGrays()['100'],\r\n\t\t\t\tborderColor: utils.getGrays()['300'],\r\n\t\t\t\ttextStyle: { color: utils.getColors().dark },\r\n\t\t\t\tborderWidth: 1,\r\n\t\t\t\ttransitionDuration: 0,\r\n\t\t\t\tposition(pos, params, dom, rect, size) {\r\n\t\t\t\t\treturn getPosition(pos, params, dom, rect, size);\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\txAxis: {\r\n\t\t\t\ttype: 'category',\r\n\t\t\t\tdata: ['Week 4', 'Week 5', 'Week 6', 'Week 7'],\r\n\t\t\t\tboundaryGap: false,\r\n\t\t\t\tsplitLine: { show: false },\r\n\t\t\t\taxisLine: {\r\n\t\t\t\t\tshow: false,\r\n\t\t\t\t\tlineStyle: {\r\n\t\t\t\t\t\tcolor: utils.getGrays()['300'],\r\n\t\t\t\t\t\ttype: 'dashed'\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\taxisLabel: { show: false },\r\n\t\t\t\taxisTick: { show: false },\r\n\t\t\t\taxisPointer: { type: 'none' }\r\n\t\t\t},\r\n\t\t\tyAxis: {\r\n\t\t\t\ttype: 'value',\r\n\t\t\t\tsplitLine: { show: false },\r\n\t\t\t\taxisLine: { show: false },\r\n\t\t\t\taxisLabel: { show: false },\r\n\t\t\t\taxisTick: { show: false },\r\n\t\t\t\taxisPointer: { show: false }\r\n\t\t\t},\r\n\t\t\tseries: [\r\n\t\t\t\t{\r\n\t\t\t\t\ttype: 'line',\r\n\t\t\t\t\tlineStyle: {\r\n\t\t\t\t\t\tcolor: utils.getColors().primary,\r\n\t\t\t\t\t\twidth: 3\r\n\t\t\t\t\t},\r\n\t\t\t\t\titemStyle: {\r\n\t\t\t\t\t\tcolor: utils.getGrays().white,\r\n\t\t\t\t\t\tborderColor: utils.getColors().primary,\r\n\t\t\t\t\t\tborderWidth: 2\r\n\t\t\t\t\t},\r\n\t\t\t\t\thoverAnimation: true,\r\n\t\t\t\t\tdata: [20, 40, 100, 120],\r\n\t\t\t\t\t// connectNulls: true,\r\n\t\t\t\t\tsmooth: 0.6,\r\n\t\t\t\t\tsmoothMonotone: 'x',\r\n\t\t\t\t\tshowSymbol: false,\r\n\t\t\t\t\tsymbol: 'circle',\r\n\t\t\t\t\tsymbolSize: 8,\r\n\t\t\t\t\tareaStyle: {\r\n\t\t\t\t\t\tcolor: {\r\n\t\t\t\t\t\t\ttype: 'linear',\r\n\t\t\t\t\t\t\tx: 0,\r\n\t\t\t\t\t\t\ty: 0,\r\n\t\t\t\t\t\t\tx2: 0,\r\n\t\t\t\t\t\t\ty2: 1,\r\n\t\t\t\t\t\t\tcolorStops: [\r\n\t\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t\toffset: 0,\r\n\t\t\t\t\t\t\t\t\tcolor: utils.rgbaColor(utils.getColors().primary, 0.25)\r\n\t\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t\toffset: 1,\r\n\t\t\t\t\t\t\t\t\tcolor: utils.rgbaColor(utils.getColors().primary, 0)\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t]\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\tgrid: {\r\n\t\t\t\tbottom: '2%',\r\n\t\t\t\ttop: '0%',\r\n\t\t\t\tright: '10px',\r\n\t\t\t\tleft: '10px'\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\techartSetOption(chart, userOptions, getDefaultOptions);\r\n\t}\r\n};\r\n\r\nexport default totalOrderInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption, getPosition } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Total Sales E-commerce */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst totalSalesEcommerce = () => {\r\n const ECHART_LINE_TOTAL_SALES_ECOMM = '.echart-line-total-sales-ecommerce';\r\n const $echartsLineTotalSalesEcomm = document.querySelector(\r\n ECHART_LINE_TOTAL_SALES_ECOMM\r\n );\r\n const months = [\r\n 'Jan',\r\n 'Feb',\r\n 'Mar',\r\n 'Apr',\r\n 'May',\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\r\n function getFormatter(params) {\r\n return params\r\n .map(\r\n ({\r\n value,\r\n borderColor,\r\n seriesName\r\n }) => `\r\n ${\r\n seriesName === 'lastMonth' ? 'Last Month' : 'Previous Year'\r\n }: ${value}`\r\n )\r\n .join('
    ');\r\n }\r\n if ($echartsLineTotalSalesEcomm) {\r\n // Get options from data attribute\r\n const userOptions = utils.getData($echartsLineTotalSalesEcomm, 'options');\r\n const TOTAL_SALES_LAST_MONTH = `#${userOptions.optionOne}`;\r\n const TOTAL_SALES_PREVIOUS_YEAR = `#${userOptions.optionTwo}`;\r\n const totalSalesLastMonth = document.querySelector(TOTAL_SALES_LAST_MONTH);\r\n const totalSalesPreviousYear = document.querySelector(\r\n TOTAL_SALES_PREVIOUS_YEAR\r\n );\r\n\r\n const chart = window.echarts.init($echartsLineTotalSalesEcomm);\r\n const getDefaultOptions = () => ({\r\n color: utils.getGrays()['100'],\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n formatter(params) {\r\n return getFormatter(params);\r\n },\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n }\r\n },\r\n legend: {\r\n data: ['lastMonth', 'previousYear'],\r\n show: false\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: [\r\n '2019-01-05',\r\n '2019-01-06',\r\n '2019-01-07',\r\n '2019-01-08',\r\n '2019-01-09',\r\n '2019-01-10',\r\n '2019-01-11',\r\n '2019-01-12',\r\n '2019-01-13',\r\n '2019-01-14',\r\n '2019-01-15',\r\n '2019-01-16'\r\n ],\r\n boundaryGap: false,\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getColor('gray-300'),\r\n type: 'dashed'\r\n }\r\n },\r\n splitLine: { show: false },\r\n axisLine: {\r\n lineStyle: {\r\n // color: utils.getGrays()['300'],\r\n color: utils.rgbaColor('#000', 0.01),\r\n type: 'dashed'\r\n }\r\n },\r\n\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getColor('gray-400'),\r\n formatter(value) {\r\n const date = new Date(value);\r\n return `${months[date.getMonth()]} ${date.getDate()}`;\r\n },\r\n margin: 15\r\n // showMaxLabel: false\r\n }\r\n },\r\n yAxis: {\r\n type: 'value',\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getColor('gray-300'),\r\n type: 'dashed'\r\n }\r\n },\r\n boundaryGap: false,\r\n axisLabel: {\r\n show: true,\r\n color: utils.getColor('gray-400'),\r\n margin: 15\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false }\r\n },\r\n\r\n series: [\r\n {\r\n name: 'lastMonth',\r\n type: 'line',\r\n data: [50, 80, 60, 80, 65, 90, 130, 90, 30, 40, 30, 70],\r\n lineStyle: { color: utils.getColor('primary') },\r\n itemStyle: {\r\n borderColor: utils.getColor('primary'),\r\n borderWidth: 2\r\n },\r\n symbol: 'circle',\r\n symbolSize: 10,\r\n hoverAnimation: true,\r\n areaStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 0,\r\n y2: 1,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color: utils.rgbaColor(utils.getColor('primary'), 0.2)\r\n },\r\n {\r\n offset: 1,\r\n color: utils.rgbaColor(utils.getColor('primary'), 0)\r\n }\r\n ]\r\n }\r\n }\r\n },\r\n\r\n {\r\n name: 'previousYear',\r\n type: 'line',\r\n data: [110, 30, 40, 50, 80, 70, 50, 40, 110, 90, 60, 60],\r\n lineStyle: { color: utils.rgbaColor(utils.getColor('warning'), 0.3) },\r\n itemStyle: {\r\n borderColor: utils.rgbaColor(utils.getColor('warning'), 0.6),\r\n borderWidth: 2\r\n },\r\n symbol: 'circle',\r\n symbolSize: 10,\r\n hoverAnimation: true\r\n }\r\n ],\r\n grid: {\r\n right: '18px',\r\n left: '40px',\r\n bottom: '15%',\r\n top: '5%'\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n totalSalesLastMonth.addEventListener('click', () => {\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'lastMonth'\r\n });\r\n });\r\n\r\n totalSalesPreviousYear.addEventListener('click', () => {\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: 'previousYear'\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default totalSalesEcommerce;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Total Sales */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst totalSalesInit = () => {\r\n const ECHART_LINE_TOTAL_SALES = '.echart-line-total-sales';\r\n const SELECT_MONTH = '.select-month';\r\n\r\n const $echartsLineTotalSales = document.querySelector(\r\n ECHART_LINE_TOTAL_SALES\r\n );\r\n const months = [\r\n 'Jan',\r\n 'Feb',\r\n 'Mar',\r\n 'Apr',\r\n 'May',\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 function getFormatter(params) {\r\n const { name, value } = params[0];\r\n const date = new Date(name);\r\n return `${months[0]} ${date.getDate()}, ${value}`;\r\n }\r\n if ($echartsLineTotalSales) {\r\n // Get options from data attribute\r\n const userOptions = utils.getData($echartsLineTotalSales, 'options');\r\n const chart = window.echarts.init($echartsLineTotalSales);\r\n const monthsnumber = [\r\n [60, 80, 60, 80, 65, 130, 120, 100, 30, 40, 30, 70],\r\n [100, 70, 80, 50, 120, 100, 130, 140, 90, 100, 40, 50],\r\n [80, 50, 60, 40, 60, 120, 100, 130, 60, 80, 50, 60],\r\n [70, 80, 100, 70, 90, 60, 80, 130, 40, 60, 50, 80],\r\n [90, 40, 80, 80, 100, 140, 100, 130, 90, 60, 70, 50],\r\n [80, 60, 80, 60, 40, 100, 120, 100, 30, 40, 30, 70],\r\n [20, 40, 20, 50, 70, 60, 110, 80, 90, 30, 50, 50],\r\n [60, 70, 30, 40, 80, 140, 80, 140, 120, 130, 100, 110],\r\n [90, 90, 40, 60, 40, 110, 90, 110, 60, 80, 60, 70],\r\n [50, 80, 50, 80, 50, 80, 120, 80, 50, 120, 110, 110],\r\n [60, 90, 60, 70, 40, 70, 100, 140, 30, 40, 30, 70],\r\n [20, 40, 20, 50, 30, 80, 120, 100, 30, 40, 30, 70]\r\n ];\r\n const getDefaultOptions = () => ({\r\n color: utils.getGrays()['100'],\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n formatter(params) {\r\n return getFormatter(params);\r\n },\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n }\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: [\r\n '2019-01-05',\r\n '2019-01-06',\r\n '2019-01-07',\r\n '2019-01-08',\r\n '2019-01-09',\r\n '2019-01-10',\r\n '2019-01-11',\r\n '2019-01-12',\r\n '2019-01-13',\r\n '2019-01-14',\r\n '2019-01-15',\r\n '2019-01-16'\r\n ],\r\n boundaryGap: false,\r\n axisPointer: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed'\r\n }\r\n },\r\n splitLine: { show: false },\r\n axisLine: {\r\n lineStyle: {\r\n // color: utils.getGrays()['300'],\r\n color: utils.rgbaColor('#000', 0.01),\r\n type: 'dashed'\r\n }\r\n },\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getGrays()['400'],\r\n formatter: value => {\r\n const date = new Date(value);\r\n return `${months[date.getMonth()]} ${date.getDate()}`;\r\n },\r\n margin: 15\r\n }\r\n },\r\n yAxis: {\r\n type: 'value',\r\n axisPointer: { show: false },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: 'dashed'\r\n }\r\n },\r\n boundaryGap: false,\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()['400'],\r\n margin: 15\r\n },\r\n axisTick: { show: false },\r\n axisLine: { show: false }\r\n },\r\n series: [\r\n {\r\n type: 'line',\r\n data: monthsnumber[0],\r\n lineStyle: { color: utils.getColors().primary },\r\n itemStyle: {\r\n borderColor: utils.getColors().primary,\r\n borderWidth: 2\r\n },\r\n symbol: 'circle',\r\n symbolSize: 10,\r\n smooth: false,\r\n hoverAnimation: true,\r\n areaStyle: {\r\n color: {\r\n type: 'linear',\r\n x: 0,\r\n y: 0,\r\n x2: 0,\r\n y2: 1,\r\n colorStops: [\r\n {\r\n offset: 0,\r\n color: utils.rgbaColor(utils.getColors().primary, 0.2)\r\n },\r\n {\r\n offset: 1,\r\n color: utils.rgbaColor(utils.getColors().primary, 0)\r\n }\r\n ]\r\n }\r\n }\r\n }\r\n ],\r\n grid: {\r\n right: '28px',\r\n left: '40px',\r\n bottom: '15%',\r\n top: '5%'\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n // Change chart options accordiong to the selected month\r\n const monthSelect = document.querySelector(SELECT_MONTH);\r\n\r\n if (monthSelect) {\r\n monthSelect.addEventListener('change', e => {\r\n const month = e.currentTarget.value;\r\n const data = monthsnumber[month];\r\n\r\n chart.setOption({\r\n tooltip: {\r\n formatter: params => {\r\n const { name, value } = params[0];\r\n const date = new Date(name);\r\n return `${months[month]} ${date.getDate()}, ${value}`;\r\n }\r\n },\r\n xAxis: {\r\n axisLabel: {\r\n formatter: value => {\r\n const date = new Date(value);\r\n return `${months[month]} ${date.getDate()}`;\r\n },\r\n margin: 15\r\n }\r\n },\r\n series: [{ data }]\r\n });\r\n });\r\n }\r\n }\r\n};\r\n\r\nexport default totalSalesInit;\r\n","import utils from '../../utils';\r\nimport { getPosition, echartSetOption, tooltipFormatter } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Traffic Channels */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst trafficChannelChartInit = () => {\r\n const $trafficChannels = document.querySelector('.echart-traffic-channels');\r\n\r\n if ($trafficChannels) {\r\n const userOptions = utils.getData($trafficChannels, 'options');\r\n const chart = window.echarts.init($trafficChannels);\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColors().primary,\r\n utils.rgbaColor(utils.getColors().primary, 0.8),\r\n utils.rgbaColor(utils.getColors().primary, 0.6),\r\n utils.rgbaColor(utils.getColors().primary, 0.4),\r\n utils.rgbaColor(utils.getColors().primary, 0.2)\r\n ],\r\n legend: {\r\n data: ['Display', 'Direct', 'Organic Search', 'Paid Search', 'Other'],\r\n left: 5,\r\n // bottom: 10,\r\n itemWidth: 10,\r\n itemHeight: 10,\r\n borderRadius: 0,\r\n icon: 'circle',\r\n inactiveColor: utils.getGrays()['400'],\r\n textStyle: { color: utils.getGrays()['700'] },\r\n itemGap: 20\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: utils.getPastDates(7).map(date => window.dayjs(date).format('DD MMM, YYYY')),\r\n axisLine: {\r\n show: false\r\n },\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200']\r\n }\r\n },\r\n axisTick: {\r\n show: false\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: value => window.dayjs(value).format('ddd')\r\n }\r\n },\r\n yAxis: {\r\n type: 'value',\r\n position: 'right',\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['200']\r\n }\r\n },\r\n axisLine: {\r\n show: false\r\n },\r\n axisTick: {\r\n show: false\r\n },\r\n axisLabel: {\r\n show: true,\r\n color: utils.getGrays()['600'],\r\n margin: 15\r\n }\r\n },\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n axisPointer: {\r\n type: 'none'\r\n },\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n },\r\n formatter: tooltipFormatter\r\n },\r\n\r\n series: [\r\n {\r\n name: 'Display',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [320, 302, 301, 334, 390, 330, 320]\r\n },\r\n {\r\n name: 'Direct',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [120, 132, 101, 134, 90, 230, 210]\r\n },\r\n {\r\n name: 'Organic Search',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [220, 182, 191, 234, 290, 330, 310]\r\n },\r\n {\r\n name: 'Paid Search',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [150, 212, 201, 154, 190, 330, 410]\r\n },\r\n {\r\n name: 'Other',\r\n type: 'bar',\r\n stack: 'total',\r\n data: [820, 832, 901, 934, 1290, 1330, 1320],\r\n itemStyle: {\r\n barBorderRadius: [5, 5, 0, 0]\r\n }\r\n }\r\n ],\r\n\r\n grid: {\r\n right: '50px',\r\n left: '0px',\r\n bottom: '10%',\r\n top: '15%'\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default trafficChannelChartInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n\r\nconst echartsUnresolvedTicketsInit = () => {\r\n const $unresolvedTickets = document.querySelector('.echart-unresolved-tickets');\r\n\r\n if ($unresolvedTickets) {\r\n const userOptions = utils.getData($unresolvedTickets, 'options');\r\n const chart = window.echarts.init($unresolvedTickets);\r\n const unresolvedTicketsLegend = document.querySelectorAll(\"[data-unresolved-tickets]\")\r\n let xAxisData = [\"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\", \"Sun\"];\r\n let data1 = [20, 18, 15, 20, 12, 15, 10];\r\n let data2 = [30, 20, 20, 25, 20, 15, 10];\r\n let data3 = [35, 32, 40, 50, 30, 25, 15];\r\n let data4 = [15, 25, 20, 18, 10, 15, 25];\r\n\r\n const emphasisStyle = {\r\n itemStyle: {\r\n shadowColor: utils.rgbaColor(utils.getColor('dark'), 0.3)\r\n }\r\n };\r\n\r\n const getDefaultOptions = () => ({\r\n color: [\r\n utils.getColor('primary'),\r\n utils.getColor('info'),\r\n localStorage.getItem('theme') === 'dark' ? '#229BD2' : '#73D3FE',\r\n localStorage.getItem('theme') === 'dark' ? '#195979' : '#A9E4FF',\r\n ],\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getGrays()['900']},\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n axisPointer: {\r\n type: 'none'\r\n }\r\n },\r\n legend: {\r\n data: ['Urgent', 'High', 'Medium', 'Low'],\r\n show: false\r\n },\r\n xAxis: {\r\n data: xAxisData,\r\n splitLine: { show: false, },\r\n splitArea: { show: false, },\r\n\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n margin:8,\r\n },\r\n\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: \"dashed\"\r\n }\r\n },\r\n axisTick: {\r\n show: false,\r\n }\r\n },\r\n yAxis: {\r\n splitLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['300'],\r\n type: \"dashed\"\r\n }\r\n },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n },\r\n position: \"right\"\r\n },\r\n series: [\r\n {\r\n name: 'Urgent',\r\n type: 'bar',\r\n stack: 'one',\r\n emphasis: emphasisStyle,\r\n data: data1\r\n },\r\n {\r\n name: 'High',\r\n type: 'bar',\r\n stack: 'one',\r\n emphasis: emphasisStyle,\r\n data: data2\r\n },\r\n {\r\n name: 'Medium',\r\n type: 'bar',\r\n stack: 'one',\r\n emphasis: emphasisStyle,\r\n data: data3\r\n },\r\n {\r\n name: 'Low',\r\n type: 'bar',\r\n stack: 'one',\r\n emphasis: emphasisStyle,\r\n data: data4,\r\n itemStyle: {\r\n borderRadius: [2, 2, 0, 0]\r\n },\r\n }\r\n ],\r\n\r\n barWidth: \"15px\",\r\n grid: {\r\n top: '8%',\r\n bottom: 10,\r\n left: 0,\r\n right: 2,\r\n containLabel: true\r\n }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n unresolvedTicketsLegend.forEach(el => {\r\n el.addEventListener('change', () => {\r\n chart.dispatchAction({\r\n type: 'legendToggleSelect',\r\n name: utils.getData(el, 'unresolved-tickets')\r\n })\r\n })\r\n })\r\n }\r\n};\r\n\r\nexport default echartsUnresolvedTicketsInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* User By Location Map */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst userByLocationInit = () => {\r\n const $userByLocationMap = document.querySelector(\r\n '.echart-user-by-location-map'\r\n );\r\n\r\n const data = [\r\n { name: 'Afghanistan', value: 28397 },\r\n { name: 'Angola', value: 19549 },\r\n { name: 'Albania', value: 3150 },\r\n { name: 'United Arab Emirates', value: 8441 },\r\n { name: 'Argentina', value: 40374 },\r\n { name: 'Armenia', value: 2963 },\r\n { name: 'French Southern and Antarctic Lands', value: 268 },\r\n { name: 'Australia', value: 22404 },\r\n { name: 'Austria', value: 8401 },\r\n { name: 'Azerbaijan', value: 9094 },\r\n { name: 'Burundi', value: 9232 },\r\n { name: 'Belgium', value: 10941 },\r\n { name: 'Benin', value: 9509 },\r\n { name: 'Burkina Faso', value: 15540 },\r\n { name: 'Bangladesh', value: 151125 },\r\n { name: 'Bulgaria', value: 7389 },\r\n { name: 'The Bahamas', value: 66402 },\r\n { name: 'Bosnia and Herzegovina', value: 3845 },\r\n { name: 'Belarus', value: 9491 },\r\n { name: 'Belize', value: 308 },\r\n { name: 'Bermuda', value: 64 },\r\n { name: 'Bolivia', value: 716 },\r\n { name: 'Brazil', value: 195210 },\r\n { name: 'Brunei', value: 27 },\r\n { name: 'Bhutan', value: 716 },\r\n { name: 'Botswana', value: 1969 },\r\n { name: 'Central African Rep.', value: 4349 },\r\n { name: 'Canada', value: 34126 },\r\n { name: 'Switzerland', value: 7830 },\r\n { name: 'Chile', value: 17150 },\r\n { name: 'China', value: 1359821 },\r\n { name: \"Côte d'Ivoire\", value: 60508 },\r\n { name: 'Cameroon', value: 20624 },\r\n { name: 'Dem. Rep. Congo', value: 62191 },\r\n { name: 'Congo', value: 3573 },\r\n { name: 'Colombia', value: 46444 },\r\n { name: 'Costa Rica', value: 4669 },\r\n { name: 'Cuba', value: 11281 },\r\n { name: 'Northern Cyprus', value: 1 },\r\n { name: 'Cyprus', value: 1103 },\r\n { name: 'Czech Republic', value: 10553 },\r\n { name: 'Germany', value: 83017 },\r\n { name: 'Djibouti', value: 834 },\r\n { name: 'Denmark', value: 5550 },\r\n { name: 'Dominican Republic', value: 10016 },\r\n { name: 'Algeria', value: 37062 },\r\n { name: 'Ecuador', value: 15001 },\r\n { name: 'Egypt', value: 78075 },\r\n { name: 'Eritrea', value: 5741 },\r\n { name: 'Spain', value: 46182 },\r\n { name: 'Estonia', value: 1298 },\r\n { name: 'Ethiopia', value: 87095 },\r\n { name: 'Finland', value: 5367 },\r\n { name: 'Fiji', value: 860 },\r\n { name: 'Falkland Islands', value: 49 },\r\n { name: 'France', value: 63230 },\r\n { name: 'Gabon', value: 1556 },\r\n { name: 'United Kingdom', value: 62066 },\r\n { name: 'Georgia', value: 4388 },\r\n { name: 'Ghana', value: 24262 },\r\n { name: 'Eq. Guinea', value: 10876 },\r\n { name: 'Guinea', value: 10876 },\r\n { name: 'Gambia', value: 1680 },\r\n { name: 'Guinea Bissau', value: 10876 },\r\n { name: 'Equatorial Guinea', value: 696 },\r\n { name: 'Greece', value: 11109 },\r\n { name: 'Greenland', value: 56 },\r\n { name: 'Guatemala', value: 14341 },\r\n { name: 'French Guiana', value: 231 },\r\n { name: 'Guyana', value: 786 },\r\n { name: 'Honduras', value: 7621 },\r\n { name: 'Croatia', value: 4338 },\r\n { name: 'Haiti', value: 9896 },\r\n { name: 'Hungary', value: 10014 },\r\n { name: 'Indonesia', value: 240676 },\r\n { name: 'India', value: 1205624 },\r\n { name: 'Ireland', value: 4467 },\r\n { name: 'Iran', value: 240676 },\r\n { name: 'Iraq', value: 30962 },\r\n { name: 'Iceland', value: 318 },\r\n { name: 'Israel', value: 7420 },\r\n { name: 'Italy', value: 60508 },\r\n { name: 'Jamaica', value: 2741 },\r\n { name: 'Jordan', value: 6454 },\r\n { name: 'Japan', value: 127352 },\r\n { name: 'Kazakhstan', value: 15921 },\r\n { name: 'Kenya', value: 40909 },\r\n { name: 'Kyrgyzstan', value: 5334 },\r\n { name: 'Cambodia', value: 14364 },\r\n { name: 'South Korea', value: 51452 },\r\n { name: 'Kosovo', value: 97 },\r\n { name: 'Kuwait', value: 2991 },\r\n { name: 'Laos', value: 6395 },\r\n { name: 'Lebanon', value: 4341 },\r\n { name: 'Liberia', value: 3957 },\r\n { name: 'Libya', value: 6040 },\r\n { name: 'Sri Lanka', value: 20758 },\r\n { name: 'Lesotho', value: 2008 },\r\n { name: 'Lithuania', value: 3068 },\r\n { name: 'Luxembourg', value: 507 },\r\n { name: 'Latvia', value: 2090 },\r\n { name: 'Morocco', value: 31642 },\r\n { name: 'Moldova', value: 103 },\r\n { name: 'Madagascar', value: 21079 },\r\n { name: 'Mexico', value: 117886 },\r\n { name: 'Macedonia', value: 507 },\r\n { name: 'Mali', value: 13985 },\r\n { name: 'Myanmar', value: 51931 },\r\n { name: 'Montenegro', value: 620 },\r\n { name: 'Mongolia', value: 2712 },\r\n { name: 'Mozambique', value: 23967 },\r\n { name: 'Mauritania', value: 3609 },\r\n { name: 'Malawi', value: 15013 },\r\n { name: 'Malaysia', value: 28275 },\r\n { name: 'Namibia', value: 2178 },\r\n { name: 'New Caledonia', value: 246 },\r\n { name: 'Niger', value: 15893 },\r\n { name: 'Nigeria', value: 159707 },\r\n { name: 'Nicaragua', value: 5822 },\r\n { name: 'Netherlands', value: 16615 },\r\n { name: 'Norway', value: 4891 },\r\n { name: 'Nepal', value: 26846 },\r\n { name: 'New Zealand', value: 4368 },\r\n { name: 'Oman', value: 2802 },\r\n { name: 'Pakistan', value: 173149 },\r\n { name: 'Panama', value: 3678 },\r\n { name: 'Peru', value: 29262 },\r\n { name: 'Philippines', value: 93444 },\r\n { name: 'Papua New Guinea', value: 6858 },\r\n { name: 'Poland', value: 38198 },\r\n { name: 'Puerto Rico', value: 3709 },\r\n { name: 'North Korea', value: 1 },\r\n { name: 'Portugal', value: 10589 },\r\n { name: 'Paraguay', value: 6459 },\r\n { name: 'Qatar', value: 1749 },\r\n { name: 'Romania', value: 21861 },\r\n { name: 'Russia', value: 21861 },\r\n { name: 'Rwanda', value: 10836 },\r\n { name: 'Western Sahara', value: 514 },\r\n { name: 'Saudi Arabia', value: 27258 },\r\n { name: 'Sudan', value: 35652 },\r\n { name: 'S. Sudan', value: 9940 },\r\n { name: 'Senegal', value: 12950 },\r\n { name: 'Solomon Islands', value: 526 },\r\n { name: 'Sierra Leone', value: 5751 },\r\n { name: 'El Salvador', value: 6218 },\r\n { name: 'Somaliland', value: 9636 },\r\n { name: 'Somalia', value: 9636 },\r\n { name: 'Republic of Serbia', value: 3573 },\r\n { name: 'Suriname', value: 524 },\r\n { name: 'Slovakia', value: 5433 },\r\n { name: 'Slovenia', value: 2054 },\r\n { name: 'Sweden', value: 9382 },\r\n { name: 'Swaziland', value: 1193 },\r\n { name: 'Syria', value: 7830 },\r\n { name: 'Chad', value: 11720 },\r\n { name: 'Togo', value: 6306 },\r\n { name: 'Thailand', value: 66402 },\r\n { name: 'Tajikistan', value: 7627 },\r\n { name: 'Turkmenistan', value: 5041 },\r\n { name: 'East Timor', value: 10016 },\r\n { name: 'Trinidad and Tobago', value: 1328 },\r\n { name: 'Tunisia', value: 10631 },\r\n { name: 'Turkey', value: 72137 },\r\n { name: 'Tanzania', value: 44973 },\r\n { name: 'Uganda', value: 33987 },\r\n { name: 'Ukraine', value: 46050 },\r\n { name: 'Uruguay', value: 3371 },\r\n { name: 'United States', value: 2526 },\r\n { name: 'Uzbekistan', value: 27769 },\r\n { name: 'Venezuela', value: 236 },\r\n { name: 'Vietnam', value: 89047 },\r\n { name: 'Vanuatu', value: 236 },\r\n { name: 'West Bank', value: 13 },\r\n { name: 'Yemen', value: 22763 },\r\n { name: 'South Africa', value: 51452 },\r\n { name: 'Zambia', value: 13216 },\r\n { name: 'Zimbabwe', value: 13076 },\r\n ];\r\n\r\n const maxZoomLevel = 5;\r\n const minZoomLevel = 1;\r\n\r\n if ($userByLocationMap) {\r\n const userOptions = utils.getData($userByLocationMap, 'options');\r\n const chart = window.echarts.init($userByLocationMap);\r\n\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: 'item',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n transitionDuration: 0,\r\n formatter: (params) =>\r\n `${params.data?.name} : ${params.data?.value}`,\r\n },\r\n\r\n visualMap: {\r\n show: false,\r\n min: 800,\r\n max: 50000,\r\n inRange: {\r\n color: [\r\n utils.getColors().primary,\r\n utils.rgbaColor(utils.getColors().primary, 0.8),\r\n utils.rgbaColor(utils.getColors().primary, 0.6),\r\n utils.rgbaColor(utils.getColors().primary, 0.4),\r\n utils.rgbaColor(utils.getColors().primary, 0.2),\r\n ].reverse(),\r\n },\r\n },\r\n series: [\r\n {\r\n type: 'map',\r\n map: 'world',\r\n data,\r\n roam: 'move',\r\n\r\n scaleLimit: {\r\n min: minZoomLevel,\r\n max: maxZoomLevel,\r\n },\r\n left: 0,\r\n right: 0,\r\n label: {\r\n show: false,\r\n },\r\n itemStyle: {\r\n borderColor: utils.getGrays()['300'],\r\n },\r\n emphasis: {\r\n label: {\r\n show: false,\r\n },\r\n itemStyle: {\r\n areaColor: utils.getColor('warning'),\r\n },\r\n },\r\n },\r\n ],\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n\r\n let zoomLevel = 1;\r\n\r\n document\r\n .querySelector('.user-by-location-map-zoom')\r\n ?.addEventListener('click', () => {\r\n if (zoomLevel < maxZoomLevel) {\r\n zoomLevel += 1;\r\n }\r\n chart.setOption({\r\n series: {\r\n zoom: zoomLevel,\r\n },\r\n });\r\n });\r\n\r\n document\r\n .querySelector('.user-by-location-map-zoomOut')\r\n ?.addEventListener('click', () => {\r\n if (zoomLevel > minZoomLevel) {\r\n zoomLevel -= 1;\r\n }\r\n chart.setOption({\r\n series: {\r\n zoom: zoomLevel,\r\n },\r\n });\r\n });\r\n }\r\n};\r\n\r\nexport default userByLocationInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Echarts Users By Time */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst usersByTimeChartInit = () => {\r\n const $echartUsersByTimeChart = document.querySelector(\r\n '.echart-users-by-time'\r\n );\r\n\r\n const hours = [\r\n '12 AM',\r\n '1 AM',\r\n '2 AM',\r\n '3 AM',\r\n '4 AM',\r\n '5 AM',\r\n '6 AM',\r\n '7 AM',\r\n '8 AM',\r\n '9 AM',\r\n '10 AM',\r\n '11 AM',\r\n '12 PM',\r\n '1 PM',\r\n '2 PM',\r\n '3 PM',\r\n '4 PM',\r\n '5 PM',\r\n '6 PM',\r\n '7 PM',\r\n '8 PM',\r\n '9 PM',\r\n '10 PM',\r\n '11 PM',\r\n ];\r\n\r\n const data = [];\r\n for (let i = 0; i < 24; i += 1) {\r\n for (let j = 0; j < 7; j += 1) {\r\n data.push([j, i, utils.getRandomNumber(20, 300)]);\r\n }\r\n }\r\n\r\n const tooltipFormatter = params => {\r\n return `
    \r\n

    ${window\r\n .dayjs(params.name)\r\n .format('MMM DD, YYYY')}

    \r\n
    \r\n

    \r\n ${window\r\n .dayjs()\r\n .hour(params.data[1])\r\n .format('hA')} : ${\r\n params.data[2]\r\n }\r\n

    \r\n
    \r\n
    `;\r\n };\r\n\r\n if ($echartUsersByTimeChart) {\r\n const userOptions = utils.getData($echartUsersByTimeChart, 'options');\r\n const chart = window.echarts.init($echartUsersByTimeChart);\r\n\r\n const getDefaultOptions = () => ({\r\n gradientColor: [utils.getColor('info'), utils.getColor('primary')],\r\n tooltip: {\r\n position: 'top',\r\n padding: [7, 10],\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n formatter: tooltipFormatter,\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: utils.getPastDates(7),\r\n splitArea: {\r\n show: true,\r\n },\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n formatter: value => window.dayjs(value).format('ddd'),\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['400'],\r\n },\r\n },\r\n },\r\n yAxis: {\r\n position: 'right',\r\n type: 'category',\r\n inverse: true,\r\n data: hours,\r\n splitArea: {\r\n show: true,\r\n },\r\n axisTick: { show: false },\r\n axisLabel: {\r\n color: utils.getGrays()['600'],\r\n margin: 20,\r\n padding: [10, 0, 0, 0],\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n color: utils.getGrays()['400'],\r\n },\r\n },\r\n },\r\n visualMap: {\r\n type: 'piecewise',\r\n orient: 'horizontal',\r\n left: 'left',\r\n bottom: '3%',\r\n itemSymbol: 'diamond',\r\n itemWidth: '10px',\r\n itemHeight: '10px',\r\n min: 20,\r\n max: 300,\r\n splitNumber: 4,\r\n textGap: 5,\r\n textStyle: {\r\n color: utils.getGrays()['600'],\r\n fontWeight: 500,\r\n },\r\n },\r\n series: [\r\n {\r\n name: 'Users By Time',\r\n type: 'heatmap',\r\n data: data,\r\n label: {\r\n show: false,\r\n },\r\n itemStyle: {\r\n borderColor: utils.getColor('white'),\r\n borderWidth: 3,\r\n },\r\n emphasis: {\r\n itemStyle: {\r\n shadowBlur: 3,\r\n shadowColor: utils.rgbaColor(utils.getGrays()['black'], 0.5),\r\n },\r\n },\r\n },\r\n ],\r\n grid: { right: '60px', left: '0px', bottom: '20%', top: '0%' },\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default usersByTimeChartInit;\r\n","import utils from '../../utils';\r\nimport { echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Bandwidth Saved */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst weeklyGoalsInit = () => {\r\n const $echartsBandwidthSaved = document.querySelector(\r\n '.echart-weekly-goals-lms'\r\n );\r\n\r\n if ($echartsBandwidthSaved) {\r\n const userOptions = utils.getData($echartsBandwidthSaved, 'options');\r\n const chart = window.echarts.init($echartsBandwidthSaved);\r\n\r\n const getDefaultOptions = () => ({\r\n series: [\r\n {\r\n type: 'gauge',\r\n startAngle: 90,\r\n endAngle: -270,\r\n radius: '85%',\r\n pointer: {\r\n show: false,\r\n },\r\n center: ['50%', '50%'],\r\n progress: {\r\n show: true,\r\n overlap: false,\r\n roundCap: true,\r\n clip: false,\r\n itemStyle: {\r\n color: utils.getColor('info'),\r\n },\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n width: 8,\r\n color: [[1, utils.getColor('gray-200')]],\r\n },\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisTick: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n data: [79],\r\n detail: {\r\n show: false,\r\n },\r\n animationDuration: 2000,\r\n },\r\n {\r\n type: 'gauge',\r\n startAngle: 90,\r\n endAngle: -270,\r\n radius: '70%',\r\n pointer: {\r\n show: false,\r\n },\r\n center: ['50%', '50%'],\r\n progress: {\r\n show: true,\r\n overlap: false,\r\n roundCap: true,\r\n clip: false,\r\n itemStyle: {\r\n color: utils.getColor('primary'),\r\n },\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n width: 8,\r\n color: [[1, utils.getColor('gray-200')]],\r\n },\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisTick: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n data: [85],\r\n detail: {\r\n show: false,\r\n },\r\n animationDuration: 2000,\r\n },\r\n {\r\n type: 'gauge',\r\n startAngle: 90,\r\n endAngle: -270,\r\n radius: '55%',\r\n pointer: {\r\n show: false,\r\n },\r\n center: ['50%', '50%'],\r\n progress: {\r\n show: true,\r\n overlap: false,\r\n roundCap: true,\r\n clip: false,\r\n itemStyle: {\r\n color: utils.getColor('success'),\r\n },\r\n },\r\n axisLine: {\r\n lineStyle: {\r\n width: 8,\r\n color: [[1, utils.getColor('gray-200')]],\r\n },\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisTick: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n data: [70],\r\n detail: {\r\n show: false,\r\n },\r\n animationDuration: 2000,\r\n },\r\n ],\r\n });\r\n\r\n const initChart = () => {\r\n if (utils.isScrolledIntoView($echartsBandwidthSaved)) {\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n window.removeEventListener('scroll', initChart);\r\n }\r\n };\r\n\r\n window.addEventListener('scroll', initChart);\r\n }\r\n};\r\n\r\nexport default weeklyGoalsInit;\r\n","/* eslint-disable */\r\nimport utils from '../../utils';\r\nimport { getPosition, echartSetOption } from './echarts-utils';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Weekly Sales */\r\n/* -------------------------------------------------------------------------- */\r\n\r\nconst weeklySalesInit = () => {\r\n const ECHART_BAR_WEEKLY_SALES = '.echart-bar-weekly-sales';\r\n const $echartBarWeeklySales = document.querySelector(ECHART_BAR_WEEKLY_SALES);\r\n\r\n if ($echartBarWeeklySales) {\r\n // Get options from data attribute\r\n const userOptions = utils.getData($echartBarWeeklySales, 'options');\r\n\r\n const data = [120, 200, 150, 80, 70, 110, 120];\r\n\r\n // Max value of data\r\n const yMax = Math.max(...data);\r\n\r\n // const dataBackground = data.map(() => yMax);\r\n const chart = window.echarts.init($echartBarWeeklySales);\r\n\r\n // Default options\r\n const getDefaultOptions = () => ({\r\n tooltip: {\r\n trigger: 'axis',\r\n padding: [7, 10],\r\n formatter: '{b0} : {c0}',\r\n transitionDuration: 0,\r\n backgroundColor: utils.getGrays()['100'],\r\n borderColor: utils.getGrays()['300'],\r\n textStyle: { color: utils.getColors().dark },\r\n borderWidth: 1,\r\n position(pos, params, dom, rect, size) {\r\n return getPosition(pos, params, dom, rect, size);\r\n }\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\r\n boundaryGap: false,\r\n axisLine: { show: false },\r\n axisLabel: { show: false },\r\n axisTick: { show: false },\r\n axisPointer: { type: 'none' }\r\n },\r\n yAxis: {\r\n type: 'value',\r\n splitLine: { show: false },\r\n axisLine: { show: false },\r\n axisLabel: { show: false },\r\n axisTick: { show: false },\r\n axisPointer: { type: 'none' }\r\n },\r\n series: [\r\n {\r\n type: 'bar',\r\n showBackground: true,\r\n backgroundStyle: {\r\n borderRadius: 10\r\n },\r\n barWidth: '5px',\r\n itemStyle: {\r\n barBorderRadius: 10,\r\n color: utils.getColors().primary\r\n },\r\n data,\r\n z: 10,\r\n emphasis: { itemStyle: { color: utils.getColors().primary } }\r\n }\r\n ],\r\n grid: { right: 5, left: 10, top: 0, bottom: 0 }\r\n });\r\n\r\n echartSetOption(chart, userOptions, getDefaultOptions);\r\n }\r\n};\r\n\r\nexport default weeklySalesInit;\r\n","import { docReady } from './utils';\r\nimport handleNavbarVerticalCollapsed from './navbar-vertical';\r\nimport detectorInit from './detector';\r\nimport tooltipInit from './tooltip';\r\nimport popoverInit from './popover';\r\nimport navbarTopDropShadow from './navbar-top';\r\nimport toastInit from './toast';\r\nimport progressAnimationToggle from './progress';\r\nimport glightboxInit from './glightbox';\r\nimport plyrInit from './plyr';\r\nimport initMap from './googleMap';\r\nimport dropzoneInit from './dropzone';\r\nimport choicesInit from './choices';\r\nimport barChartInit from './charts/chartjs/chart-bar';\r\nimport formValidationInit from './form-validation';\r\nimport leafletActiveUserInit from './leaflet-active-user';\r\nimport countupInit from './countup';\r\nimport copyLink from './copy-link';\r\nimport typedTextInit from './typed';\r\nimport navbarDarkenOnScroll from './navbar-darken-on-scroll';\r\nimport tinymceInit from './tinymce';\r\nimport bulkSelectInit from './bulk-select';\r\nimport quantityInit from './quantity';\r\nimport navbarComboInit from './navbar-combo';\r\nimport listInit from './list';\r\nimport chatInit from './chat';\r\nimport draggableInit from './draggable';\r\nimport kanbanInit from './kanban';\r\nimport { fullCalendarInit } from './fullcalendar';\r\nimport appCalendarInit from './calendar/index';\r\nimport managementCalendarInit from './calendar/management-calendar';\r\nimport lottieInit from './lottie';\r\nimport wizardInit from './wizard';\r\nimport swiperInit from './swiper';\r\nimport ratingInit from './rater';\r\nimport searchInit from './search';\r\nimport cookieNoticeInit from './cookie-notice';\r\nimport themeControl from './theme-control';\r\nimport dropdownOnHover from './dropdown-on-hover';\r\nimport productShareDoughnutInit from './charts/chartjs/product-share-doughnut';\r\nimport chartHalfDoughnutInit from './charts/chartjs/chart-half-doughnut';\r\nimport totalSalesEcommerce from './charts/echarts/total-sales-ecommerce';\r\nimport avgEnrollmentRateInit from './charts/echarts/average-enrollment-rate';\r\nimport salesByPosLocationInit from './charts/echarts/sales-by-pos-location';\r\nimport returningCustomerRateInit from './charts/echarts/returning-customer-rate';\r\nimport topProductsInit from './charts/echarts/top-products';\r\nimport courseEnrollmentsInit from './charts/echarts/course-enrollments';\r\nimport marketShareEcommerceInit from './charts/echarts/market-share-ecommerce';\r\nimport totalSalesInit from './charts/echarts/total-sales';\r\nimport weeklySalesInit from './charts/echarts/weekly-sales';\r\nimport marketShareInit from './charts/echarts/market-share';\r\nimport weeklyGoalsInit from './charts/echarts/weekly-goals-lms';\r\nimport totalOrderInit from './charts/echarts/total-order';\r\nimport candleChartInit from './charts/echarts/candle-chart';\r\nimport grossRevenueChartInit from './charts/echarts/gross-revenue';\r\nimport browsedCoursesInit from './charts/echarts/browsed-courses';\r\nimport courseStatusInit from './charts/echarts/course-status';\r\nimport assignmentScoresInit from './charts/echarts/assignment-scores';\r\nimport scrollbarInit from './scrollbar';\r\nimport iconCopiedInit from './icons';\r\nimport reportForThisWeekInit from './charts/echarts/report-for-this-week';\r\nimport basicEchartsInit from './charts/echarts/basic-echarts';\r\nimport trendingKeywordsInit from './charts/d3/trending-keywords';\r\nimport D3PackedBubbleInit from './charts/d3/d3-packed-bubble';\r\nimport chartScatter from './charts/chartjs/chart-scatter';\r\nimport chartDoughnut from './charts/chartjs/chart-doughnut';\r\nimport chartPie from './charts/chartjs/chart-pie';\r\nimport chartPolar from './charts/chartjs/chart-polar';\r\nimport chartRadar from './charts/chartjs/chart-radar';\r\nimport chartCombo from './charts/chartjs/chart-combo';\r\nimport chartBubble from './charts/chartjs/chart-bubble';\r\nimport dropdownMenuInit from './dropdown-menu';\r\nimport audienceChartInit from './charts/echarts/audience';\r\nimport sessionByBrowserChartInit from './charts/echarts/session-by-browser';\r\nimport sessionByCountryChartInit from './charts/echarts/session-by-country';\r\nimport activeUsersChartReportInit from './charts/echarts/active-users-report';\r\nimport trafficChannelChartInit from './charts/echarts/traffic-channels';\r\nimport bounceRateChartInit from './charts/echarts/bounce-rate';\r\nimport usersByTimeChartInit from './charts/echarts/users-by-time';\r\nimport sessionByCountryMapInit from './charts/echarts/session-by-country-map';\r\nimport mostLeadsInit from './charts/echarts/most-leads';\r\nimport closedVsGoalInit from './charts/echarts/closed-vs-goal';\r\nimport leadConversionInit from './charts/echarts/lead-conversion';\r\nimport dealStorageFunnelInit from './charts/echarts/deal-storage-funnel';\r\nimport revenueChartInit from './charts/echarts/crm-revenue';\r\nimport locationBySessionInit from './charts/echarts/location-by-session-crm';\r\nimport realTimeUsersChartInit from './charts/echarts/real-time-users';\r\nimport linePaymentChartInit from './charts/echarts/line-payment';\r\nimport chartLine from './charts/chartjs/chart-line';\r\nimport bandwidthSavedInit from './charts/echarts/bandwidth-saved';\r\nimport marketingExpensesInit from './charts/echarts/marketing-expenses';\r\nimport treeviewInit from './treeview';\r\nimport bottomBarInit from './bottom-bar';\r\nimport scrollInit from './scroll';\r\nimport echartsUnresolvedTicketsInit from './charts/echarts/unresolved-tickets';\r\nimport echartsNumberOfTicketsInit from './charts/echarts/number-of-tickets';\r\nimport echartsCustomerSatisfactionInit from './charts/echarts/customer-satisfaction';\r\nimport echartsDistributionOfPerformanceInit from './charts/echarts/distribution-of-performance';\r\nimport echartsSatisfactionSurveyInit from './charts/echarts/satisfaction-survey';\r\nimport echartsReceivedTicketsInit from './charts/echarts/received-tickets';\r\nimport topCustomersChartInit from './charts/echarts/top-customers';\r\nimport ticketVolumeChartInit from './charts/echarts/ticket-volume';\r\nimport echartTicketPriority from './charts/echarts/ticket-priority';\r\nimport hideOnCollapseInit from './hide-on-collapse';\r\nimport userByLocationInit from './charts/echarts/user-by-location-lms';\r\nimport dataTablesInit from './datatables';\r\nimport select2Init from './select2';\r\nimport inputmaskInit from './inputmask';\r\nimport unresolvedTicketsTabInit from './unresolved-tickets-tab';\r\nimport picmoInit from './picmo';\r\nimport nouisliderInit from './nouislider';\r\nimport advanceAjaxTableInit from './advance-ajax-table';\r\n\r\n/* -------------------------------------------------------------------------- */\r\n/* Theme Initialization */\r\n/* -------------------------------------------------------------------------- */\r\ndocReady(detectorInit);\r\ndocReady(handleNavbarVerticalCollapsed);\r\ndocReady(totalOrderInit);\r\ndocReady(weeklySalesInit);\r\ndocReady(marketShareInit);\r\ndocReady(totalSalesInit);\r\ndocReady(topProductsInit);\r\ndocReady(navbarTopDropShadow);\r\ndocReady(tooltipInit);\r\ndocReady(popoverInit);\r\ndocReady(toastInit);\r\ndocReady(progressAnimationToggle);\r\ndocReady(glightboxInit);\r\ndocReady(plyrInit);\r\ndocReady(initMap);\r\ndocReady(dropzoneInit);\r\ndocReady(choicesInit);\r\ndocReady(formValidationInit);\r\ndocReady(barChartInit);\r\ndocReady(leafletActiveUserInit);\r\ndocReady(countupInit);\r\ndocReady(copyLink);\r\ndocReady(navbarDarkenOnScroll);\r\ndocReady(typedTextInit);\r\ndocReady(tinymceInit);\r\ndocReady(chatInit);\r\ndocReady(quantityInit);\r\ndocReady(navbarComboInit);\r\ndocReady(swiperInit);\r\ndocReady(ratingInit);\r\ndocReady(draggableInit);\r\ndocReady(kanbanInit);\r\ndocReady(fullCalendarInit);\r\ndocReady(appCalendarInit);\r\ndocReady(managementCalendarInit);\r\ndocReady(lottieInit);\r\ndocReady(wizardInit);\r\ndocReady(searchInit);\r\ndocReady(cookieNoticeInit);\r\ndocReady(themeControl);\r\ndocReady(dropdownOnHover);\r\ndocReady(marketShareEcommerceInit);\r\ndocReady(productShareDoughnutInit);\r\ndocReady(totalSalesEcommerce);\r\ndocReady(avgEnrollmentRateInit);\r\ndocReady(bandwidthSavedInit);\r\ndocReady(salesByPosLocationInit);\r\ndocReady(returningCustomerRateInit);\r\ndocReady(candleChartInit);\r\ndocReady(grossRevenueChartInit);\r\ndocReady(scrollbarInit);\r\ndocReady(iconCopiedInit);\r\ndocReady(reportForThisWeekInit);\r\ndocReady(basicEchartsInit);\r\ndocReady(chartScatter);\r\ndocReady(chartDoughnut);\r\ndocReady(chartPie);\r\ndocReady(chartPolar);\r\ndocReady(chartRadar);\r\ndocReady(chartCombo);\r\ndocReady(dropdownMenuInit);\r\ndocReady(audienceChartInit);\r\ndocReady(sessionByBrowserChartInit);\r\ndocReady(sessionByCountryChartInit);\r\ndocReady(activeUsersChartReportInit);\r\ndocReady(trafficChannelChartInit);\r\ndocReady(bounceRateChartInit);\r\ndocReady(usersByTimeChartInit);\r\ndocReady(sessionByCountryMapInit);\r\ndocReady(mostLeadsInit);\r\ndocReady(closedVsGoalInit);\r\ndocReady(leadConversionInit);\r\ndocReady(dealStorageFunnelInit);\r\ndocReady(revenueChartInit);\r\ndocReady(locationBySessionInit);\r\ndocReady(realTimeUsersChartInit);\r\ndocReady(linePaymentChartInit);\r\ndocReady(chartBubble);\r\ndocReady(chartLine);\r\ndocReady(treeviewInit);\r\ndocReady(scrollInit);\r\ndocReady(echartsUnresolvedTicketsInit);\r\ndocReady(echartsNumberOfTicketsInit);\r\ndocReady(echartsCustomerSatisfactionInit);\r\ndocReady(echartsDistributionOfPerformanceInit);\r\ndocReady(echartsSatisfactionSurveyInit);\r\ndocReady(echartsReceivedTicketsInit);\r\ndocReady(topCustomersChartInit);\r\ndocReady(ticketVolumeChartInit);\r\ndocReady(echartTicketPriority);\r\ndocReady(userByLocationInit);\r\ndocReady(courseEnrollmentsInit);\r\ndocReady(weeklyGoalsInit);\r\ndocReady(assignmentScoresInit);\r\ndocReady(browsedCoursesInit);\r\ndocReady(courseStatusInit);\r\ndocReady(bottomBarInit);\r\ndocReady(marketingExpensesInit);\r\ndocReady(chartHalfDoughnutInit);\r\ndocReady(trendingKeywordsInit);\r\ndocReady(D3PackedBubbleInit);\r\ndocReady(dataTablesInit);\r\ndocReady(select2Init);\r\ndocReady(hideOnCollapseInit);\r\ndocReady(unresolvedTicketsTabInit);\r\ndocReady(inputmaskInit);\r\ndocReady(picmoInit);\r\ndocReady(nouisliderInit);\r\ndocReady(bulkSelectInit);\r\ndocReady(advanceAjaxTableInit);\r\ndocReady(listInit);\r\n"]}