\n tokenType: \"Bearer\",\n\n // ** Value of this property will be used as key to store JWT token in storage\n storageTokenKeyName: \"accessToken\",\n storageRefreshTokenKeyName: \"refreshToken\",\n};\n","import axios from \"axios\";\nimport jwtDefaultConfig from \"./jwtDefaultConfig\";\n\nexport default class JwtService {\n // ** jwtConfig <= Will be used by this service\n jwtConfig = { ...jwtDefaultConfig };\n\n // ** For Refreshing Token\n isAlreadyFetchingAccessToken = false;\n\n // ** For Refreshing Token\n subscribers = [];\n\n constructor(jwtOverrideConfig) {\n this.jwtConfig = { ...this.jwtConfig, ...jwtOverrideConfig };\n\n // ** Request Interceptor\n axios.interceptors.request.use(\n (config) => {\n // ** Get token from localStorage\n const accessToken = this.getToken();\n\n // ** If token is present add it to request's Authorization Header\n if (accessToken) {\n // ** eslint-disable-next-line no-param-reassign\n config.headers.Authorization = `${this.jwtConfig.tokenType} ${accessToken}`;\n }\n return config;\n },\n (error) => Promise.reject(error)\n );\n\n // ** Add request/response interceptor\n axios.interceptors.response.use(\n (response) => response,\n (error) => {\n // ** const { config, response: { status } } = error\n const { config, response } = error;\n const originalRequest = config;\n\n // ** if (status === 401) {\n if (response && response.status === 401) {\n if (!this.isAlreadyFetchingAccessToken) {\n this.isAlreadyFetchingAccessToken = true;\n this.refreshToken().then((r) => {\n this.isAlreadyFetchingAccessToken = false;\n\n // ** Update accessToken in localStorage\n this.setToken(r.data.accessToken);\n this.setRefreshToken(r.data.refreshToken);\n\n this.onAccessTokenFetched(r.data.accessToken);\n });\n }\n const retryOriginalRequest = new Promise((resolve) => {\n this.addSubscriber((accessToken) => {\n // ** Make sure to assign accessToken according to your response.\n // ** Check: https://pixinvent.ticksy.com/ticket/2413870\n // ** Change Authorization header\n originalRequest.headers.Authorization = `${this.jwtConfig.tokenType} ${accessToken}`;\n resolve(this.axios(originalRequest));\n });\n });\n return retryOriginalRequest;\n }\n return Promise.reject(error);\n }\n );\n }\n\n onAccessTokenFetched(accessToken) {\n this.subscribers = this.subscribers.filter((callback) =>\n callback(accessToken)\n );\n }\n\n addSubscriber(callback) {\n this.subscribers.push(callback);\n }\n\n getToken() {\n return localStorage.getItem(this.jwtConfig.storageTokenKeyName);\n }\n\n getRefreshToken() {\n return localStorage.getItem(this.jwtConfig.storageRefreshTokenKeyName);\n }\n\n setToken(value) {\n localStorage.setItem(this.jwtConfig.storageTokenKeyName, value);\n }\n\n setRefreshToken(value) {\n localStorage.setItem(this.jwtConfig.storageRefreshTokenKeyName, value);\n }\n\n login(...args) {\n return axios.post(this.jwtConfig.loginEndpoint, ...args);\n }\n\n register(...args) {\n return axios.post(this.jwtConfig.registerEndpoint, ...args);\n }\n\n refreshToken() {\n return axios.post(this.jwtConfig.refreshEndpoint, {\n refreshToken: this.getRefreshToken(),\n });\n }\n}\n","// ** Core JWT Import\nimport useJwt from \"@src/@core/auth/jwt/useJwt\";\n\nconst { jwt } = useJwt({});\n\nexport default jwt;\n","// ** JWT Service Import\nimport JwtService from \"./jwtService\";\n\n// ** Export Service as useJwt\nexport default function useJwt(jwtOverrideConfig) {\n const jwt = new JwtService(jwtOverrideConfig);\n\n return {\n jwt,\n };\n}\n","// ** Redux Imports\nimport { createSlice } from \"@reduxjs/toolkit\";\nimport Cookies from \"js-cookie\";\n\n// ** UseJWT import to get config\nimport useJwt from \"@src/auth/jwt/useJwt\";\n\nimport mixpanel from \"mixpanel-browser\";\nimport { MIXPANEL_USER_SESSION } from \"../mixpanel/mixpanel_constants\";\n\nconst config = useJwt.jwtConfig;\n\nconst initialUser = () => {\n const item = window.localStorage.getItem(\"userData\");\n //** Parse stored json or if none return initialValue\n return item ? JSON.parse(item) : {};\n};\n\nexport const authSlice = createSlice({\n name: \"authentication\",\n initialState: {\n userData: initialUser(),\n },\n reducers: {\n handleLogin: (state, action) => {\n state.userData = action.payload;\n state[config.storageTokenKeyName] =\n action.payload[config.storageTokenKeyName];\n state[config.storageRefreshTokenKeyName] =\n action.payload[config.storageRefreshTokenKeyName];\n // console.log(state.config.storageRefreshTokenKeyName);\n // localStorage.setItem('userData', JSON.stringify(action.payload))\n // localStorage.setItem(config.storageTokenKeyName, JSON.stringify(action.payload.accessToken))\n // localStorage.setItem(config.storageRefreshTokenKeyName, JSON.stringify(action.payload.refreshToken))\n\n // Mixpanel Tracking\n const currentUser = action.payload;\n mixpanel.identify(currentUser._id);\n mixpanel.people.set({\n $email: currentUser.email,\n });\n mixpanel.track(MIXPANEL_USER_SESSION.USER_LOGIN);\n },\n handleLogout: (state) => {\n state.userData = {};\n state[config.storageTokenKeyName] = null;\n state[config.storageRefreshTokenKeyName] = null;\n // ** Remove user, accessToken & refreshToken from localStorage\n // localStorage.removeItem('userData')\n // localStorage.removeItem('userDetails')\n // localStorage.removeItem(config.storageTokenKeyName)\n // localStorage.removeItem(config.storageRefreshTokenKeyName)\n\n //Vyrill Storage\n Cookies.remove(\"bId\");\n Cookies.remove(\"uId\");\n Cookies.remove(\"jwt\");\n localStorage.removeItem(\"session\");\n localStorage.removeItem(\"vidUploadedInSession\");\n localStorage.removeItem(\"toturialScreen\");\n localStorage.removeItem(\"firstVideoAnalysisId\");\n \n // Mixpanel Tracking\n mixpanel.track(MIXPANEL_USER_SESSION.USER_LOGOUT);\n mixpanel.reset();\n },\n },\n});\n\nexport const { handleLogin, handleLogout } = authSlice.actions;\n\nexport default authSlice.reducer;\n","import Cookies from \"js-cookie\";\nimport { cloneDeep } from \"lodash\";\n// import { receiveServerErrors } from '../errors/error_actions';\n\nconst RECEIVE_LICENSE_VIDEO = \"RECEIVE_LICENSE_VIDEO\";\nconst RESET_LICENSE_VIDEO = \"RESET_LICENSE_VIDEO\";\nconst RECEIVE_LICENSE_AGREEMENT = \"RECEIVE_LICENSE_AGREEMENT\";\nconst RECEIVE_VIDEO_AGREEMENTS = \"RECEIVE_VIDEO_AGREEMENTS\";\nconst RECEIVE_LICENSE_AGREEMENTS = \"RECEIVE_LICENSE_AGREEMENTS\";\nconst REQUEST_LICENSE_AGREEMENTS = \"REQUEST_LICENSE_AGREEMENTS\";\nconst REQUEST_LICENSE_HISTORY = \"REQUEST_LICENSE_HISTORY\";\nconst REQUEST_PURCHASE_HISTORY = \"REQUEST_PURCHASE_HISTORY\";\nconst RECEIVE_LICENSE_HISTORY = \"RECEIVE_LICENSE_HISTORY\";\nconst RECEIVE_PURCHASE_HISTORY = \"RECEIVE_PURCHASE_HISTORY\";\n\nexport const receiveLicenseRequestVideo = (video) => ({\n type: RECEIVE_LICENSE_VIDEO,\n video,\n});\n\nexport const resetLicenseRequestVideo = () => ({\n type: RESET_LICENSE_VIDEO,\n});\n\nconst receiveLicenseAgreement = (agreement) => ({\n type: RECEIVE_LICENSE_AGREEMENT,\n agreement,\n});\n\nconst receiveVideoAgreements = (licenseAgreements) => ({\n type: RECEIVE_VIDEO_AGREEMENTS,\n licenseAgreements,\n});\n\nexport const receiveLicenseAgreements = (agreements) => ({\n type: RECEIVE_LICENSE_AGREEMENTS,\n agreements,\n});\n\nexport const requestLicenseAgreement = (loading) => ({\n type: REQUEST_LICENSE_AGREEMENTS,\n loading,\n});\n\nconst requestLicenseAgreementsHistory = (loading) => ({\n type: REQUEST_LICENSE_HISTORY,\n loading,\n});\n\nconst requestPurchaseHistory = (loading) => ({\n type: REQUEST_PURCHASE_HISTORY,\n loading,\n});\n\nconst receiveLicenseAgreementsHistory = (agreements) => ({\n type: RECEIVE_LICENSE_HISTORY,\n agreements,\n});\n\nconst receivePurchaseHistory = (agreements) => ({\n type: RECEIVE_PURCHASE_HISTORY,\n agreements,\n});\n\nexport const sendLicenseRequest =\n ({ data, message, channel, video, note }) =>\n (dispatch) => {\n $.ajax({\n method: \"post\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/license_agreements`,\n data: {\n ...data,\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n },\n success(licenseAgreement) {\n const { pubnub } = window;\n pubnub.publish({\n channel,\n message: {\n message,\n publisher: licenseAgreement.requester_id,\n meta: { license_agreement: licenseAgreement._id },\n },\n });\n dispatch(receiveLicenseRequestVideo({}));\n dispatch(\n receiveLicenseAgreement({\n license_agreement: licenseAgreement,\n license_video: video,\n influencer_video_note: note,\n })\n );\n },\n error(xhr) {\n // dispatch(receiveServerErrors(xhr));\n },\n });\n };\n\nexport const fetchLicenseAgreement = (id) => (dispatch) => {\n $.ajax({\n method: \"get\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/license_agreements/${id}`,\n data: {\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n },\n success(agreement) {\n dispatch(receiveLicenseAgreement(agreement));\n },\n error(xhr) {\n // dispatch(receiveServerErrors(xhr));\n },\n });\n};\n\nexport const fetchLicenseHistory = () => (dispatch) => {\n dispatch(requestLicenseAgreementsHistory(true));\n $.ajax({\n method: \"get\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/license_agreements`,\n data: {\n license_history: true,\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n },\n success(agreements) {\n dispatch(requestLicenseAgreementsHistory(false));\n dispatch(receiveLicenseAgreementsHistory(agreements));\n },\n error(xhr) {\n // dispatch(receiveServerErrors(xhr));\n },\n });\n};\n\nexport const fetchPurchaseHistory = () => (dispatch) => {\n dispatch(requestPurchaseHistory(true));\n $.ajax({\n method: \"get\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/license_agreements`,\n data: {\n purchase_history: true,\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n },\n success(agreements) {\n dispatch(requestPurchaseHistory(false));\n dispatch(receivePurchaseHistory(agreements));\n },\n error(xhr) {\n // dispatch(receiveServerErrors(xhr));\n },\n });\n};\n\nexport const updateLicenseAgreement = (id, data) => (dispatch) => {\n $.ajax({\n method: \"put\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/license_agreements/${id}`,\n data: {\n ...data,\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n },\n success(agreement) {\n dispatch(receiveLicenseAgreement(agreement));\n },\n error(xhr) {\n // dispatch(receiveServerErrors(xhr));\n },\n });\n};\n\nexport const fetchLicenseAgreementsForVideo = (id) => (dispatch) => {\n $.ajax({\n method: \"get\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/videos/${id}/license_agreements`,\n data: {\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n },\n success(licenseAgreements) {\n dispatch(receiveVideoAgreements(licenseAgreements));\n },\n error(xhr) {\n // dispatch(receiveServerErrors(xhr));\n },\n });\n};\n\nexport const licenseRequestVideo = (state = {}, payload = {}) => {\n const { type, video } = payload;\n switch (type) {\n case RECEIVE_LICENSE_VIDEO:\n return video;\n case RESET_LICENSE_VIDEO:\n return {};\n default:\n return state;\n }\n};\n\nexport const videoLicenseAgreements = (state = [], payload = {}) => {\n const { type, licenseAgreements } = payload;\n return type === RECEIVE_VIDEO_AGREEMENTS ? licenseAgreements : state;\n};\n\nexport const licenseAgreements = (state = [], payload = {}) => {\n const { type, agreement, agreements } = payload;\n const newState = cloneDeep(state);\n switch (type) {\n case RECEIVE_LICENSE_AGREEMENTS:\n return agreements;\n case RECEIVE_LICENSE_AGREEMENT:\n const i = newState.findIndex(\n ({ license_agreement: { _id } }) =>\n _id === agreement.license_agreement._id\n );\n if (i === -1) {\n newState.push(agreement);\n } else {\n newState[i] = agreement;\n }\n return newState;\n default:\n return state;\n }\n};\n\nexport const licenseHistory = (state = [], payload = {}) => {\n const { type, agreements } = payload;\n return type === RECEIVE_LICENSE_HISTORY ? agreements : state;\n};\n\nexport const purchaseHistory = (state = [], payload = {}) => {\n const { type, agreements } = payload;\n return type === RECEIVE_PURCHASE_HISTORY ? agreements : state;\n};\n\nexport const loadingLicenseHistory = (state = false, payload = {}) => {\n const { type, loading } = payload;\n return type === REQUEST_LICENSE_HISTORY ? loading : false;\n};\n\nexport const loadingPurchaseHistory = (state = false, payload = {}) => {\n const { type, loading } = payload;\n return type === REQUEST_PURCHASE_HISTORY ? loading : false;\n};\n","import {\n REQUEST_INFLUENCERS,\n RECEIVE_INFLUENCERS,\n UPDATE_INFLUENCER_PARAMS,\n RECEIVE_INFLUENCER,\n RECEIVE_INFLUENCER_VIDEOS,\n RECEIVE_INFLUENCER_PRODUCTS,\n RECEIVE_INFLUENCER_BRANDS,\n REQUEST_INFLUENCER_BRANDS,\n REQUEST_INFLUENCER_VIDEOS,\n REQUEST_INFLUENCER_PRODUCTS,\n FINDING_VIDEOS,\n REQUEST_INFLUENCER_USER,\n RECEIVE_INFLUENCER_USER,\n REQUEST_INFLUENCER_DEMOGRAPHICS,\n RECEIVE_INFLUENCER_DEMOGRAPHICS,\n REQUEST_INFLUENCER_SENTIMENT,\n RECEIVE_INFLUENCER_SENTIMENT,\n REQUEST_INFLUENCER_DAILY_TRACKINGS,\n RECEIVE_INFLUENCER_DAILY_TRACKINGS,\n RESET_FILTERS_INFLUENCERS,\n INFLUENCER_PAGE_STATES,\n} from \"./influencer_actions\";\n\n// import { RECEIVE_CURRENT_SESSION } from '../entry/session_actions';\n// import { RECEIVE_SERVER_ERRORS } from '../errors/error_actions';\n\nexport const influencers = (state = [], payload = {}) => {\n const { type, influencers, influencer } = payload;\n switch (type) {\n case RECEIVE_INFLUENCERS:\n return influencers;\n case RECEIVE_INFLUENCER:\n return [...state, influencer];\n default:\n return state;\n }\n};\n\nexport const filters = {\n platform: [],\n note: [],\n pov: [],\n demographic: {\n age_range: [],\n ethnicity: [],\n gender: [],\n },\n category: [],\n product: [],\n brand: [],\n country: [],\n subscribers: {\n radio: true,\n value: null,\n },\n videos: {\n radio: true,\n value: null,\n },\n};\n\nexport const _nullParams = {\n sort: \"latest_platform_video_published_at\",\n desc: true,\n search: \"\",\n page: 1,\n tab: \"My Creators\",\n filters,\n date: null,\n trending: false,\n validEmail: false,\n vyrillVerified: false,\n};\n\nexport const influencerParams = (state = _nullParams, payload = {}) => {\n const { type, params } = payload;\n switch (type) {\n case RESET_FILTERS_INFLUENCERS:\n return { ...state, filters };\n case UPDATE_INFLUENCER_PARAMS:\n return { ...state, ...params };\n // case RECEIVE_CURRENT_SESSION:\n // return _nullParams;\n default:\n return state;\n }\n};\n\nconst _nullData = {\n totalPages: 1,\n loading: false,\n loadignVideos: false,\n loadingProucts: false,\n count: 0,\n filters,\n videos: {\n trending: [],\n recent: [],\n sponsored: [],\n },\n sentiment: {\n positive: [],\n negative: [],\n },\n products: [],\n pictures: [],\n searched: false,\n findingVideos: false,\n demographics: {\n age: [],\n ethnicity: [],\n gender: [],\n demographics_data: [],\n },\n loadingDemographics: false,\n loadingVyrillData: false,\n loaded_for: null,\n statistics: [],\n engagementIndex: {\n average_views_per_video: [],\n average_engagement_index: [],\n influencer_performance_index: [],\n },\n loadingEngagementIndex: false,\n loadingCreatorBrands: false,\n creatorBrands: [],\n};\n\nexport const influencerData = (state = _nullData, payload = {}) => {\n const {\n type,\n data,\n videos,\n products,\n pictures,\n categories,\n id,\n findingVideos,\n demographics,\n sentiment,\n statistics,\n engagementIndex,\n creatorBrands,\n } = payload;\n switch (type) {\n case REQUEST_INFLUENCERS:\n return { ...state, loading: true };\n case RECEIVE_INFLUENCERS:\n return { ...state, ...data };\n case REQUEST_INFLUENCER_VIDEOS:\n return { ...state, loadingVideos: id };\n case RECEIVE_INFLUENCER_VIDEOS:\n return { ...state, videos, loadingVideos: false };\n // case RECEIVE_SERVER_ERRORS:\n // return { ...state, loadingVideos: false };\n case REQUEST_INFLUENCER_PRODUCTS:\n return { ...state, loadingProducts: id, loadingVyrillData: id };\n case RECEIVE_INFLUENCER_PRODUCTS:\n return {\n ...state,\n products,\n pictures,\n categories,\n loadingProducts: false,\n loadingVyrillData: false,\n };\n case REQUEST_INFLUENCER_BRANDS:\n return { ...state, loadingCreatorBrands: true };\n case RECEIVE_INFLUENCER_BRANDS:\n return {\n ...state,\n loadingCreatorBrands: false,\n creatorBrands,\n };\n case FINDING_VIDEOS:\n return { ...state, findingVideos };\n case REQUEST_INFLUENCER_DEMOGRAPHICS:\n return { ...state, loadingDemographics: true };\n case RECEIVE_INFLUENCER_DEMOGRAPHICS:\n return { ...state, demographics, loadingDemographics: false };\n case REQUEST_INFLUENCER_SENTIMENT:\n return { ...state, loadingVyrillData: true };\n case RECEIVE_INFLUENCER_SENTIMENT:\n return { ...state, sentiment, loadingVyrillData: false };\n case REQUEST_INFLUENCER_DAILY_TRACKINGS:\n return { ...state, loadingEngagementIndex: true };\n case RECEIVE_INFLUENCER_DAILY_TRACKINGS:\n return { ...state, engagementIndex, loadingEngagementIndex: false };\n case RECEIVE_INFLUENCER:\n return { ...state, ...{ statistics } };\n default:\n return state;\n }\n};\n\nconst _nullInfluencerUser = {\n loadingUser: false,\n user: null,\n};\n\nexport const influencerUser = (state = _nullInfluencerUser, payload = {}) => {\n const { type, user } = payload;\n switch (type) {\n case REQUEST_INFLUENCER_USER:\n return { ...state, loadingUser: true };\n case RECEIVE_INFLUENCER_USER:\n return { ...state, loadingUser: false, user };\n default:\n return state;\n }\n};\n\nconst _nullInfluencerStates = {\n isCategoryPage: true,\n};\n\nexport const InfluencerPageStates = (\n state = _nullInfluencerStates,\n { type, status }\n) => {\n switch (type) {\n case INFLUENCER_PAGE_STATES:\n return status;\n default:\n return state;\n }\n};\n","import { receiveServerErrors } from \"../Errors/errorActions\";\nimport Cookies from \"js-cookie\";\n\nexport const RECEIVE_VIDEO_NOTES = \"RECEIVE_VIDEO_NOTES\";\nexport const RECEIVE_PRODUCT_NOTES = \"RECEIVE_PRODUCT_NOTES\";\nexport const RECEIVE_INFLUENCER_NOTES = \"RECEIVE_INFLUENCER_NOTES\";\nexport const RECEIVE_VIDEO_NOTE = \"RECEIVE_VIDEO_NOTE\";\nexport const RECEIVE_PRODUCT_NOTE = \"RECEIVE_PRODUCT_NOTE\";\nexport const RECEIVE_INFLUENCER_NOTE = \"RECEIVE_INFLUENCER_NOTE\";\n\nconst receiveNotes = (notes, type) => {\n switch (type) {\n case \"video\":\n return { type: RECEIVE_VIDEO_NOTES, notes };\n case \"product\":\n return { type: RECEIVE_PRODUCT_NOTES, notes };\n case \"influencer\":\n return { type: RECEIVE_INFLUENCER_NOTES, notes };\n }\n};\n\nconst receiveNote = (note, type) => {\n switch (type) {\n case \"video\":\n return { type: RECEIVE_VIDEO_NOTE, note };\n case \"product\":\n return { type: RECEIVE_PRODUCT_NOTE, note };\n case \"influencer\":\n return { type: RECEIVE_INFLUENCER_NOTE, note };\n }\n};\n\nexport const fetchNotes = (type) => (dispatch) => {\n $.ajax({\n method: \"get\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/${type}_notes`,\n data: {\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n },\n success(notes) {\n dispatch(receiveNotes(notes, type));\n },\n error(xhr) {\n dispatch(receiveServerErrors(xhr));\n },\n });\n};\n\nexport const fetchNote = (type, id) => (dispatch) => {\n $.ajax({\n method: \"get\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/${type}s/${id}/${type}_note`,\n data: {\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n },\n success(notes) {\n dispatch(receiveNotes(notes, type));\n },\n error(xhr) {\n dispatch(receiveServerErrors(xhr));\n },\n });\n};\n\nexport const updateNote = (id, data, type) => (dispatch) => {\n $.ajax({\n method: \"put\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/${type}s/${id}/${type}_note`,\n data: {\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n ...data,\n },\n success(note) {\n dispatch(receiveNote(note, type));\n },\n error(xhr) {\n dispatch(receiveServerErrors(xhr));\n },\n });\n};\n","import { isEqual, get } from \"lodash\";\nimport Cookies from \"js-cookie\";\n\nexport const REQUEST_NAVBAR_STATS = \"REQUEST_NAVBAR_STATS\";\nexport const RECEIVE_NAVBAR_STATS = \"RECEIVE_NAVBAR_STATS\";\n\nconst requestNavbarStats = () => ({ type: REQUEST_NAVBAR_STATS });\nconst receiveNavbarStats = (data) => ({ type: RECEIVE_NAVBAR_STATS, data });\n\nexport const fetchNavbarStats = () => (dispatch) => {\n dispatch(requestNavbarStats());\n $.ajax({\n method: \"get\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/navbar_stats`,\n data: { brand_id: Cookies.get(\"bId\"), user_id: Cookies.get(\"uId\") },\n success(data) {\n dispatch(receiveNavbarStats(data));\n },\n error(xhr) {\n console.log(xhr);\n // dispatch(receiveServerErrors(xhr));\n },\n });\n};\n","export const UPDATE_SENTIMENT_REPORT = \"UPDATE_SENTIMENT_REPORT\";\nexport const UPDATE_ACTIVE_DURATION = \"UPDATE_ACTIVE_DURATION\";\nexport const UPDATE_PRODUCT_SORTING = \"UPDATE_PRODUCT_SORTING\";\nexport const UPDATE_VIDEOS_SORTING = \"UPDATE_VIDEOS_SORTING\";\nexport const UPDATE_VIDEOS_SEARCH = \"UPDATE_VIDEOS_SEARCH\";\nexport const UPDATE_PLATFORMS = \"UPDATE_PLATFORMS\";\n\nexport const updatePlatforms = (platformsOption) => ({\n type: UPDATE_PLATFORMS,\n platformsOption,\n});\n\nexport const updateActiveDuration = (selectedDuration) => ({\n type: UPDATE_ACTIVE_DURATION,\n selectedDuration,\n});\n\nexport const updateActiveSortSentiment = (productsSortBy) => ({\n type: UPDATE_PRODUCT_SORTING,\n productsSortBy,\n});\n\nexport const updateActiveSortVideos = (videosSortBy) => ({\n type: UPDATE_VIDEOS_SORTING,\n videosSortBy,\n});\n\nexport const updateVideosSearch = ({ search }) => ({\n type: UPDATE_VIDEOS_SEARCH,\n search,\n});\n\nexport const sentimentReportAction = (data) => ({\n type: UPDATE_SENTIMENT_REPORT,\n data,\n});\n","import axios from \"axios\";\n\nexport const WIDGET_STATES = \"WIDGET_STATES\";\nexport const ADD_SELECTED_VIDEO = \"ADD_SELECTED_VIDEO\";\nexport const REMOVE_SELECTED_VIDEO = \"REMOVE_SELECTED_VIDEO\";\nexport const CLEAR_SELECTED_VIDEOS = \"CLEAR_SELECTED_VIDEOS\";\nexport const UPDATE_VIDEO_SETTINGS = \"UPDATE_VIDEO_SETTINGS\";\n\nexport const updateWidgetState = (status) => ({\n type: WIDGET_STATES,\n status,\n});\n\nexport const addSelectedVideo = (video) => ({\n type: ADD_SELECTED_VIDEO,\n payload: video,\n});\n\nexport const updateVideoSettings = (videoId, newSettings) => ({\n type: UPDATE_VIDEO_SETTINGS,\n payload: { videoId, newSettings },\n});\n\nexport const removeSelectedVideo = (id) => ({\n type: REMOVE_SELECTED_VIDEO,\n payload: id,\n});\n\nexport const clearSelectedVideos = () => ({\n type: CLEAR_SELECTED_VIDEOS,\n});\n\nconst apiUrl = process.env.REACT_APP_WIDGET_BASE_URL;\nconst apiKey =\n \"ZhrsS5EtnaA1shtKyC6Tr3IOS5M1rQcRPjxyAk7jhndlNOlJbwUleGH0vEeEU4eb\";\n\nconst getConfig = (method, data = null) => ({\n method,\n url: `${apiUrl}${method === \"get\" ? \"\" : \"/widget\"}`,\n headers: {\n \"Content-Type\": \"application/json\",\n \"x-api-key\": apiKey,\n },\n data,\n maxBodyLength: Infinity,\n});\n\nexport const createWidget = async (data) => {\n try {\n const response = await axios.post(\n `${apiUrl}/widget`,\n data,\n getConfig(\"post\", data)\n );\n return response.data;\n } catch (error) {\n throw error;\n }\n};\n\nexport const getWidgetData = async (id) => {\n try {\n const response = await axios.get(\n `${apiUrl}/widget/${id}`,\n getConfig(\"get\")\n );\n return response.data;\n } catch (error) {\n throw error;\n }\n};\n\nexport const getShopifyProducts = async (\n shopifyAccessToken,\n shopifyStoreUrl\n) => {\n try {\n const response = await axios.get(\n `${apiUrl}/products/inventory?shopifyAccessToken=${shopifyAccessToken}&shopifyStoreUrl=${shopifyStoreUrl}`,\n getConfig(\"get\")\n );\n return response.data;\n } catch (error) {\n throw error;\n }\n};\n\nexport const updateWidgetData = async (id, data) => {\n try {\n const response = await axios.put(\n `${apiUrl}/widget/${id}`,\n JSON.stringify(data),\n getConfig(\"put\", data)\n );\n return response.data;\n } catch (error) {\n throw error;\n }\n};\n\nexport const updatePlaylistData = async (id, data) => {\n try {\n const response = await axios.put(\n `${apiUrl}/playlist/${id}`,\n JSON.stringify(data),\n getConfig(\"put\", data)\n );\n return response.data;\n } catch (error) {\n throw error;\n }\n};\n\nexport const deleteWidget = async (widgetId) => {\n try {\n const response = await axios.delete(\n `${apiUrl}/widget/${widgetId}`,\n getConfig(\"delete\")\n );\n return response.data;\n } catch (error) {\n throw error;\n }\n};\n\nexport const createPlaylist = async (data) => {\n try {\n const response = await axios.post(\n `${apiUrl}/playlist`,\n data,\n getConfig(\"post\", data)\n );\n return response.data;\n } catch (error) {\n throw error;\n }\n};\n\nexport const getAllWidgets = async (params) => {\n try {\n const response = await axios.get(`${apiUrl}/widgets/`, {\n ...getConfig(\"get\"),\n params,\n });\n return response.data;\n } catch (error) {\n throw error;\n }\n};\n\nexport const generateWidgetToken = async (id) => {\n try {\n const response = await axios.post(\n `${apiUrl}/widget/${id}/token/generate`,\n null,\n getConfig(\"post\")\n );\n return response.data;\n } catch (error) {\n throw error;\n }\n};\n","import { useDispatch, useSelector } from \"react-redux\";\nimport { updateTutorialState } from \"./TutorialActions\";\nimport { useNavigate } from \"react-router-dom\";\n\nexport const Header = ({ showProgress = true, successMessage }) => {\n const activeStep = useSelector((state) => state.tutorials_states.activeStep);\n const totalSteps = useSelector((state) => state.tutorials_states.totalSteps);\n const activeTutorial = useSelector(\n (state) => state.tutorials_states.activeTutorial\n );\n const dispatch = useDispatch();\n const navigate = useNavigate();\n\n const handleBack = () => {\n dispatch(updateTutorialState({ activeStep: activeStep - 1 }));\n };\n\n const handleClose = () => {\n if (activeTutorial === \"first-video-analyzed\") {\n navigate(\"/videos\");\n dispatch(\n updateTutorialState({\n isTutorial: true,\n activeTutorial: \"first-video-analyzed\",\n activeStep: 0,\n // totalSteps: 2,\n })\n );\n\n if (activeStep == 2) {\n localStorage.removeItem(\"firstVideoAnalysisId\")\n // Closeing modal after first video analysed tutorial\n dispatch(\n updateTutorialState({\n isTutorial: false,\n activeTutorial: \"\",\n activeStep: 1,\n totalSteps: 0,\n })\n );\n }\n } else {\n navigate(\"/home\");\n dispatch(\n updateTutorialState({\n isTutorial: false,\n activeTutorial: \"\",\n activeStep: 1,\n isVistComplete: true,\n })\n );\n }\n\n // TODO:\n localStorage.removeItem(\"toturialScreen\");\n };\n\n return (\n \n {activeStep !== 1 && (\n
handleBack()}>\n {\" \"}\n \n \n {\" \"}\n Back{\" \"}\n
\n )}\n
\n {activeStep}\n /{totalSteps} \n
\n
\n
handleClose()}\n src={require(\"@src/assets/images/vyrill/cross.png\").default}\n alt=\"\"\n role=\"button\"\n width=\"25px\"\n />\n
\n {showProgress && (\n
\n )}\n {successMessage && (\n
{successMessage} \n )}\n
\n );\n};\n\nconst ProgressInSteps = ({ active, totalSteps }) => {\n return (\n \n {[...Array(totalSteps)].map((_, index) => (\n
\n ))}\n
\n );\n};\n\nexport const BuletTick = () => {\n return (\n \n \n \n );\n};\n","import { useDispatch, useSelector } from \"react-redux\";\nimport { updateTutorialState } from \"./TutorialActions\";\n\nconst useTutorialState = (tutorialType) => {\n const activeStep = useSelector((state) => state.tutorials_states.activeStep);\n const isTutorial = useSelector((state) => state.tutorials_states.isTutorial);\n const activeTutorial = useSelector(\n (state) => state.tutorials_states.activeTutorial\n );\n\n const dispatch = useDispatch();\n\n const handleNext = () => {\n dispatch(updateTutorialState({ activeStep: activeStep + 1 }));\n };\n\n const showStep = isTutorial && activeTutorial === tutorialType;\n \n return {\n activeStep,\n handleNext,\n showStep,\n };\n};\n\nexport default useTutorialState;\n","export default __webpack_public_path__ + \"static/media/avatar-s-1.d383013d.jpg\";","export default __webpack_public_path__ + \"static/media/2.c8691d67.png\";","export default __webpack_public_path__ + \"static/media/9-small.ceb32575.png\";","export const UPDATE_ASK_VYRILL_STATE = \"UPDATE_ASK_VYRILL_STATE\";\nexport const RESET_ASK_VYRILL_STATE = \"RESET_ASK_VYRILL_STATE\";\nexport const UPDATE_SINGLE_MESSAGE = \"UPDATE_SINGLE_MESSAGE\";\nexport const UPDATE_ASK_VYRILL_MODAL = \"UPDATE_ASK_VYRILL_MODAL\";\n\ntype ActionPayload = {\n [key: string]: any;\n};\n\n// Define the action type\ntype UpdateAskVyrillStateAction = {\n type: typeof UPDATE_ASK_VYRILL_STATE;\n data: ActionPayload;\n};\n\n// Define the action creator function\nexport const updateAskVyrillState = (\n data: ActionPayload\n): UpdateAskVyrillStateAction => ({\n type: UPDATE_ASK_VYRILL_STATE,\n data,\n});\n\ntype UpdateSingleMessageAction = {\n type: typeof UPDATE_SINGLE_MESSAGE;\n data: ActionPayload;\n};\n\nexport const updateSingleMessage = (\n data: ActionPayload\n): UpdateSingleMessageAction => ({\n type: UPDATE_SINGLE_MESSAGE,\n data,\n});\n\ntype askVyrillModalAction = {\n type: typeof UPDATE_ASK_VYRILL_MODAL;\n data: ActionPayload;\n};\n\nexport const updateAskVyrillModal = (\n data: ActionPayload\n): askVyrillModalAction => ({\n type: UPDATE_ASK_VYRILL_MODAL,\n data,\n});\n","export default __webpack_public_path__ + \"static/media/avatar-s-2.d21f2121.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-5.301316d5.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-8.e9b18971.jpg\";","export default __webpack_public_path__ + \"static/media/7.0fc55608.png\";","export default __webpack_public_path__ + \"static/media/3.80eecfc8.png\";","export default __webpack_public_path__ + \"static/media/4.4bfb7963.png\";","export default __webpack_public_path__ + \"static/media/6.858a7a6b.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/avatar-s-11.1d46cc62.jpg\";","export default \"\"","export default \"\"","import types from \"./types\";\nimport { IDLE, LOADING, SUCCESS, FAILURE } from \"../common/status\";\nimport { UPDATED_SENTIMENT_FEEDBACK } from \"../../../Pages/Video/VideoActions\";\n\nconst {\n VIDEO_ASSOCIATIONS_REQUEST,\n VIDEO_ASSOCIATIONS_SUCCESS,\n VIDEO_ASSOCIATIONS_FAILURE,\n VIDEO_ASSOCIATIONS_RESET,\n UPDATED_DROPBOX_DATA,\n UPDATED_API_DATA,\n SET_VIDEO_TRANSCRIPT,\n} = types;\n\nconst INITIAL_STATE = {\n body: {},\n error: null,\n status: IDLE,\n statusText: \"\",\n statusCode: null,\n transcript: [],\n};\n\nexport default function (state = INITIAL_STATE, action) {\n const { type, payload, transcript } = action;\n\n switch (type) {\n case VIDEO_ASSOCIATIONS_REQUEST:\n return {\n ...state,\n status: LOADING,\n };\n case VIDEO_ASSOCIATIONS_SUCCESS:\n return {\n ...state,\n status: SUCCESS,\n body: payload.data,\n statusCode: payload.status,\n };\n case VIDEO_ASSOCIATIONS_FAILURE:\n return {\n ...state,\n status: FAILURE,\n error: payload,\n statusText: payload.statusText,\n statusCode: payload.status,\n };\n case SET_VIDEO_TRANSCRIPT:\n return { ...state, transcript };\n case VIDEO_ASSOCIATIONS_RESET:\n return INITIAL_STATE;\n case UPDATED_DROPBOX_DATA:\n return { ...state, body: { video: payload } };\n case UPDATED_API_DATA:\n return { ...state, body: { video: payload } };\n case UPDATED_SENTIMENT_FEEDBACK:\n return {\n ...state,\n body: { ...state.body, sentiment_feedback_like: payload },\n };\n default:\n return state;\n }\n}\n","import { standardAction, errorAction } from \"../common/actions\";\nimport types from \"./types\";\n\nconst {\n VIDEO_ASSOCIATIONS_REQUEST,\n VIDEO_ASSOCIATIONS_SUCCESS,\n VIDEO_ASSOCIATIONS_FAILURE,\n VIDEO_ASSOCIATIONS_RESET,\n SET_VIDEO_TRANSCRIPT,\n} = types;\n\nconst doVideoAssociationsRequest = (payload) =>\n standardAction(VIDEO_ASSOCIATIONS_REQUEST, payload);\nconst doVideoAssociationsSuccess = (payload) =>\n standardAction(VIDEO_ASSOCIATIONS_SUCCESS, payload);\nconst doVideoAssociationsFailure = (payload) =>\n errorAction(VIDEO_ASSOCIATIONS_FAILURE, payload);\nconst doVideoAssociationsReset = (payload) =>\n standardAction(VIDEO_ASSOCIATIONS_RESET, payload);\n\nconst setVideoDetailTranscript = (transcript) => ({\n type: SET_VIDEO_TRANSCRIPT,\n transcript,\n});\n\nexport default {\n doVideoAssociationsRequest,\n doVideoAssociationsSuccess,\n doVideoAssociationsFailure,\n doVideoAssociationsReset,\n setVideoDetailTranscript,\n};\n","import Cookies from \"js-cookie\";\nimport actions from \"./actions\";\nimport endpoints from \"../api/endpoints\";\n\nconst {\n doVideoAssociationsRequest,\n doVideoAssociationsSuccess,\n doVideoAssociationsFailure,\n} = actions;\n\nconst fetchVideoAssociations = (videoId) => async (dispatch) => {\n dispatch(doVideoAssociationsRequest());\n return new Promise((resolve, reject) => {\n $.ajax({\n method: \"get\",\n url: endpoints.videoAssociations.replace(\"{{videoId}}\", videoId),\n headers: {\n Authorization: \"Bearer \" + Cookies.get(\"jwt\"),\n },\n success(data, statusText, { status }) {\n dispatch(doVideoAssociationsSuccess({ data, statusText, status }));\n resolve({ data, statusText, status });\n },\n error(xhr) {\n dispatch(doVideoAssociationsFailure(xhr));\n reject(xhr);\n },\n });\n });\n};\n\nexport default {\n fetchVideoAssociations,\n};\n","import reducer from \"./reducer\";\nimport types from \"./types\";\nimport actions from \"./actions\";\nimport operations from \"./operations\";\n\nexport { types, actions, operations };\n\nexport default reducer;\n","export default __webpack_public_path__ + \"static/media/avatar-s-4.a649af23.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-7.ba3f6823.jpg\";","export default __webpack_public_path__ + \"static/media/5.b76b05aa.png\";","export default __webpack_public_path__ + \"static/media/10.5da4bd6d.png\";","export default __webpack_public_path__ + \"static/media/8.ee1de961.png\";","export default __webpack_public_path__ + \"static/media/10-small.ab9b80df.png\";","export default __webpack_public_path__ + \"static/media/5-small.b567e4fa.png\";","export default __webpack_public_path__ + \"static/media/6-small.cb875cd8.png\";","export default __webpack_public_path__ + \"static/media/3-small.8d6585e8.png\";","// Login Page\nexport const MIXPANEL_USER_SESSION = {\n USER_LOGIN: \"user_login\",\n USER_LOGOUT: \"user_logout\",\n};\n\n// Home Page\nexport const MIXPANEL_HOME_PAGE = {\n SHORTCUT_RUN_REPORT: \"shortcut_run_report\",\n SHORTCUT_ADD_PRODUCT: \"shortcut_add_product\",\n SHORTCUT_ADD_VIDEOS: \"shortcut_add_videos\",\n SHORTCUT_ADD_VIDEOS_SUCCESS: \"shortcut_add_videos_success\",\n RECENT_TRENDING_TOGGLE_VIDEOS_TAB: \"recent_trending_toggle_videos_tab\",\n RECENT_TRENDING_TOGGLE_CREATORS_TAB: \"recent_trending_toggle_creators_tab\",\n RECENT_TRENDING_VIEW_ALL_VIDEOS: \"recent_trending_view_all_videos\",\n RECENT_TRENDING_VIEW_ALL_CREATORS: \"recent_trending_view_all_creators\",\n BRAND_OVERVEW_VIEW_BRAND_ENGAGEMENT_REPORT:\n \"brand_overview_view_brand_engagement_report\",\n BRAND_OVERVIEW_VIEW_SENTIMENT_REPORT: \"brand_overview_view_sentiment_report\",\n BRAND_OVERVIEW_VIEW_TOP_PRODUCTS_REPORT:\n \"brand_overview_view_products_report\",\n BRAND_OVERVIEW_VIEW_DEMOGRAPHICS_REPORT:\n \"brand_overview_view_demographics_report\",\n WORD_CLOUD_VIEW_DETAILS: \"word_cloud_view_details\",\n};\n\n// Product Page\nexport const MIXPANEL_PRODUCTS_PAGE = {\n MY_PRODUCTS_TAB: \"my_products_tab_product_page\",\n COMPETITORS_TAB: \"competitors_tab_product_page\",\n CLEAR_ALL_FILTERS: \"products_clear_filters\",\n PRODUCT_CARD: \"select_product\",\n SELECT_FILTER_ITEM: \"select_filter_item_product_page\",\n};\n\n// Videos Page\nexport const MIXPANEL_VIDEOS_PAGE = {\n MY_VIDEOS_TAB: \"videos_my_videos_tab\",\n COMPETITORS_TAB: \"videos_competitors_tab\",\n CLEAR_ALL_FILTERS: \"videos_clear_filters\",\n SELECT_FILTER: \"videos_select_filter\",\n PUBLISH_TO_APP: \"videos_publish_to_app\",\n DOWNLOAD_ALL_TRANSCRIPTS: \"videos_download_all_transcripts\",\n CLICK_VIDEO_CARD: \"videos_click_video_card\",\n};\n\n// Video Details Page\nexport const MIXPANEL_VIDEO_DETAILS_PAGE = {\n PUBLISH_TO_APP: \"video_detail_publish_to_app\",\n UNPUBLISH_FROM_APP: \"video_detail_unpublish_from_app\",\n PEOPLE_IN_VIDEO_TAB: \"video_detail_people_in_video_tab\",\n TRANSCRIPT_TAB: \"video_detail_transcript_tab\",\n BRAND_SAFETY_TAB: \"video_detail_brand_safety_tab\",\n SUBMIT_FOR_RE_ANALYZE: \"submit_for_re_analyze\",\n};\n\n// Creators Page\nexport const MIXPANEL_CREATORS_PAGE = {\n MY_CREATORS_TAB: \"my_creators_tab_creators_page\",\n COMPETITORS_TAB: \"competitors_tab_creators_page\",\n VIEW_ALL_TAB: \"view_all_tab_creators_page\",\n CONTACT_CREATORS: \"contact_creators\",\n DOWNLOAD_CSV: \"download_csv\",\n CREATOR_CARD: \"select_creator_card\",\n SELECT_FILTER_ITEM: \"select_filter_item\",\n CLEAR_ALL_FILTERS: \"creators_clear_filters\",\n};\n\n// Reports Page\nexport const MIXPANEL_REPORTS_PAGE = {\n SELECT_CUSTOM_REPORT: \"select_custom_report\",\n SELECT_DEMOGRAPHIC_REPORT: \"select_demographic_report\",\n SELECT_SENTIMENT_REPORT: \"select_sentiment_report\",\n SELECT_ENGAGEMENT_REPORT: \"select_engagement_report\",\n SELECT_SPEECH_REPORT: \"select_speech_report\",\n SELECT_FILTER_ITEM: \"select_filter_item_report\",\n};\n\n// App Manager Page\nexport const MIXPANEL_APP_MANAGER_PAGE = {\n BRAND_TAB: \"brand_tab_app_manager_page\",\n SHOPPER_TAB: \"shopper_tab_app_manager_page\",\n VIEW_ALL_TAB: \"view_all_tab_app_manager_page\",\n VIDEO_CARD: \"select_video\",\n OPEN_UNPUBLISH_FROM_APP_MODAL: \"open_unpublish_from_app_modal\",\n UNPUBLISH_FROM_APP: \"unpublish_from_app\",\n SELECT_FILTER_ITEM: \"select_filter_item_app_manager_page\",\n};\n\n// Shared mixpanel events for Videos and Products Card (Heart, Flag, Edit Note, Edit)\nexport const MIXPANEL_PRODUCTS_VIDEOS_CARD = {\n ADD_TO_FAVORITES: \"add_to_favorites\",\n COPY_EMAIL: \"copy_email\",\n FLAG: \"flag\",\n OPEN_EDIT_NOTE_DIALOG: \"open_edit_note_dialog\",\n SUBMIT_EDIT_NOTE: \"submit_edit_note\",\n EDIT_PRODUCT: \"edit_product\",\n};\n","import { useEffect, useRef } from \"react\";\n\nexport const usePrevious = (value) => {\n // The ref object is a generic container whose current property is mutable ...\n // ... and can hold any value, similar to an instance property on a class\n const ref = useRef();\n // Store current value in ref\n useEffect(() => {\n ref.current = value;\n }, [value]); // Only re-run if value changes\n // Return previous value (happens before update in useEffect above)\n return ref.current;\n};\n","export const CAMPAIGN_STATES = \"CAMPAIGN_STATES\";\nexport const UPDATE_FORM_FIELDS = \"UPDATE_FORM_FIELDS\";\n\n\nexport const updateCampaignState = (status) => ({\n type: CAMPAIGN_STATES,\n status,\n});\n\nexport const updateCampaignFields = (status) => ({\n type: UPDATE_FORM_FIELDS,\n status,\n});\n","export default \"\"","export default __webpack_public_path__ + \"static/media/competitors.e77b7310.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-6.974f64da.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-10.79a4ca26.jpg\";","export default __webpack_public_path__ + \"static/media/11.9d340e5c.png\";","export default __webpack_public_path__ + \"static/media/2-small.d95009b5.png\";","export default __webpack_public_path__ + \"static/media/4-small.4a4717ef.png\";","export default __webpack_public_path__ + \"static/media/7-small.9d136aaa.png\";","import {\n receiveServerErrors,\n receiveValidationErrors,\n RESET_LOADING,\n} from \"../Shared/Errors/errorActions\";\nimport {\n receiveCurrentSession,\n REQUEST_CURRENT_SESSION,\n RECEIVE_CURRENT_SESSION,\n requestCurrentSession,\n} from \"./session_actions\";\nimport { handleLogin } from \"@store/authentication\";\nimport { receiveServerMessage } from \"../Shared/ServerMessages/ServerMessageActions\";\nimport { findInfluencerVideos } from \"../Pages/Influencer/influencer_actions\";\nimport Cookies from \"js-cookie\";\nimport axios from \"axios\";\n\nexport const RECEIVE_CATEGORY_NAMES = \"RECEIVE_CATEGORY_NAMES\";\nexport const RECEIVE_BRAND_NAMES = \"RECEIVE_BRAND_NAMES\";\n\nconst receiveCategories = (categories) => ({\n type: RECEIVE_CATEGORY_NAMES,\n categories,\n});\n\nconst receiveBrands = (brands) => ({ type: RECEIVE_BRAND_NAMES, brands });\n\nexport const createUser = (data, callback) => (dispatch) => {\n dispatch({ type: REQUEST_CURRENT_SESSION });\n $.ajax({\n method: \"post\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/users`,\n data,\n success(session) {\n dispatch(receiveCurrentSession(session));\n dispatch(handleLogin(session.currentUser));\n Cookies.set(\"uId\", session.currentUser._id);\n // Cookies.set('jwt', session.jwt)\n localStorage.setItem(\"session\", JSON.stringify(session));\n callback(session);\n },\n error(xhr) {\n dispatch(receiveServerErrors(xhr));\n },\n });\n};\n\nexport const signup = (data, callback, fieldError) => (dispatch) => {\n dispatch(requestCurrentSession());\n axios\n .post(\n `${process.env.REACT_APP_BASE_URL}/jwt_api/login/user_sign_up`,\n data,\n {}\n )\n .then((res) => {\n const { data } = res;\n if (!data.roles.includes(\"vip_influencer\")) {\n dispatch(receiveCurrentSession(data));\n dispatch(handleLogin(data.currentUser));\n Cookies.set(\"uId\", data.currentUser._id);\n Cookies.set(\"jwt\", data.jwt);\n localStorage.setItem(\"session\", JSON.stringify(data));\n }\n callback(data);\n })\n .catch((err) => {\n if (\n err.response.data.code === 208 &&\n err.response.data.error_message ===\n \"There is already an account with this email.\"\n ) {\n err.response.responseJSON = [err.response.data.error_message];\n dispatch(\n receiveValidationErrors({ email: err.response.data.error_message })\n );\n dispatch({ type: RESET_LOADING });\n } else if (err.response.data.code === 208) {\n fieldError(err.response.data.error_message);\n err.response.responseJSON = [err.response.data.error_message];\n dispatch(receiveServerErrors(err.response));\n }\n });\n};\n\nexport const updateUser = (data, triggerAVA) => (dispatch) => {\n dispatch({ type: REQUEST_CURRENT_SESSION });\n $.ajax({\n method: \"put\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/users/current`,\n data,\n success(session) {\n if (triggerAVA) {\n dispatch(findInfluencerVideos(session.influencer._id));\n }\n dispatch(receiveCurrentSession(session));\n dispatch(receiveServerMessage(\"Profile successfully updated!\"));\n },\n error(xhr) {\n dispatch(receiveServerErrors(xhr));\n },\n });\n};\n","export default \"\"","import { Spinner } from \"reactstrap\";\n\nconst Loader = () => {\n return (\n \n \n
\n );\n};\nexport default Loader;\n","export default \"\"","// ** Redux Imports\nimport { createSlice } from \"@reduxjs/toolkit\";\n\n// ** ThemeConfig Import\nimport themeConfig from \"@configs/themeConfig\";\n\nconst initialMenuCollapsed = () => {\n const item = window.localStorage.getItem(\"menuCollapsed\");\n //** Parse stored json or if none return initialValue\n return item ? JSON.parse(item) : themeConfig.layout.menu.isCollapsed;\n};\n\nconst initialDirection = () => {\n const item = window.localStorage.getItem(\"direction\");\n //** Parse stored json or if none return initialValue\n return item ? JSON.parse(item) : themeConfig.layout.isRTL;\n};\n\nconst initialSkin = () => {\n const item = window.localStorage.getItem(\"skin\");\n //** Parse stored json or if none return initialValue\n return item ? JSON.parse(item) : themeConfig.layout.skin;\n};\n\nexport const layoutSlice = createSlice({\n name: \"layout\",\n initialState: {\n skin: initialSkin(),\n isRTL: initialDirection(),\n layout: themeConfig.layout.type,\n lastLayout: themeConfig.layout.type,\n menuCollapsed: initialMenuCollapsed(),\n footerType: themeConfig.layout.footer.type,\n navbarType: themeConfig.layout.navbar.type,\n menuHidden: themeConfig.layout.menu.isHidden,\n contentWidth: themeConfig.layout.contentWidth,\n routerTransition: themeConfig.layout.routerTransition,\n navbarColor: themeConfig.layout.navbar.backgroundColor,\n },\n reducers: {\n handleRTL: (state, action) => {\n state.isRTL = action.payload;\n window.localStorage.setItem(\"direction\", JSON.stringify(action.payload));\n },\n handleSkin: (state, action) => {\n state.skin = action.payload;\n window.localStorage.setItem(\"skin\", JSON.stringify(action.payload));\n },\n handleLayout: (state, action) => {\n state.layout = action.payload;\n },\n handleFooterType: (state, action) => {\n state.footerType = action.payload;\n },\n handleNavbarType: (state, action) => {\n state.navbarType = action.payload;\n },\n handleMenuHidden: (state, action) => {\n state.menuHidden = action.payload;\n },\n handleLastLayout: (state, action) => {\n state.lastLayout = action.payload;\n },\n handleNavbarColor: (state, action) => {\n state.navbarColor = action.payload;\n },\n handleContentWidth: (state, action) => {\n state.contentWidth = action.payload;\n },\n handleMenuCollapsed: (state, action) => {\n state.menuCollapsed = action.payload;\n window.localStorage.setItem(\n \"menuCollapsed\",\n JSON.stringify(action.payload)\n );\n },\n handleRouterTransition: (state, action) => {\n state.routerTransition = action.payload;\n },\n },\n});\n\nexport const {\n handleRTL,\n handleSkin,\n handleLayout,\n handleLastLayout,\n handleMenuHidden,\n handleNavbarType,\n handleFooterType,\n handleNavbarColor,\n handleContentWidth,\n handleMenuCollapsed,\n handleRouterTransition,\n} = layoutSlice.actions;\n\nexport default layoutSlice.reducer;\n","import { gql } from \"@apollo/client\";\n\nexport const GET_ALL_PROMPTS = gql`\n query MyQuery {\n getAllPrompts {\n _id\n prompt\n created_at\n updated_at\n }\n }\n`;\n\nexport const CREATE_CONVERSATION_MUTATION = gql`\n mutation CreateConversation($brandId: String!) {\n createConversation(brandId: $brandId) {\n _id\n brand_id\n created_at\n title\n updated_at\n working_messages {\n content\n role\n }\n }\n }\n`;\n\nexport const ASK_VYRILL_QUERY = gql`\n query MyQuery(\n $brandId: String!\n $conversationId: String!\n $duration: String!\n $content: String!\n $role: String!\n $start_date: String\n $end_date: String\n ) {\n askVyrill(\n brandId: $brandId\n conversationId: $conversationId\n duration: $duration\n start_date: $start_date\n end_date: $end_date\n userMessage: { content: $content, role: $role }\n ) {\n _id\n content\n conversation_id\n end_date\n like\n role\n start_date\n question_id\n supporting_data {\n collection_source\n db_id\n end_ts\n source_doc\n source_doc_type\n start_ts\n thumbnail_url\n transcript_id_video_id\n }\n _id\n }\n }\n`;\n\nexport const ASK_VYRILL_REGENRATE_RESPONSE = gql`\n query MyQuery(\n $conversationId: String!\n $questionId: String!\n $responseId: String!\n ) {\n regenerate(\n conversationId: $conversationId\n questionId: $questionId\n responseId: $responseId\n ) {\n _id\n content\n conversation_id\n end_date\n like\n role\n start_date\n supporting_data {\n collection_source\n db_id\n end_ts\n source_doc\n source_doc_type\n start_ts\n thumbnail_url\n transcript_id_video_id\n }\n _id\n }\n }\n`;\n\n// getting all conversation by brand\nexport const GET_CONVERSATIONS = gql`\n query GetConversations($brandId: String!) {\n getConversations(brandId: $brandId) {\n _id\n brand_id\n created_at\n title\n updated_at\n working_messages {\n content\n role\n }\n }\n }\n`;\n\nexport const GET_MESSAGES_QUERY = gql`\n query MyQuery($conversationId: String!) {\n getMessages(conversationId: $conversationId) {\n _id\n content\n conversation_id\n end_date\n like\n role\n start_date\n supporting_data {\n collection_source\n db_id\n end_ts\n source_doc\n source_doc_type\n start_ts\n thumbnail_url\n transcript_id_video_id\n }\n }\n }\n`;\n\nexport const UPDATE_CONVERSATION_MUTATION = gql`\n mutation updateConversation($conversationId: String!, $title: String!) {\n updateConversation(conversationId: $conversationId, title: $title) {\n _id\n brand_id\n created_at\n title\n updated_at\n }\n }\n`;\n\nexport const GET_VIDEO_DETAILS = gql`\n query GetVideo($_id: ID!) {\n getVideo(queryVideo: { _id: $_id }) {\n _id\n thumbnail_url\n added_by_bm\n platform\n video_embedded_url\n title\n video_url\n tiktok_id\n }\n }\n`;\n\nexport const DELETE_CONVERSATION_MUTATION = gql`\n mutation DeleteConversation($conversationId: String!) {\n deleteConversation(conversationId: $conversationId)\n }\n`;\n\nexport const LIKE_MESSAGE_MUTATION = gql`\n mutation LikeMessage($like: Int!, $messageId: String!) {\n likeMessage(like: $like, messageId: $messageId) {\n _id\n content\n conversation_id\n end_date\n like\n role\n start_date\n supporting_data {\n collection_source\n db_id\n end_ts\n source_doc\n source_doc_type\n start_ts\n thumbnail_url\n transcript_id_video_id\n }\n }\n }\n`;\n","export default __webpack_public_path__ + \"static/media/favorites.1dcaf6a6.png\";","export default __webpack_public_path__ + \"static/media/trash.f7d2e39f.png\";","export default \"\"","export default \"\"","export const ADD_PRODUCT_MODAL = \"ADD_PRODUCT_MODAL\";\n\nexport const toggelAddProductModal = (data) => ({\n type: ADD_PRODUCT_MODAL,\n data,\n});\n","const VIDEO_DETAIL_REQUEST = \"videoDetail/REQUEST\";\nconst VIDEO_DETAIL_SUCCESS = \"videoDetail/SUCCESS\";\nconst VIDEO_DETAIL_FAILURE = \"videoDetail/FAILURE\";\nconst VIDEO_DETAIL_RESET = \"videoDetail/RESET\";\n\nexport default {\n VIDEO_DETAIL_REQUEST,\n VIDEO_DETAIL_SUCCESS,\n VIDEO_DETAIL_FAILURE,\n VIDEO_DETAIL_RESET,\n};\n","import types from \"./types\";\nimport { IDLE, LOADING, SUCCESS, FAILURE } from \"../common/status\";\n\nconst {\n VIDEO_DETAIL_REQUEST,\n VIDEO_DETAIL_SUCCESS,\n VIDEO_DETAIL_FAILURE,\n VIDEO_DETAIL_RESET,\n} = types;\n\nconst INITIAL_STATE = {\n body: {},\n error: null,\n status: IDLE,\n statusText: \"\",\n statusCode: null,\n};\n\nexport default function (state = INITIAL_STATE, action) {\n const { type, payload } = action;\n\n switch (type) {\n case VIDEO_DETAIL_REQUEST:\n return {\n ...state,\n status: LOADING,\n };\n case VIDEO_DETAIL_SUCCESS:\n return {\n ...state,\n status: SUCCESS,\n body: payload.data,\n statusCode: payload.status,\n statusText: payload.statusText,\n };\n case VIDEO_DETAIL_FAILURE:\n return {\n ...state,\n status: FAILURE,\n error: payload,\n statusText: payload.statusText,\n statusCode: payload.status,\n };\n case VIDEO_DETAIL_RESET:\n return INITIAL_STATE;\n default:\n return state;\n }\n}\n","import { standardAction, errorAction } from \"../common/actions\";\nimport types from \"./types\";\n\nconst {\n VIDEO_DETAIL_REQUEST,\n VIDEO_DETAIL_SUCCESS,\n VIDEO_DETAIL_FAILURE,\n VIDEO_DETAIL_RESET,\n} = types;\n\nconst doVideoDetailRequest = (payload) =>\n standardAction(VIDEO_DETAIL_REQUEST, payload);\nconst doVideoDetailSuccess = (payload) =>\n standardAction(VIDEO_DETAIL_SUCCESS, payload);\nconst doVideoDetailFailure = (payload) =>\n errorAction(VIDEO_DETAIL_FAILURE, payload);\nconst doVideoDetailReset = (payload) =>\n standardAction(VIDEO_DETAIL_RESET, payload);\n\nexport default {\n doVideoDetailRequest,\n doVideoDetailSuccess,\n doVideoDetailFailure,\n doVideoDetailReset,\n};\n","import actions from \"./actions\";\nimport endpoints from \"../api/endpoints\";\nimport { updateVideos } from \"../../../Pages/Video/VideoActions\";\nimport { actions as videoAssociationActions } from \"../videoAssociations\";\n\nconst { doVideoDetailRequest, doVideoDetailSuccess, doVideoDetailFailure } =\n actions;\n\nconst fetchVideoDetail = (videoId) => (dispatch) => {\n dispatch(doVideoDetailRequest());\n $.ajax({\n method: \"get\",\n url: endpoints.videoDetail.replace(\"{{videoId}}\", videoId),\n success(data, statusText, { status }) {\n dispatch(doVideoDetailSuccess({ data, statusText, status }));\n },\n error(xhr) {\n dispatch(doVideoDetailFailure(xhr));\n },\n });\n};\n\nconst updateVideoDetail =\n (videoId, payload, isRemove = false) =>\n (dispatch, getState) => {\n dispatch(doVideoDetailRequest());\n //const { store } = window;\n const globalState = getState();\n const { videos, videoData } = globalState || {};\n $.ajax({\n method: \"put\",\n url: endpoints.videoDetail.replace(\"{{videoId}}\", videoId),\n data: payload,\n success(data, statusText, { status }) {\n dispatch(\n videoAssociationActions.doVideoAssociationsSuccess({\n data,\n statusText,\n status,\n })\n );\n if (!isRemove) {\n const newVideos = videos.map((el) => {\n const { video } = el;\n if (video._id === videoId) {\n return data;\n }\n return el;\n });\n dispatch(updateVideos(newVideos, videoData));\n }\n dispatch(doVideoDetailSuccess({ data, statusText, status }));\n },\n error(xhr) {\n dispatch(doVideoDetailFailure(xhr));\n },\n });\n };\n\nexport default {\n fetchVideoDetail,\n updateVideoDetail,\n};\n","import reducer from \"./reducer\";\nimport types from \"./types\";\nimport actions from \"./actions\";\nimport operations from \"./operations\";\n\nexport { types, actions, operations };\n\nexport default reducer;\n","const COPIED_TEXT = \"COPIED_TEXT\";\n\nexport const updateCopiedText = (text) => ({ type: COPIED_TEXT, text });\n\nconst copiedText = (state = null, payload = {}) => {\n const { type, text } = payload;\n return type === COPIED_TEXT ? text : state;\n};\n\nexport default copiedText;\n","export default \"\"","import { useEffect, useState } from \"react\";\n\nconst TikTokPlayer = (props) => {\n const [video, setVideo] = useState(props.video);\n\n useEffect(() => {\n if (props.video._id !== video._id) {\n const refreshVideo = setInterval(() => {\n const videoPlayer = document.getElementById(\"video-tiktok\");\n if (videoPlayer) {\n clearInterval(refreshVideo);\n }\n }, 1000);\n\n setVideo(props.video);\n }\n }, [props.video, video._id]);\n\n return (\n \n {video && (\n \n )}\n
\n );\n};\n\nexport default TikTokPlayer;\n","const CrossSVG = () => {\n return (\n \n \n \n \n );\n};\n\nexport default CrossSVG;\n","const VIDEO_PRODUCTS_REQUEST = \"videoProducts/REQUEST\";\nconst VIDEO_PRODUCTS_SUCCESS = \"videoProducts/SUCCESS\";\nconst VIDEO_PRODUCTS_FAILURE = \"videoProducts/FAILURE\";\nconst VIDEO_PRODUCTS_RESET = \"videoProducts/RESET\";\n\nexport default {\n VIDEO_PRODUCTS_REQUEST,\n VIDEO_PRODUCTS_SUCCESS,\n VIDEO_PRODUCTS_FAILURE,\n VIDEO_PRODUCTS_RESET,\n};\n","import types from \"./types\";\nimport { IDLE, LOADING, SUCCESS, FAILURE } from \"../common/status\";\n\nconst {\n VIDEO_PRODUCTS_REQUEST,\n VIDEO_PRODUCTS_SUCCESS,\n VIDEO_PRODUCTS_FAILURE,\n VIDEO_PRODUCTS_RESET,\n} = types;\n\nconst INITIAL_STATE = {\n body: [],\n error: null,\n status: IDLE,\n statusText: \"\",\n statusCode: null,\n};\n\nexport default function (state = INITIAL_STATE, action) {\n const { type, payload } = action;\n\n switch (type) {\n case VIDEO_PRODUCTS_REQUEST:\n return {\n ...state,\n status: LOADING,\n };\n case VIDEO_PRODUCTS_SUCCESS:\n return {\n ...state,\n status: SUCCESS,\n body: payload.data,\n statusCode: payload.status,\n };\n case VIDEO_PRODUCTS_FAILURE:\n return {\n ...state,\n status: FAILURE,\n error: payload,\n statusText: payload.statusText,\n statusCode: payload.status,\n };\n case VIDEO_PRODUCTS_RESET:\n return INITIAL_STATE;\n default:\n return state;\n }\n}\n","import { standardAction, errorAction } from \"../common/actions\";\nimport types from \"./types\";\n\nconst {\n VIDEO_PRODUCTS_REQUEST,\n VIDEO_PRODUCTS_SUCCESS,\n VIDEO_PRODUCTS_FAILURE,\n VIDEO_PRODUCTS_RESET,\n} = types;\n\nconst doVideoProductsRequest = (payload) =>\n standardAction(VIDEO_PRODUCTS_REQUEST, payload);\nconst doVideoProductsSuccess = (payload) =>\n standardAction(VIDEO_PRODUCTS_SUCCESS, payload);\nconst doVideoProductsFailure = (payload) =>\n errorAction(VIDEO_PRODUCTS_FAILURE, payload);\nconst doVideoProductsReset = (payload) =>\n standardAction(VIDEO_PRODUCTS_RESET, payload);\n\nexport default {\n doVideoProductsRequest,\n doVideoProductsSuccess,\n doVideoProductsFailure,\n doVideoProductsReset,\n};\n","import actions from \"./actions\";\nimport endpoints from \"../api/endpoints\";\n\nconst {\n doVideoProductsRequest,\n doVideoProductsSuccess,\n doVideoProductsFailure,\n} = actions;\n\nconst fetchVideoProducts = (videoId) => (dispatch) => {\n dispatch(doVideoProductsRequest());\n $.ajax({\n method: \"get\",\n url: endpoints.videoProducts.replace(\"{{videoId}}\", videoId),\n success(data, statusText, { status }) {\n dispatch(doVideoProductsSuccess({ data, statusText, status }));\n },\n error(xhr) {\n dispatch(doVideoProductsFailure(xhr));\n },\n });\n};\n\nexport default {\n fetchVideoProducts,\n};\n","import reducer from \"./reducer\";\nimport types from \"./types\";\nimport actions from \"./actions\";\nimport operations from \"./operations\";\n\nexport { types, actions, operations };\n\nexport default reducer;\n","export const SWITCH_BRAND = \"SWITCH_BRAND\";\n\nexport const requestSwitchBrand = ({ brand_id, brand_name }) => ({\n type: SWITCH_BRAND,\n brand_id,\n brand_name,\n});\n","// ** Imports createContext function\nimport { createContext } from \"react\";\n\n// ** Imports createContextualCan function\nimport { createContextualCan } from \"@casl/react\";\n\n// ** Create Context\nexport const AbilityContext = createContext();\n\n// ** Init Can Context\nexport const Can = createContextualCan(AbilityContext.Consumer);\n","export default __webpack_public_path__ + \"static/media/8-small.34d2edd5.png\";","export default __webpack_public_path__ + \"static/media/12-small.59ec58ce.png\";","export default __webpack_public_path__ + \"static/media/03.1c67b250.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-13.41f43dab.jpg\";","import { cloneDeep } from \"lodash\";\nimport Cookies from \"js-cookie\";\n\n// import { receiveServerErrors } from '../errors/error_actions';\n\nconst RECEIVE_LAST_SEEN_CHANNELS = \"RECEIVE_LAST_SEEN_CHANNELS\";\nconst RECEIVE_LAST_SEEN_CHANNEL = \"RECEIVE_LAST_SEEN_CHANNEL\";\n\nconst receiveChannels = (channels) => ({\n type: RECEIVE_LAST_SEEN_CHANNELS,\n channels,\n});\n\nconst receiveChannel = (channel) => ({\n type: RECEIVE_LAST_SEEN_CHANNEL,\n channel,\n});\n\nexport const fetchChannels = () => (dispatch) =>\n $.ajax({\n method: \"get\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/channels`,\n data: {\n brand_id: Cookies.get(\"bId\"),\n user_id: Cookies.get(\"uId\"),\n },\n success(channels) {\n dispatch(receiveChannels(channels));\n },\n error(xhr) {\n // dispatch(receiveServerErrors(xhr));\n },\n });\n\nexport const updateChannel = (id, data) => (dispatch) => {\n $.ajax({\n method: \"put\",\n url: `${process.env.REACT_APP_BASE_URL}/jwt_api/channels/${id}`,\n data,\n success(channel) {\n dispatch(receiveChannel(channel));\n },\n error(xhr) {\n // dispatch(receiveServerErrors(xhr));\n },\n });\n};\n\nexport const lastSeenChannels = (state = [], payload = {}) => {\n const { type, channels, channel } = payload;\n const newState = cloneDeep(state);\n switch (type) {\n case RECEIVE_LAST_SEEN_CHANNELS:\n return channels;\n case RECEIVE_LAST_SEEN_CHANNEL:\n const i = state.findIndex((c) => c.pubnub_id === channel.pubnub_id);\n if (i === -1) {\n newState.push(channel);\n } else {\n newState[i] = channel;\n }\n return newState;\n default:\n return state;\n }\n};\n","const VIDEO_LIST_REQUEST = \"videoList/REQUEST\";\nconst VIDEO_LIST_SUCCESS = \"videoList/SUCCESS\";\nconst VIDEO_LIST_FAILURE = \"videoList/FAILURE\";\nconst VIDEO_LIST_RESET = \"videoList/RESET\";\nconst VIDEO_LIST_ADD = \"videoList/ADD\";\n\nexport default {\n VIDEO_LIST_REQUEST,\n VIDEO_LIST_SUCCESS,\n VIDEO_LIST_FAILURE,\n VIDEO_LIST_RESET,\n VIDEO_LIST_ADD,\n};\n","import types from \"./types\";\nimport { IDLE, LOADING, SUCCESS, FAILURE } from \"../common/status\";\n\nconst {\n VIDEO_LIST_REQUEST,\n VIDEO_LIST_SUCCESS,\n VIDEO_LIST_FAILURE,\n VIDEO_LIST_RESET,\n VIDEO_LIST_ADD,\n} = types;\n\nconst INITIAL_STATE = {\n body: [],\n error: null,\n status: IDLE,\n statusText: \"\",\n statusCode: null,\n};\n\nexport default function (state = INITIAL_STATE, action) {\n const { type, payload } = action;\n\n switch (type) {\n case VIDEO_LIST_REQUEST:\n return {\n ...state,\n status: LOADING,\n };\n case VIDEO_LIST_SUCCESS:\n return {\n ...state,\n status: SUCCESS,\n body: payload.data,\n statusCode: payload.status,\n statusText: payload.statusText,\n };\n case VIDEO_LIST_ADD:\n return {\n ...state,\n status: SUCCESS,\n body: [...state.body, ...payload],\n };\n case VIDEO_LIST_FAILURE:\n return {\n ...state,\n status: FAILURE,\n error: payload,\n statusText: payload.statusText,\n statusCode: payload.status,\n };\n case VIDEO_LIST_RESET:\n return INITIAL_STATE;\n default:\n return state;\n }\n}\n","import { standardAction, errorAction } from \"../common/actions\";\nimport types from \"./types\";\n\nconst {\n VIDEO_LIST_REQUEST,\n VIDEO_LIST_SUCCESS,\n VIDEO_LIST_FAILURE,\n VIDEO_LIST_RESET,\n VIDEO_LIST_ADD,\n} = types;\n\nconst doVideoListRequest = (payload) =>\n standardAction(VIDEO_LIST_REQUEST, payload);\nconst doVideoListSuccess = (payload) =>\n standardAction(VIDEO_LIST_SUCCESS, payload);\nconst doVideoListFailure = (payload) =>\n errorAction(VIDEO_LIST_FAILURE, payload);\nconst doVideoListReset = (payload) => standardAction(VIDEO_LIST_RESET, payload);\nconst doVideoListAdd = (payload) => standardAction(VIDEO_LIST_ADD, payload);\n\nexport default {\n doVideoListRequest,\n doVideoListSuccess,\n doVideoListFailure,\n doVideoListReset,\n doVideoListAdd,\n};\n","import actions from \"./actions\";\nimport endpoints from \"../api/endpoints\";\n\nconst {\n doVideoListRequest,\n doVideoListSuccess,\n doVideoListFailure,\n doVideoListAdd,\n} = actions;\n\nconst fetchVideoList =\n (params, isAdding = false) =>\n (dispatch) => {\n dispatch(doVideoListRequest());\n $.ajax({\n method: \"get\",\n url: endpoints.videoList,\n data: params,\n success(data, statusText, { status }) {\n if (isAdding) {\n dispatch(doVideoListAdd(data ? data.videos || [] : []));\n } else {\n dispatch(\n doVideoListSuccess({\n data: data ? data.videos || [] : [],\n statusText,\n status,\n })\n );\n }\n },\n error(xhr) {\n dispatch(doVideoListFailure(xhr));\n },\n });\n };\n\nexport default {\n fetchVideoList,\n};\n","import reducer from \"./reducer\";\nimport types from \"./types\";\nimport actions from \"./actions\";\nimport operations from \"./operations\";\n\nexport { types, actions, operations };\n\nexport default reducer;\n","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/instagram_icon.be662ef5.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/close.128d1edc.svg\";","export default __webpack_public_path__ + \"static/media/dropbox-deleted.094653cb.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/SummaryError.5d59bc71.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/campaign.d6fe006d.png\";","export default __webpack_public_path__ + \"static/media/flagged.9263b075.png\";","export default __webpack_public_path__ + \"static/media/NoSummaryAvailable.22919b04.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/analyzingDataMessage.7e6f4d2e.png\";","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/my-products.10211cf1.jpg\";","export default __webpack_public_path__ + \"static/media/MyVideos.254b54f6.jpg\";","export default \"\"","export default __webpack_public_path__ + \"static/media/creators.b425a7bc.jpg\";","export default __webpack_public_path__ + \"static/media/brand.2e8609d1.jpg\";","export default __webpack_public_path__ + \"static/media/shopper.5d906d4d.jpg\";","export default \"\"","export default __webpack_public_path__ + \"static/media/27.6e221366.png\";","export default __webpack_public_path__ + \"static/media/26.36455f10.png\";","export default __webpack_public_path__ + \"static/media/25.76c78fa2.png\";","export default __webpack_public_path__ + \"static/media/24.ab73dba3.png\";","export default __webpack_public_path__ + \"static/media/23.b5cfac66.png\";","export default __webpack_public_path__ + \"static/media/22.9503518d.png\";","export default __webpack_public_path__ + \"static/media/21.cf4f5cc8.png\";","export default __webpack_public_path__ + \"static/media/20.3e941ed9.png\";","export default __webpack_public_path__ + \"static/media/19.5954cbf7.png\";","export default __webpack_public_path__ + \"static/media/18.026ea648.png\";","export default __webpack_public_path__ + \"static/media/17.87af0de0.png\";","export default __webpack_public_path__ + \"static/media/16.3cda5ff2.png\";","export default __webpack_public_path__ + \"static/media/15.971993ae.png\";","export default __webpack_public_path__ + \"static/media/14.90c7a24b.png\";","export default __webpack_public_path__ + \"static/media/13.f127d0f5.png\";","export default __webpack_public_path__ + \"static/media/12.28ae7022.png\";","export default __webpack_public_path__ + \"static/media/11.67c299f8.png\";","export default __webpack_public_path__ + \"static/media/10.0815a1b1.png\";","export default __webpack_public_path__ + \"static/media/9.89feb552.png\";","export default __webpack_public_path__ + \"static/media/8.cb23d30f.png\";","export default __webpack_public_path__ + \"static/media/7.0a9d1776.png\";","export default __webpack_public_path__ + \"static/media/6.72ede113.png\";","export default __webpack_public_path__ + \"static/media/5.280939a5.png\";","export default __webpack_public_path__ + \"static/media/4.9573c075.png\";","export default __webpack_public_path__ + \"static/media/3.b3c8f04e.png\";","export default __webpack_public_path__ + \"static/media/2.64ec9144.png\";","export default __webpack_public_path__ + \"static/media/1.0c19af20.png\";","export default \"\"","export default __webpack_public_path__ + \"static/media/kb-image.e310b4d3.jpg\";","export default __webpack_public_path__ + \"static/media/white-pinn.9c881027.png\";","export default __webpack_public_path__ + \"static/media/vyrill_logo_with_text.ded44798.png\";","export default __webpack_public_path__ + \"static/media/logo_drive.bd086da7.svg\";","export default __webpack_public_path__ + \"static/media/vyrill_app_logo.d870099e.svg\";","export default {\n platform: [],\n note: [],\n pov: [],\n demographic: { age_range: [], ethnicity: [], gender: [] },\n category: [],\n product: { radio: true, value: null },\n competitor_brands: { radio: true, value: null },\n};\n","export default \"\"","export default __webpack_public_path__ + \"static/media/12.761057bd.png\";","export default __webpack_public_path__ + \"static/media/timeline.91041dd4.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-18.9af4f6d3.jpg\";","export default __webpack_public_path__ + \"static/media/2.ce6a0451.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-22.d21f2121.jpg\";","export default __webpack_public_path__ + \"static/media/25.b2ba32bd.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-15.37a99cd4.jpg\";","export default __webpack_public_path__ + \"static/media/user-13.a5c1b5aa.jpg\";","export default __webpack_public_path__ + \"static/media/user-02.14e3bc05.jpg\";","export default __webpack_public_path__ + \"static/media/user-03.680deb88.jpg\";","export default __webpack_public_path__ + \"static/media/user-04.cb73a993.jpg\";","export default __webpack_public_path__ + \"static/media/user-05.e3f603db.jpg\";","export default __webpack_public_path__ + \"static/media/user-06.98e7a260.jpg\";","export default __webpack_public_path__ + \"static/media/user-07.7d2fc5cc.jpg\";","export default __webpack_public_path__ + \"static/media/user-08.98c05135.jpg\";","export default __webpack_public_path__ + \"static/media/user-09.5b8ab77e.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-12.09119fd6.jpg\";","export default __webpack_public_path__ + \"static/media/02.7b36c041.jpg\";","export default __webpack_public_path__ + \"static/media/06.1c554057.jpg\";","export default __webpack_public_path__ + \"static/media/04.aa9354e9.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-14.ea440a6a.jpg\";","export default __webpack_public_path__ + \"static/media/09.0a36d812.jpg\";","export default __webpack_public_path__ + \"static/media/10.da20d572.jpg\";","export default __webpack_public_path__ + \"static/media/banner-22.ef7c71c5.jpg\";","export default \"\"","export default __webpack_public_path__ + \"static/media/banner-39.7081a958.jpg\";","export default __webpack_public_path__ + \"static/media/banner-35.5c5c7794.jpg\";","export default __webpack_public_path__ + \"static/media/banner-12.3bf1dcd0.jpg\";","export default __webpack_public_path__ + \"static/media/Pot1.430ec954.svg\";","export default __webpack_public_path__ + \"static/media/Pot2.4c202bd9.svg\";","export default __webpack_public_path__ + \"static/media/Pot3.b2940082.svg\";","export default __webpack_public_path__ + \"static/media/avatar-s-26.974f64da.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-25.301316d5.jpg\";","export default __webpack_public_path__ + \"static/media/sales.48b19d43.svg\";","export default __webpack_public_path__ + \"static/media/marketing.ea1e3c4f.svg\";","export default __webpack_public_path__ + \"static/media/api.fb3b32d5.svg\";","export default __webpack_public_path__ + \"static/media/personalization.a7646583.svg\";","export default __webpack_public_path__ + \"static/media/email.03e998e9.svg\";","export default __webpack_public_path__ + \"static/media/demand.70f9d066.svg\";","export default __webpack_public_path__ + \"static/media/11-small.5c61c575.png\";","var map = {\n\t\"./NoSummaryAvailable.png\": 476,\n\t\"./SummaryError.png\": 463,\n\t\"./addLink.png\": 477,\n\t\"./analyzed.png\": 452,\n\t\"./analyzingDataMessage.png\": 478,\n\t\"./big-comment.png\": 479,\n\t\"./big-like.png\": 480,\n\t\"./big-view.png\": 481,\n\t\"./brand-safety-icon.png\": 514,\n\t\"./brandSafety.png\": 464,\n\t\"./campaignIcon.png\": 482,\n\t\"./campaignRewardIcon.png\": 483,\n\t\"./close.svg\": 458,\n\t\"./creatorIcon.png\": 515,\n\t\"./dateIcon.png\": 484,\n\t\"./demo-edit-icon.png\": 516,\n\t\"./demographicsAddIcon.png\": 485,\n\t\"./descriptionIcon.png\": 486,\n\t\"./dollarIcon.png\": 487,\n\t\"./dropbox-deleted.png\": 459,\n\t\"./dropboxIcon.png\": 488,\n\t\"./editPen.png\": 460,\n\t\"./editPenBlack.png\": 489,\n\t\"./emailIcon.png\": 490,\n\t\"./expand-right-icon.png\": 447,\n\t\"./expandDown.png\": 517,\n\t\"./favIcon.png\": 518,\n\t\"./flagIcon.png\": 519,\n\t\"./hashIcon.png\": 520,\n\t\"./info.png\": 454,\n\t\"./left-arrow.png\": 491,\n\t\"./minors.png\": 465,\n\t\"./musicIcon.png\": 492,\n\t\"./negativeSentimentIcon.png\": 493,\n\t\"./newCreatorIcon.png\": 494,\n\t\"./notAnalyzed.png\": 450,\n\t\"./notesIcon.png\": 495,\n\t\"./pendingAnalysis.png\": 453,\n\t\"./positiveSentimentIcon.png\": 466,\n\t\"./productFeatured.png\": 496,\n\t\"./publishWhiteIcon.png\": 497,\n\t\"./publishWidget.png\": 521,\n\t\"./publishWidgetWhite.png\": 522,\n\t\"./publishedActive.png\": 523,\n\t\"./publishedIcon.png\": 498,\n\t\"./publishedModal.png\": 524,\n\t\"./publishedNonActive.png\": 525,\n\t\"./publishedSwirll.png\": 467,\n\t\"./restore.png\": 290,\n\t\"./right-arrow.png\": 499,\n\t\"./saveIcon.png\": 500,\n\t\"./see-original.png\": 501,\n\t\"./shareIcon.png\": 502,\n\t\"./sizeIcon.png\": 503,\n\t\"./sound-icon.png\": 526,\n\t\"./sound.png\": 468,\n\t\"./speech-icon.png\": 527,\n\t\"./speech.png\": 469,\n\t\"./summaryAccordion.png\": 504,\n\t\"./swirlLogo.png\": 470,\n\t\"./tagsIcon.png\": 528,\n\t\"./tikTokIcon.png\": 471,\n\t\"./trashIcon.png\": 505,\n\t\"./unPublishWidgetWhite.png\": 529,\n\t\"./unPublishedModal.png\": 530,\n\t\"./unPublishedSwirll.png\": 506,\n\t\"./unpublish-Icon.png\": 472,\n\t\"./unpublishWidget.png\": 531,\n\t\"./uploadVideo.png\": 532,\n\t\"./upload_image_video.png\": 507,\n\t\"./videoDetail.png\": 508,\n\t\"./vyrillData.png\": 509,\n\t\"./watchIcon.png\": 510,\n\t\"./youtubeIcon.png\": 473\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = 907;","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const getBookmarks = createAsyncThunk(\n \"layout/getBookmarks\",\n async () => {\n const response = await axios.get(\"/api/bookmarks/data\");\n return {\n data: response.data.suggestions,\n bookmarks: response.data.bookmarks,\n };\n }\n);\n\nexport const updateBookmarked = createAsyncThunk(\n \"layout/updateBookmarked\",\n async (id) => {\n await axios.post(\"/api/bookmarks/update\", { id });\n return id;\n }\n);\n\nexport const layoutSlice = createSlice({\n name: \"layout\",\n initialState: {\n query: \"\",\n bookmarks: [],\n suggestions: [],\n },\n reducers: {\n handleSearchQuery: (state, action) => {\n state.query = action.payload;\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(getBookmarks.fulfilled, (state, action) => {\n state.suggestions = action.payload.data;\n state.bookmarks = action.payload.bookmarks;\n })\n .addCase(updateBookmarked.fulfilled, (state, action) => {\n let objectToUpdate;\n\n // ** find & update object\n state.suggestions.find((item) => {\n if (item.id === action.payload) {\n item.isBookmarked = !item.isBookmarked;\n objectToUpdate = item;\n }\n });\n\n // ** Get index to add or remove bookmark from array\n const bookmarkIndex = state.bookmarks.findIndex(\n (x) => x.id === action.payload\n );\n\n if (bookmarkIndex === -1) {\n state.bookmarks.push(objectToUpdate);\n } else {\n state.bookmarks.splice(bookmarkIndex, 1);\n }\n });\n },\n});\n\nexport const { handleSearchQuery } = layoutSlice.actions;\n\nexport default layoutSlice.reducer;\n","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const getTasks = createAsyncThunk(\"appTodo/getTasks\", async (params) => {\n const response = await axios.get(\"/apps/todo/tasks\", { params });\n\n return {\n params,\n data: response.data,\n };\n});\n\nexport const addTask = createAsyncThunk(\n \"appTodo/addTask\",\n async (task, { dispatch, getState }) => {\n const response = await axios.post(\"/apps/todo/add-tasks\", { task });\n await dispatch(getTasks(getState().todo.params));\n return response.data;\n }\n);\n\nexport const updateTask = createAsyncThunk(\n \"appTodo/updateTask\",\n async (task, { dispatch, getState }) => {\n const response = await axios.post(\"/apps/todo/update-task\", { task });\n await dispatch(getTasks(getState().todo.params));\n return response.data;\n }\n);\n\nexport const deleteTask = createAsyncThunk(\n \"appTodo/deleteTask\",\n async (taskId, { dispatch, getState }) => {\n const response = await axios.delete(\"/apps/todo/delete-task\", { taskId });\n await dispatch(getTasks(getState().todo.params));\n return response.data;\n }\n);\n\nexport const appTodoSlice = createSlice({\n name: \"appTodo\",\n initialState: {\n tasks: [],\n selectedTask: {},\n params: {\n filter: \"\",\n q: \"\",\n sort: \"\",\n tag: \"\",\n },\n },\n reducers: {\n reOrderTasks: (state, action) => {\n state.tasks = action.payload;\n },\n selectTask: (state, action) => {\n state.selectedTask = action.payload;\n },\n },\n extraReducers: (builder) => {\n builder.addCase(getTasks.fulfilled, (state, action) => {\n state.tasks = action.payload.data;\n state.params = action.payload.params;\n });\n },\n});\n\nexport const { reOrderTasks, selectTask } = appTodoSlice.actions;\n\nexport default appTodoSlice.reducer;\n","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const getUserProfile = createAsyncThunk(\"appChat/getTasks\", async () => {\n const response = await axios.get(\"/apps/chat/users/profile-user\");\n return response.data;\n});\n\nexport const getChatContacts = createAsyncThunk(\n \"appChat/getChatContacts\",\n async () => {\n const response = await axios.get(\"/apps/chat/chats-and-contacts\");\n return response.data;\n }\n);\n\nexport const selectChat = createAsyncThunk(\n \"appChat/selectChat\",\n async (id, { dispatch }) => {\n const response = await axios.get(\"/apps/chat/get-chat\", { id });\n await dispatch(getChatContacts());\n return response.data;\n }\n);\n\nexport const sendMsg = createAsyncThunk(\n \"appChat/sendMsg\",\n async (obj, { dispatch }) => {\n const response = await axios.post(\"/apps/chat/send-msg\", { obj });\n await dispatch(selectChat(obj.contact.id));\n return response.data;\n }\n);\n\nexport const appChatSlice = createSlice({\n name: \"appChat\",\n initialState: {\n chats: [],\n contacts: [],\n userProfile: {},\n selectedUser: {},\n },\n reducers: {},\n extraReducers: (builder) => {\n builder\n .addCase(getUserProfile.fulfilled, (state, action) => {\n state.userProfile = action.payload;\n })\n .addCase(getChatContacts.fulfilled, (state, action) => {\n state.chats = action.payload.chatsContacts;\n state.contacts = action.payload.contacts;\n })\n .addCase(selectChat.fulfilled, (state, action) => {\n state.selectedUser = action.payload;\n });\n },\n});\n\nexport default appChatSlice.reducer;\n","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const getAllData = createAsyncThunk(\"appUsers/getAllData\", async () => {\n const response = await axios.get(\"/api/users/list/all-data\");\n return response.data;\n});\n\nexport const getData = createAsyncThunk(\"appUsers/getData\", async (params) => {\n const response = await axios.get(\"/api/users/list/data\", params);\n return {\n params,\n data: response.data.users,\n totalPages: response.data.total,\n };\n});\n\nexport const getUser = createAsyncThunk(\"appUsers/getUser\", async (id) => {\n const response = await axios.get(\"/api/users/user\", { id });\n return response.data.user;\n});\n\nexport const addUser = createAsyncThunk(\n \"appUsers/addUser\",\n async (user, { dispatch, getState }) => {\n await axios.post(\"/apps/users/add-user\", user);\n await dispatch(getData(getState().users.params));\n await dispatch(getAllData());\n return user;\n }\n);\n\nexport const deleteUser = createAsyncThunk(\n \"appUsers/deleteUser\",\n async (id, { dispatch, getState }) => {\n await axios.delete(\"/apps/users/delete\", { id });\n await dispatch(getData(getState().users.params));\n await dispatch(getAllData());\n return id;\n }\n);\n\nexport const appUsersSlice = createSlice({\n name: \"appUsers\",\n initialState: {\n data: [],\n total: 1,\n params: {},\n allData: [],\n selectedUser: null,\n },\n reducers: {},\n extraReducers: (builder) => {\n builder\n .addCase(getAllData.fulfilled, (state, action) => {\n state.allData = action.payload;\n })\n .addCase(getData.fulfilled, (state, action) => {\n state.data = action.payload.data;\n state.params = action.payload.params;\n state.total = action.payload.totalPages;\n })\n .addCase(getUser.fulfilled, (state, action) => {\n state.selectedUser = action.payload;\n });\n },\n});\n\nexport default appUsersSlice.reducer;\n","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const getMails = createAsyncThunk(\n \"appEmail/getMails\",\n async (params) => {\n const response = await axios.get(\"/apps/email/emails\", { params });\n return {\n params,\n data: response.data,\n };\n }\n);\n\nexport const updateMails = createAsyncThunk(\n \"appEmail/updateMails\",\n async ({ emailIds, dataToUpdate }, { dispatch, getState }) => {\n const response = await axios.post(\"/apps/email/update-emails\", {\n emailIds,\n dataToUpdate,\n });\n await dispatch(getMails(getState().email.params));\n return {\n emailIds,\n dataToUpdate,\n data: response.data,\n };\n }\n);\n\nexport const updateMailLabel = createAsyncThunk(\n \"appEmail/updateMailLabel\",\n async ({ emailIds, label }, { dispatch, getState }) => {\n const response = await axios.post(\"/apps/email/update-emails-label\", {\n emailIds,\n label,\n });\n await dispatch(getMails(getState().email.params));\n return response.data;\n }\n);\n\nexport const paginateMail = createAsyncThunk(\n \"appEmail/paginateMail\",\n async ({ dir, emailId }) => {\n const response = await axios.get(\"/apps/email/paginate-email\", {\n params: { dir, emailId },\n });\n return response.data;\n }\n);\n\nexport const selectCurrentMail = createAsyncThunk(\n \"appEmail/selectCurrentMail\",\n async (id) => {\n const response = await axios.get(\"/apps/email/get-email\", { id });\n return response.data;\n }\n);\n\nexport const appEmailSlice = createSlice({\n name: \"appEmail\",\n initialState: {\n mails: [],\n params: {},\n emailsMeta: {},\n selectedMails: [],\n currentMail: null,\n },\n reducers: {\n selectMail: (state, action) => {\n const selectedMails = state.selectedMails;\n if (!selectedMails.includes(action.payload)) {\n selectedMails.push(action.payload);\n } else {\n selectedMails.splice(selectedMails.indexOf(action.payload), 1);\n }\n state.selectedMails = selectedMails;\n },\n selectAllMail: (state, action) => {\n const selectAllMailsArr = [];\n if (action.payload) {\n selectAllMailsArr.length = 0;\n state.mails.forEach((mail) => selectAllMailsArr.push(mail.id));\n } else {\n selectAllMailsArr.length = 0;\n }\n state.selectedMails = selectAllMailsArr;\n },\n resetSelectedMail: (state) => {\n state.selectedMails = [];\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(getMails.fulfilled, (state, action) => {\n let currMail = null;\n if (state.currentMail !== null && state.currentMail !== undefined) {\n currMail = action.payload.data.emails.find(\n (i) => i.id === state.currentMail.id\n );\n }\n state.currentMail = currMail;\n state.params = action.payload.params;\n state.mails = action.payload.data.emails;\n state.emailsMeta = action.payload.data.emailsMeta;\n })\n .addCase(updateMails.fulfilled, (state, action) => {\n function updateMailData(email) {\n Object.assign(email, action.payload.dataToUpdate);\n }\n state.mails.forEach((email) => {\n if (action.payload.emailIds.includes(email.id)) {\n updateMailData(email);\n }\n });\n })\n .addCase(paginateMail.fulfilled, (state, action) => {\n const data = action.payload;\n const dataIndex = state.mails.findIndex((i) => i.id === data.id);\n dataIndex === 0\n ? (data.hasPreviousMail = false)\n : (data.hasPreviousMail = true);\n dataIndex === state.mails.length - 1\n ? (data.hasNextMail = false)\n : (data.hasNextMail = true);\n state.currentMail = data;\n })\n .addCase(selectCurrentMail.fulfilled, (state, action) => {\n state.currentMail = action.payload;\n });\n },\n});\n\nexport const { selectMail, selectAllMail, resetSelectedMail } =\n appEmailSlice.actions;\n\nexport default appEmailSlice.reducer;\n","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const getData = createAsyncThunk(\n \"appInvoice/getData\",\n async (params) => {\n const response = await axios.get(\"/apps/invoice/invoices\", params);\n return {\n params,\n data: response.data.invoices,\n allData: response.data.allData,\n totalPages: response.data.total,\n };\n }\n);\n\nexport const deleteInvoice = createAsyncThunk(\n \"appInvoice/deleteInvoice\",\n async (id, { dispatch, getState }) => {\n await axios.delete(\"/apps/invoice/delete\", { id });\n await dispatch(getData(getState().invoice.params));\n return id;\n }\n);\n\nexport const appInvoiceSlice = createSlice({\n name: \"appInvoice\",\n initialState: {\n data: [],\n total: 1,\n params: {},\n allData: [],\n },\n reducers: {},\n extraReducers: (builder) => {\n builder.addCase(getData.fulfilled, (state, action) => {\n state.data = action.payload.data;\n state.allData = action.payload.allData;\n state.total = action.payload.totalPages;\n state.params = action.payload.params;\n });\n },\n});\n\nexport default appInvoiceSlice.reducer;\n","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const fetchEvents = createAsyncThunk(\n \"appCalendar/fetchEvents\",\n async (calendars) => {\n const response = await axios.get(\"/apps/calendar/events\", { calendars });\n return response.data;\n }\n);\n\nexport const addEvent = createAsyncThunk(\n \"appCalendar/addEvent\",\n async (event, { dispatch, getState }) => {\n await axios.post(\"/apps/calendar/add-event\", { event });\n await dispatch(fetchEvents(getState().calendar.selectedCalendars));\n return event;\n }\n);\n\nexport const updateEvent = createAsyncThunk(\n \"appCalendar/updateEvent\",\n async (event, { dispatch, getState }) => {\n await axios.post(\"/apps/calendar/update-event\", { event });\n await dispatch(fetchEvents(getState().calendar.selectedCalendars));\n return event;\n }\n);\n\nexport const updateFilter = createAsyncThunk(\n \"appCalendar/updateFilter\",\n async (filter, { dispatch, getState }) => {\n if (getState().calendar.selectedCalendars.includes(filter)) {\n await dispatch(\n fetchEvents(\n getState().calendar.selectedCalendars.filter((i) => i !== filter)\n )\n );\n } else {\n await dispatch(\n fetchEvents([...getState().calendar.selectedCalendars, filter])\n );\n }\n return filter;\n }\n);\n\nexport const updateAllFilters = createAsyncThunk(\n \"appCalendar/updateAllFilters\",\n async (value, { dispatch }) => {\n if (value === true) {\n await dispatch(\n fetchEvents([\"Personal\", \"Business\", \"Family\", \"Holiday\", \"ETC\"])\n );\n } else {\n await dispatch(fetchEvents([]));\n }\n return value;\n }\n);\n\nexport const removeEvent = createAsyncThunk(\n \"appCalendar/removeEvent\",\n async (id) => {\n await axios.delete(\"/apps/calendar/remove-event\", { id });\n return id;\n }\n);\n\nexport const appCalendarSlice = createSlice({\n name: \"appCalendar\",\n initialState: {\n events: [],\n selectedEvent: {},\n selectedCalendars: [\"Personal\", \"Business\", \"Family\", \"Holiday\", \"ETC\"],\n },\n reducers: {\n selectEvent: (state, action) => {\n state.selectedEvent = action.payload;\n },\n },\n extraReducers: (builder) => {\n builder\n .addCase(fetchEvents.fulfilled, (state, action) => {\n state.events = action.payload;\n })\n .addCase(updateFilter.fulfilled, (state, action) => {\n if (state.selectedCalendars.includes(action.payload)) {\n state.selectedCalendars.splice(\n state.selectedCalendars.indexOf(action.payload),\n 1\n );\n } else {\n state.selectedCalendars.push(action.payload);\n }\n })\n .addCase(updateAllFilters.fulfilled, (state, action) => {\n const value = action.payload;\n let selected = [];\n if (value === true) {\n selected = [\"Personal\", \"Business\", \"Family\", \"Holiday\", \"ETC\"];\n } else {\n selected = [];\n }\n state.selectedCalendars = selected;\n });\n },\n});\n\nexport const { selectEvent } = appCalendarSlice.actions;\n\nexport default appCalendarSlice.reducer;\n","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const getProducts = createAsyncThunk(\n \"appEcommerce/getProducts\",\n async (params) => {\n const response = await axios.get(\"/apps/ecommerce/products\", { params });\n return { params, data: response.data };\n }\n);\n\nexport const addToCart = createAsyncThunk(\n \"appEcommerce/addToCart\",\n async (id, { dispatch, getState }) => {\n const response = await axios.post(\"/apps/ecommerce/cart\", {\n productId: id,\n });\n await dispatch(getProducts(getState().ecommerce.params));\n return response.data;\n }\n);\n\nexport const getWishlistItems = createAsyncThunk(\n \"appEcommerce/getWishlistItems\",\n async () => {\n const response = await axios.get(\"/apps/ecommerce/wishlist\");\n return response.data;\n }\n);\n\nexport const deleteWishlistItem = createAsyncThunk(\n \"appEcommerce/deleteWishlistItem\",\n async (id, { dispatch }) => {\n const response = await axios.delete(`/apps/ecommerce/wishlist/${id}`);\n dispatch(getWishlistItems());\n return response.data;\n }\n);\n\nexport const getCartItems = createAsyncThunk(\n \"appEcommerce/getCartItems\",\n async () => {\n const response = await axios.get(\"/apps/ecommerce/cart\");\n return response.data;\n }\n);\n\nexport const getProduct = createAsyncThunk(\n \"appEcommerce/getProduct\",\n async (slug) => {\n const response = await axios.get(`/apps/ecommerce/products/${slug}`);\n return response.data;\n }\n);\n\nexport const addToWishlist = createAsyncThunk(\n \"appEcommerce/addToWishlist\",\n async (id) => {\n await axios.post(\"/apps/ecommerce/wishlist\", { productId: id });\n return id;\n }\n);\n\nexport const deleteCartItem = createAsyncThunk(\n \"appEcommerce/deleteCartItem\",\n async (id, { dispatch }) => {\n await axios.delete(`/apps/ecommerce/cart/${id}`);\n dispatch(getCartItems());\n return id;\n }\n);\n\nexport const appEcommerceSlice = createSlice({\n name: \"appEcommerce\",\n initialState: {\n cart: [],\n params: {},\n products: [],\n wishlist: [],\n totalProducts: 0,\n productDetail: {},\n },\n reducers: {},\n extraReducers: (builder) => {\n builder\n .addCase(getProducts.fulfilled, (state, action) => {\n state.params = action.payload.params;\n state.products = action.payload.data.products;\n state.totalProducts = action.payload.data.total;\n })\n .addCase(getWishlistItems.fulfilled, (state, action) => {\n state.wishlist = action.payload.products;\n })\n .addCase(getCartItems.fulfilled, (state, action) => {\n state.cart = action.payload.products;\n })\n .addCase(getProduct.fulfilled, (state, action) => {\n state.productDetail = action.payload.product;\n });\n },\n});\n\nexport default appEcommerceSlice.reducer;\n","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const getData = createAsyncThunk(\n \"datatables/getData\",\n async (params) => {\n const response = await axios.get(\"/api/datatables/data\", params);\n return {\n allData: response.data.allData,\n data: response.data.invoices,\n totalPages: response.data.total,\n params,\n };\n }\n);\n\nexport const datatablesSlice = createSlice({\n name: \"datatables\",\n initialState: {\n data: [],\n total: 1,\n params: {},\n allData: [],\n },\n reducers: {},\n extraReducers: (builder) => {\n builder.addCase(getData.fulfilled, (state, action) => {\n state.data = action.payload.data;\n state.params = action.payload.params;\n state.allData = action.payload.allData;\n state.total = action.payload.totalPages;\n });\n },\n});\n\nexport default datatablesSlice.reducer;\n","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from \"@reduxjs/toolkit\";\n\n// ** Axios Imports\nimport axios from \"axios\";\n\nexport const getData = createAsyncThunk(\n \"permissions/getData\",\n async (params) => {\n const response = await axios.get(\"/apps/permissions/data\", { params });\n return {\n total: response.data.total,\n params: response.data.params,\n allData: response.data.allData,\n data: response.data.permissions,\n };\n }\n);\n\nexport const addPermission = createAsyncThunk(\n \"permissions/addPermission\",\n async (permission, { dispatch, getState }) => {\n await axios.post(\"/apps/permissions/add-permission\", { permission });\n await dispatch(getData(getState().permissions.params));\n return permission;\n }\n);\n\nexport const updatePermission = createAsyncThunk(\n \"permissions/updatePermission\",\n async ({ id, name }, { dispatch, getState }) => {\n await axios.post(\"/apps/permissions/update-permission\", { id, name });\n await dispatch(getData(getState().permissions.params));\n return { id, name };\n }\n);\n\nexport const deletePermission = createAsyncThunk(\n \"permissions/deletePermission\",\n async (id, { dispatch, getState }) => {\n await axios.delete(\"/apps/permissions/delete\", { id });\n await dispatch(getData(getState().permissions.params));\n return id;\n }\n);\n\nexport const permissionsSlice = createSlice({\n name: \"permissions\",\n initialState: {\n data: [],\n total: 1,\n params: {},\n allData: [],\n selected: null,\n },\n reducers: {\n selectPermission: (state, action) => {\n if (action.payload === null) {\n state.selected = null;\n } else {\n state.selected = action.payload;\n }\n },\n },\n extraReducers: (builder) => {\n builder.addCase(getData.fulfilled, (state, action) => {\n state.data = action.payload.data;\n state.total = action.payload.total;\n state.params = action.payload.params;\n state.allData = action.payload.allData;\n });\n },\n});\n\nexport const { selectPermission } = permissionsSlice.actions;\n\nexport default permissionsSlice.reducer;\n","import {\n REQUEST_CURRENT_SESSION,\n RECEIVE_CURRENT_SESSION,\n RECEIVE_CURRENT_SESSION_INFLUENCER,\n LOGOUT,\n} from \"./session_actions\";\nimport {\n RECEIVE_SERVER_ERRORS,\n SERVER_DOWN_ERROR,\n RESET_LOADING,\n} from \"../Shared/Errors/errorActions\";\nimport { getCurrentBrandIfTryAndBuy } from \"../utilities\";\n\nexport const nullSession = {\n currentUser: {},\n roles: [],\n brands: [],\n userPicture: null,\n currentBrand: null,\n brandPicture: null,\n competitor: null,\n competitorPicture: null,\n influencer: {},\n influencerStatistics: {},\n tryAndBuyConfigurations: {},\n loading: false,\n serverDownModal: false,\n lastSignInAt: \"\",\n};\n\nconst sessionReducer = (state = nullSession, payload = {}) => {\n const { type, session, influencer, serverDownModal } = payload;\n switch (type) {\n case REQUEST_CURRENT_SESSION:\n return { ...state, loading: true };\n case RECEIVE_CURRENT_SESSION_INFLUENCER:\n return { ...state, influencer, loading: false };\n case RECEIVE_CURRENT_SESSION:\n return {\n ...state,\n ...session,\n currentBrand: getCurrentBrandIfTryAndBuy(\n session.currentBrand,\n session.currentUser && session.currentUser.try_and_buy\n ),\n loading: false,\n };\n case RECEIVE_SERVER_ERRORS:\n return { ...state, loading: false };\n case SERVER_DOWN_ERROR:\n return { ...state, serverDownModal };\n case RESET_LOADING:\n return { ...state, loading: !state.loading };\n case LOGOUT:\n return nullSession;\n default:\n return state;\n }\n};\n\nexport default sessionReducer;\n","import mixpanel from \"mixpanel-browser\";\nimport { SWITCH_BRAND } from \"./switch_brand_actions\";\n\nconst null_data = {\n brand_id: \"\",\n brand_name: \"\",\n};\n\nconst selectedBrandReducer = (state = null_data, payload = {}) => {\n const { type, brand_id, brand_name } = payload;\n switch (type) {\n case SWITCH_BRAND:\n mixpanel.register(\n { selected_brand_id: brand_id, selected_brand_name: brand_name },\n { persistent: false }\n );\n return { ...state, brand_id, brand_name };\n default:\n return state;\n }\n};\n\nexport default selectedBrandReducer;\n","import { clone } from \"lodash\";\nimport { combineReducers } from \"redux\";\nimport {\n RECEIVE_SERVER_ERRORS,\n RECEIVE_VALIDATION_ERRORS,\n RESET_SERVER_ERRORS,\n RESET_VALIDATION_ERRORS,\n RESET_EMAIL_PASSWORD_ERRORS,\n} from \"./errorActions\";\nimport { RECEIVE_CURRENT_SESSION } from \"../../Entry/session_actions\";\nimport { DISMISS_SERVER_MESSAGE } from \"../../Shared/ServerMessages/ServerMessageActions\";\n\nconst serverErrors = (state = [], payload = {}) => {\n const { type, xhr, message } = payload;\n const newState = clone(state);\n let i;\n switch (type) {\n case RECEIVE_SERVER_ERRORS:\n return xhr.responseJSON || [xhr.statusText];\n case DISMISS_SERVER_MESSAGE:\n i = newState.indexOf(message);\n if (i !== -1) newState.splice(i, 1);\n return newState;\n case RECEIVE_VALIDATION_ERRORS:\n case RECEIVE_CURRENT_SESSION:\n case RESET_SERVER_ERRORS:\n return [];\n default:\n return state;\n }\n};\n\nconst validationErrors = (state = {}, payload = {}) => {\n const { type, errors } = payload;\n switch (type) {\n case RECEIVE_VALIDATION_ERRORS:\n return errors;\n case RECEIVE_SERVER_ERRORS:\n case RESET_VALIDATION_ERRORS:\n return {};\n case RESET_EMAIL_PASSWORD_ERRORS:\n return {};\n default:\n return state;\n }\n};\n\nexport default combineReducers({ serverErrors, validationErrors });\n","import { clone } from \"lodash\";\nimport {\n RECEIVE_SERVER_MESSAGE,\n DISMISS_SERVER_MESSAGE,\n RESET_SERVER_MESSAGE,\n} from \"./ServerMessageActions\";\n\nconst serverMessagesReducer = (state = [], payload = {}) => {\n const { type, message } = payload;\n const newState = clone(state);\n let i;\n switch (type) {\n case RECEIVE_SERVER_MESSAGE:\n i = newState.indexOf(message);\n if (i === -1) newState.push(message);\n return newState;\n case DISMISS_SERVER_MESSAGE:\n i = newState.indexOf(message);\n if (i !== -1) newState.splice(i, 1);\n return newState;\n case RESET_SERVER_MESSAGE:\n return [];\n default:\n return state;\n }\n};\n\nexport default serverMessagesReducer;\n","import { cloneDeep } from \"lodash\";\nimport { productImage } from \"../../utilities\";\nimport {\n UPDATE_PRODUCT_PARAMS,\n REQUEST_PRODUCTS,\n RECEIVE_PRODUCTS,\n REQUEST_PRODUCT,\n RECEIVE_PRODUCT,\n REQUEST_PRODUCT_VIDEOS,\n RECEIVE_PRODUCT_VIDEOS,\n REQUEST_PRODUCT_INFLUENCERS,\n RECEIVE_PRODUCT_INFLUENCERS,\n REQUEST_PRODUCT_NAMES,\n RECEIVE_PRODUCT_NAMES,\n RECEIVE_CREATE_PRODUCT,\n REMOVE_ADDED_PRODUCT_INFO,\n REQUEST_ADD_PRODUCT_HASHTAG,\n RECEIVE_AUTO_COMPLETE_PRODUCT_OR_HASHTAG_LIST,\n RECEIVE_AUTO_COMPLETE_PRODUCT_OR_HASHTAG_CATEGORIES,\n RECEIVE_PRODUCT_ERRORS,\n RESET_FILTERS_PRODUCTS,\n REQUEST_EDIT_PRODUCT_HASHTAG,\n RECEIVE_UPDATE_PRODUCT,\n RECEIVE_PRODUCT_UPDATE_ERRORS,\n CLEAR_UPDATED_PRODUCT_DATA,\n RESET_PRODUCTS_DATA,\n PRODUCT_PAGE_STATES,\n} from \"./productActions\";\nimport { RECEIVE_CURRENT_SESSION } from \"../../Entry/session_actions\";\n\nexport const _nullProducts = [];\nexport const products = (state = _nullProducts, payload = {}) => {\n const { type, products, product } = payload;\n switch (type) {\n case RECEIVE_PRODUCTS:\n return products;\n case RECEIVE_PRODUCT:\n const newState = cloneDeep(state);\n const i = state.findIndex((p) => p._id === product._id);\n if (i === -1) {\n return [product];\n }\n newState[i] = product;\n return newState;\n case RESET_PRODUCTS_DATA:\n return _nullProducts;\n default:\n return state;\n }\n};\n\nconst filters = {\n note: [],\n category: [],\n influencer: [],\n brand: [],\n};\n\nexport const _nullParams = {\n desc: true,\n tab: \"My Products\",\n filters,\n trending: false,\n page: 1,\n isTrashTab: false,\n isFavoriteTab: false,\n};\n\nexport const productParams = (state = _nullParams, payload = {}) => {\n const { type, params } = payload;\n switch (type) {\n case RESET_FILTERS_PRODUCTS:\n return { ...state, filters };\n case UPDATE_PRODUCT_PARAMS:\n return { ...state, ...params };\n case RECEIVE_CURRENT_SESSION:\n return _nullParams;\n default:\n return state;\n }\n};\n\nexport const autoCompleteProductOrHashtagList = (state = {}, payload = {}) => {\n const { type, data } = payload;\n switch (type) {\n case RECEIVE_AUTO_COMPLETE_PRODUCT_OR_HASHTAG_LIST:\n return { ...state, data };\n default:\n return state;\n }\n};\n\nexport const autoCompleteProductOrHashtagCategories = (\n state = {},\n payload = {}\n) => {\n const { type, data } = payload;\n switch (type) {\n case RECEIVE_AUTO_COMPLETE_PRODUCT_OR_HASHTAG_CATEGORIES:\n return { ...state, data };\n default:\n return state;\n }\n};\n\nexport const createProduct = (state = {}, payload = {}) => {\n const { type, data, name } = payload;\n\n switch (type) {\n case REQUEST_ADD_PRODUCT_HASHTAG:\n return {\n ...state,\n name,\n loading: true,\n error: undefined,\n success: undefined,\n };\n case RECEIVE_CREATE_PRODUCT:\n return {\n ...state,\n success: data,\n loading: false,\n added: true,\n error: undefined,\n };\n case REMOVE_ADDED_PRODUCT_INFO:\n return {\n ...state,\n name: \"\",\n loading: false,\n added: false,\n };\n case RECEIVE_PRODUCT_ERRORS:\n const { xhr } = payload;\n return { ...state, error: xhr, success: undefined };\n default:\n return state;\n }\n};\n\nexport const updateProduct = (state = {}, payload = {}) => {\n const { type, data } = payload;\n\n switch (type) {\n case REQUEST_EDIT_PRODUCT_HASHTAG:\n return {\n ...state,\n loading: true,\n error: undefined,\n success: undefined,\n };\n case RECEIVE_UPDATE_PRODUCT:\n return {\n ...state,\n success: data,\n loading: false,\n error: undefined,\n };\n case RECEIVE_PRODUCT_UPDATE_ERRORS:\n const { xhr } = payload;\n return { ...state, error: xhr, success: undefined };\n case CLEAR_UPDATED_PRODUCT_DATA:\n return { ...state, loading: false, error: undefined, success: undefined };\n default:\n return state;\n }\n};\n\nconst _nullData = {\n filters,\n loading: false,\n loadingVideos: false,\n loadingInfluencers: false,\n loadingNames: false,\n videos: { trending: [], recent: [] },\n influencers: { trending: [], popular: [] },\n pictures: [],\n names: [],\n loaded_for: null,\n totalPages: 1,\n count: 0,\n // isCategoryPage: true,\n};\n\nexport const productData = (state = _nullData, payload = {}) => {\n const { type, data, videos, influencers, pictures, id, names } = payload;\n switch (type) {\n case REQUEST_PRODUCTS:\n return { ...state, loading: true };\n case RECEIVE_PRODUCTS:\n return { ...data, loading: false };\n case REQUEST_PRODUCT_VIDEOS:\n return { ...state, loadingVideos: id };\n case RECEIVE_PRODUCT_VIDEOS:\n if (state.loadingVideos === id) {\n return { ...state, videos, loadingVideos: false };\n }\n return { ...state }; // DO: stop loading?\n case REQUEST_PRODUCT_INFLUENCERS:\n return { ...state, loadingInfluencers: id };\n case RECEIVE_PRODUCT_INFLUENCERS:\n if (state.loadingInfluencers === id) {\n return { ...state, influencers, loadingInfluencers: false };\n }\n return { ...state }; // DO: stop loadingInfluencers?\n case REQUEST_PRODUCT:\n return { ...state, loading: true };\n case RECEIVE_PRODUCT:\n if (productImage({ _id: id }, state.pictures)) {\n return { ...state, loading: false };\n }\n return {\n ...state,\n pictures: [...state.pictures, ...pictures],\n loading: false,\n };\n case REQUEST_PRODUCT_NAMES:\n return { ...state, loadingNames: true };\n case RECEIVE_PRODUCT_NAMES:\n return { ...state, names, loadingNames: false };\n default:\n return state;\n }\n};\n\nconst _nullPageState = {\n isCategoryPage: true,\n itemId: \"\",\n moveToTrashModal: false,\n movedToTrash: false, //Single item\n removedFromTrash: false,\n showchecks: false,\n itemsCheckList: [],\n selectAllChecks: false,\n permanentDeleteModal: false,\n unFavoriteModal: false,\n modalFor: \"product\",\n // isProcessSuccessfull: false,\n restoreFromTrashModal: false,\n isDetailPage: false,\n processType: \"\",\n};\n\nexport const productPageStates = (state = _nullPageState, { type, status }) => {\n switch (type) {\n case PRODUCT_PAGE_STATES:\n return { ...state, ...status };\n default:\n return state;\n }\n};\n","/* eslint-disable */\nimport { combineReducers } from \"redux\";\nimport {\n RECEIVE_REPORTS,\n UPDATE_TAB,\n REPORT_PAGE_STATES,\n UPDATE_SPEECH_REPORT_TAB,\n UPDATE_SPEECH_REPORT_DATA,\n UPDATE_SPEECH_REPORT_FILTERS,\n UPDATE_SPEECH_REPORT_DURATION,\n UPDATE_SPEECH_REPORT_HIGHLIGHT,\n} from \"./ReportActions\";\n\nconst reports = (\n state = { reports: [], tabClicked: undefined },\n payload = {}\n) => {\n const { type, reports } = payload;\n return type === RECEIVE_REPORTS ? { reports, tabClicked: undefined } : state;\n};\n\nconst tab = (\n state = { tab: \"All Reports\", tabClicked: false },\n payload = {}\n) => {\n const { type, tab, tabClicked } = payload;\n return type === UPDATE_TAB ? { tab, tabClicked: tabClicked } : state;\n};\n\nconst _nullPageState = {\n isEnterFromHome: false,\n //Default report values\n activePlatforms: {\n wordcloud: \"All_platforms\",\n engagement: \"\",\n demographics: \"All_platforms\",\n },\n selectedCompetitors: {},\n};\n\nconst reportPageStates = (state = _nullPageState, { type, status }) => {\n switch (type) {\n case REPORT_PAGE_STATES:\n return { ...state, ...status };\n default:\n return state;\n }\n};\n\nconst initialSpeechReportFilters = {\n platform: [],\n note: [],\n pov: [],\n demographic: { age_range: [], ethnicity: [], gender: [] },\n category: [],\n product: { radio: true, value: null },\n competitor_brands: { radio: true, value: null },\n};\n\nconst speechReportInitialState = {\n highlight: '',\n tab: \"overview\",\n duration: \"6m\",\n data: {\n loading: true,\n loadingReport: true,\n loadingData: false,\n submitStatus: false,\n isFiltered: false,\n },\n selectedFilters: { ...initialSpeechReportFilters },\n initialSelectedFilters: { ...initialSpeechReportFilters },\n};\n\nconst speechReportReducer = (\n state = { ...speechReportInitialState },\n payload = {}\n) => {\n const { type, highlight, tab, data, selectedFilters, duration } = payload;\n switch (type) {\n case UPDATE_SPEECH_REPORT_HIGHLIGHT:\n return { ...state, highlight };\n case UPDATE_SPEECH_REPORT_TAB:\n return { ...state, tab };\n case UPDATE_SPEECH_REPORT_DATA:\n return { ...state, data: { ...state.data, ...data } };\n case UPDATE_SPEECH_REPORT_FILTERS:\n return { ...state, selectedFilters: { ...selectedFilters } };\n case UPDATE_SPEECH_REPORT_DURATION:\n return { ...state, duration };\n default:\n return state;\n }\n};\n\nexport default combineReducers({\n reports,\n tab,\n reportPageStates,\n speechReportReducer,\n});\n","import {\n RECEIVE_VIP_HOME_PAGE,\n RECEIVE_INFLUENCER_NAMES,\n RECEIVE_VIP_INFLUENCER_VIDEOS,\n REQUEST_VIP_INFLUENCER_VIDEOS,\n REQUEST_GAME_VIDEOS,\n RECEIVE_GAME_VIDEOS,\n RECEIVE_INFLUENCER_VIDEO_NOTE,\n REQUEST_INFLUENCER_VIDEO_NOTES,\n RECEIVE_INFLUENCER_VIDEO_NOTES,\n REQUEST_INFLUENCER_DAILY_TRACKINGS_DATA,\n RECEIVE_INFLUENCER_DAILY_TRACKINGS_DATA,\n REQUEST_VIDEO_URL,\n RECEIVE_VIDEO_URL,\n REQUEST_DROPBOX_VIDEO_URL,\n RECEIVE_DROPBOX_VIDEO_URL,\n} from \"./home_actions\";\n\nconst nullState = {\n influencerCount: 0,\n videoCount: 0,\n categories: [],\n countries: [],\n influencers: [],\n topics: [],\n trendingVideos: [],\n trendingInfluencers: [],\n recentVideos: [],\n loadingVideos: false,\n loadingGame: false,\n gameVideos: [],\n gameCount: 0,\n loadingNotes: false,\n influencerVideoNotes: [],\n loadingCounts: false,\n stats: {\n average_likes: null,\n average_views: null,\n average_video_length: null,\n },\n gameProducts: [],\n gameProductPictures: [],\n loaded_for: null,\n engagementIndexData: {\n average_views_per_video: null,\n average_engagement_index: null,\n influencer_performance_index: null,\n },\n loadingEngagementIndexData: false,\n video_url: null,\n loadingVideoUrl: false,\n dropbox_video: null,\n loadingDropBoxVideoUrl: false,\n};\n\nconst vipReducer = (state = nullState, payload = {}) => {\n const {\n type,\n data,\n influencers,\n recentVideos,\n influencerVideoNotes,\n note,\n engagementIndexData,\n video_url,\n dropbox_video,\n } = payload;\n switch (type) {\n case RECEIVE_VIP_HOME_PAGE:\n return { ...state, ...data };\n case RECEIVE_INFLUENCER_NAMES:\n return { ...state, influencers };\n case RECEIVE_VIP_INFLUENCER_VIDEOS:\n return { ...state, loadingVideos: false, recentVideos };\n case REQUEST_VIP_INFLUENCER_VIDEOS:\n return { ...state, loadingVideos: true };\n case REQUEST_GAME_VIDEOS:\n return { ...state, loadingGame: true };\n case RECEIVE_GAME_VIDEOS:\n return { ...state, ...data, loadingGame: false };\n case REQUEST_INFLUENCER_VIDEO_NOTES:\n return { ...state, loadingNotes: true };\n case RECEIVE_INFLUENCER_VIDEO_NOTES:\n return { ...state, influencerVideoNotes, loadingNotes: false };\n case RECEIVE_INFLUENCER_VIDEO_NOTE:\n const index = state.influencerVideoNotes.findIndex(\n ({ _id }) => _id === note._id\n );\n const notes = [...state.influencerVideoNotes];\n if (index !== -1) {\n notes[index] = note;\n } else {\n notes.push(note);\n }\n return { ...state, influencerVideoNotes: notes, loadingNotes: false };\n case REQUEST_INFLUENCER_DAILY_TRACKINGS_DATA:\n return { ...state, loadingEngagementIndexData: true };\n case RECEIVE_INFLUENCER_DAILY_TRACKINGS_DATA:\n return {\n ...state,\n engagementIndexData,\n loadingEngagementIndexData: false,\n };\n case REQUEST_VIDEO_URL:\n return { ...state, loadingVideoUrl: false };\n case RECEIVE_VIDEO_URL:\n return { ...state, video_url, loadingVideoUrl: true };\n case REQUEST_DROPBOX_VIDEO_URL:\n return { ...state, loadingDropBoxVideoUrl: false };\n case RECEIVE_DROPBOX_VIDEO_URL:\n return { ...state, dropbox_video, loadingDropBoxVideoUrl: true };\n default:\n return state;\n }\n};\n\nexport default vipReducer;\n","import {\n REQUEST_HOME_PAGE,\n RECEIVE_HOME_PAGE,\n REQUEST_COMPETITORS_BRAND,\n RECEIVE_COMPETITORS_BRAND,\n UPDATE_GRAPH_TYPE,\n HOME_ACTIVE_TAB,\n REQUEST_HOME_PAGE_GRAPH,\n RECEIVE_HOME_PAGE_GRAPH,\n} from \"./home_actions\";\n\nconst lodash = require(\"lodash\");\n\nconst _nullState = {\n counts: {\n products: 0,\n videos: 0,\n influencers: 0,\n },\n trending: {\n videos: [],\n influencers: [],\n },\n recent: {\n videos: [],\n influencers: [],\n },\n demographics: {\n age: [],\n gender: [],\n ethnicity: [],\n },\n loadingHome: false,\n loaded_for: null,\n brand_engagement_graph: [],\n your_word_cloud: [],\n competitor_brands: [],\n isDataPresent: false,\n};\n\nconst homeReducer = (state = _nullState, payload = {}) => {\n const { type, data } = payload;\n switch (type) {\n case REQUEST_HOME_PAGE:\n return { ...state, loadingHome: true, isDataPresent: false };\n case RECEIVE_HOME_PAGE:\n return { ...data, loadingHome: false, isDataPresent: true };\n default:\n return state;\n }\n};\n\nexport default homeReducer;\n\nconst _nullCompetitorsState = {\n loading: false,\n competitors_brand: {},\n};\n\nexport const home_competitor_brands = (\n state = _nullCompetitorsState,\n { type, competitors_brand }\n) => {\n switch (type) {\n case REQUEST_COMPETITORS_BRAND:\n return { ...state, loading: true };\n case RECEIVE_COMPETITORS_BRAND:\n return {\n ...state,\n competitors_brand: { ...state.competitors_brand, ...competitors_brand },\n loading: false,\n };\n default:\n return state;\n }\n};\n\nconst _nullData = {\n duration_wise_brand_engagement_graph: false,\n duration_wise_demographics_data: false,\n duration_wise_your_word_cloud: false,\n\n myBrandTab: {\n // duration_wise_brand_engagement_graph: {},\n // duration_wise_demographics_data: {},\n // duration_wise_your_word_cloud: {},\n },\n competitorTab: {},\n};\n\nexport const home_Graph_Data = (state = _nullData, { type, data }) => {\n switch (type) {\n case REQUEST_HOME_PAGE_GRAPH:\n return { ...state, [data.url]: true };\n case RECEIVE_HOME_PAGE_GRAPH:\n if (!data.competitors_brands) {\n return {\n ...state,\n [data.url]: false,\n myBrandTab: {\n ...state.myBrandTab,\n [data.url]: {\n ...(state.myBrandTab[data.url] ? state.myBrandTab[data.url] : {}),\n [data.duration]: data.response,\n },\n },\n };\n } else if (data.competitors_brands) {\n let copyState = { ...state };\n copyState[data.url] = false;\n let { competitorTab } = copyState;\n if (competitorTab[data.competitors_brands]) {\n if (competitorTab[data.competitors_brands][data.url]) {\n if (\n competitorTab[data.competitors_brands][data.url][data.duration]\n ) {\n competitorTab[data.competitors_brands][data.url][data.duration] =\n data.response;\n } else {\n competitorTab[data.competitors_brands][data.url] = {\n ...competitorTab[data.competitors_brands][data.url],\n [data.duration]: data.response,\n };\n }\n } else {\n competitorTab[data.competitors_brands][data.url] = {\n [data.duration]: data.response,\n };\n }\n } else {\n competitorTab[data.competitors_brands] = {\n [data.url]: { [data.duration]: data.response },\n };\n }\n return { ...copyState };\n }\n default:\n return state;\n }\n};\n\nconst _defaultState = {\n status: \"6m\",\n};\n\nexport const switchGraphStatus = (state = _defaultState, { type, status }) => {\n switch (type) {\n case UPDATE_GRAPH_TYPE:\n return status;\n default:\n return state;\n }\n};\n\nconst _defaultTabState = {\n activeTab: \"My Brand\",\n};\n\nexport const switchActiveTab = (\n state = _defaultTabState,\n { type, activeTab }\n) => {\n switch (type) {\n case HOME_ACTIVE_TAB:\n return activeTab;\n default:\n return state;\n }\n};\n","import {\n REQUEST_NAVBAR_STATS,\n RECEIVE_NAVBAR_STATS,\n} from \"./navbarStatsActions\";\n\nconst _nullState = {\n brandPicture: {},\n brands: [],\n counts: {\n products: 0,\n videos: null,\n influencers: 0,\n },\n currentBrand: {},\n current_user: {\n first_name: \"\",\n last_name: \"\",\n _id: \"\",\n },\n priority_notification: {\n new_videos_count: 0,\n trending_videos_count: 0,\n },\n roles: [],\n loadingStats: false,\n};\n\nexport const navbarStatsReducer = (state = _nullState, payload = {}) => {\n const { type, data } = payload;\n switch (type) {\n case REQUEST_NAVBAR_STATS:\n return { ...state, loadingStats: true };\n case RECEIVE_NAVBAR_STATS:\n return { ...data, loadingStats: false };\n default:\n return state;\n }\n};\n","import { ADD_PRODUCT_MODAL } from \"./GlobalParamsActions\";\n\nconst _nullGlobalParams = {\n addProductState: false,\n};\nexport const globalParamStates = (\n state = _nullGlobalParams,\n { type, data }\n) => {\n switch (type) {\n case ADD_PRODUCT_MODAL:\n return { ...state, ...data };\n default:\n return state;\n }\n};\n","import { combineReducers } from \"redux\";\nimport {\n RECEIVE_BRAND_NAMES,\n RECEIVE_CATEGORY_NAMES,\n} from \"./register_actions\";\n\nconst brands = (state = [], payload = {}) => {\n const { type, brands } = payload;\n return type === RECEIVE_BRAND_NAMES ? brands : state;\n};\n\nconst categories = (state = [], payload = {}) => {\n const { type, categories } = payload;\n return type === RECEIVE_CATEGORY_NAMES ? categories : state;\n};\n\nexport default combineReducers({ brands, categories });\n","import {\n REQUEST_CAMPAIGN,\n RECEIVE_CAMPAIGN,\n ADD_CAMPAIGN,\n RECEIVE_ADDED_CAMPAIGN,\n FAILURE_ADDED_CAMPAIGN,\n SEND_EMAIL,\n RECEIVE_RESPONSE,\n RECEIVE_INFLUENCERS_CAMPAIGN,\n RESET_RESPONSE,\n} from \"./CampaignActions\";\n\nconst _nullData = {\n loading: false,\n campaign: {\n currentBrandName: \"\",\n myProducts: [],\n myBrands: [],\n competitionProducts: [],\n competitionBrands: [],\n existingCampaigns: [],\n },\n loadingCampaign: false,\n data: {\n mailCampaign: {},\n },\n loadingResponse: false,\n response: {\n sentMail: false,\n },\n influencersCampaign: {},\n};\n\nexport default (state = _nullData, payload = {}) => {\n const { data, type, campaign, response, influencersCampaign } = payload;\n switch (type) {\n case REQUEST_CAMPAIGN:\n return { ...state, loading: true };\n case RECEIVE_CAMPAIGN:\n return { ...state, campaign, loading: false };\n case ADD_CAMPAIGN:\n return { ...state, loadingCampaign: true };\n case FAILURE_ADDED_CAMPAIGN:\n return { ...state, loadingCampaign: false };\n case RECEIVE_ADDED_CAMPAIGN:\n return {\n ...state,\n data,\n loadingCampaign: false,\n campaign: {\n ...state.campaign,\n existingCampaigns: [\n ...state.campaign.existingCampaigns,\n data.mailCampaign,\n ],\n },\n };\n case SEND_EMAIL:\n return { ...state, loadingResponse: true };\n case RECEIVE_RESPONSE:\n return { ...state, response, loadingResponse: false };\n case RESET_RESPONSE:\n return { ...state, response: { sentMail: false } };\n case RECEIVE_INFLUENCERS_CAMPAIGN:\n return { ...state, influencersCampaign };\n default:\n return state;\n }\n};\n","import { TUTORIAL_STATES } from \"./TutorialActions\";\n\nconst _nullState = {\n isTutorial: true,\n activeTutorial: \"home-overview\", // first-video, video-detail, home-overview\n activeStep: 1,\n isVistComplete: false,\n openVideoModal: false,\n totalSteps: 5,\n};\n\nexport const tutorials_states = (state = _nullState, { type, status }) => {\n switch (type) {\n case TUTORIAL_STATES:\n return { ...state, ...status };\n default:\n return state;\n }\n \n};\n","import {\n UPDATE_ACTIVE_DURATION,\n UPDATE_PRODUCT_SORTING,\n UPDATE_DASHBOARD_STATE,\n UPDATE_METRICS_DATA,\n UPDATE_GUIDE_MODAL,\n UPDATE_CUSTOM_DATE,\n UPDATE_SELECTED_CAROUSEL,\n UPDATE_SELECTED_DEVICE,\n UPDATE_VIDEO_DATA,\n UPDATE_PRODUCT_DATA,\n} from \"./Actions\";\n\nconst _nullState = {\n selectedDuration: {\n value: \"1y\",\n label: \"\",\n },\n productSortingOptions: [\n \"highest_sentiment\",\n \"lowest_sentiment\",\n \"new_products\",\n \"highest_video_reviews\",\n ],\n productsSortBy: \"highest_sentiment\",\n videoReviewsCollected: {},\n videoReviewsCollectedLoading: false,\n userGuideModal: false,\n custom_start_date: \"\",\n custom_end_date: \"\",\n metricsData: null,\n fetchedVideoData: null,\n fetchedProductData: null,\n selectedCarousel: {\n id: \"all\",\n name: \"\",\n },\n selectedDevice: \"Desktop\",\n};\n\nconst DashboardReducer = (state = _nullState, payload = {}) => {\n const {\n type,\n selectedDuration,\n productsSortBy,\n data,\n userGuideModal,\n customDate,\n metricsData,\n selectedCarousel,\n selectedDevice,\n fetchedVideoData,\n fetchedProductData,\n } = payload;\n switch (type) {\n case UPDATE_ACTIVE_DURATION:\n return {\n ...state,\n selectedDuration,\n };\n\n case UPDATE_PRODUCT_SORTING:\n return {\n ...state,\n productsSortBy,\n };\n case UPDATE_GUIDE_MODAL:\n return {\n ...state,\n userGuideModal,\n };\n case UPDATE_CUSTOM_DATE:\n return {\n ...state,\n ...customDate,\n };\n\n case UPDATE_DASHBOARD_STATE:\n return { ...state, ...data };\n\n case UPDATE_METRICS_DATA:\n return {\n ...state,\n metricsData,\n };\n case UPDATE_VIDEO_DATA:\n return {\n ...state,\n fetchedVideoData,\n };\n case UPDATE_PRODUCT_DATA:\n return {\n ...state,\n fetchedProductData,\n };\n case UPDATE_SELECTED_CAROUSEL:\n return {\n ...state,\n selectedCarousel: {\n id: selectedCarousel.id,\n name: selectedCarousel.name,\n },\n };\n case UPDATE_SELECTED_DEVICE:\n return {\n ...state,\n selectedDevice,\n };\n\n default:\n return state;\n }\n};\n\nexport default DashboardReducer;\n","import {\n UPDATE_ASK_VYRILL_STATE,\n RESET_ASK_VYRILL_STATE,\n UPDATE_SINGLE_MESSAGE,\n UPDATE_ASK_VYRILL_MODAL,\n} from \"./Actions\";\n\n// TODO:\nexport interface RootState {\n askVyrill: askVyrillState;\n}\n\ninterface askVyrillState {\n selectedPrompt: string;\n messages: any[];\n conversationId: string;\n loadFromHistory: boolean;\n allPrompts: any[];\n isFirstPrompt: boolean;\n allConversations: any[];\n messagesLoading: boolean;\n askVyrillError: boolean;\n historyLoading: boolean;\n askVyrillTimoutError: boolean;\n askVyrillDuration: {\n value: string;\n label: string;\n };\n custom_start_date:string;\n custom_end_date:string;\n isNewChat: boolean;\n askVyrillModal: {\n shouldOpen: boolean;\n requestFrom: string;\n };\n}\n\nconst _nullState: askVyrillState = {\n selectedPrompt: \"\",\n messages: [],\n conversationId: \"\",\n loadFromHistory: false,\n allPrompts: [],\n isFirstPrompt: false,\n allConversations: [],\n messagesLoading: false,\n askVyrillError: false,\n askVyrillTimoutError: false,\n historyLoading: false,\n askVyrillDuration: {\n value: \"1y\",\n label: \"\",\n },\n custom_start_date : \"\",\n custom_end_date : \"\",\n isNewChat: false,\n askVyrillModal: { shouldOpen: false, requestFrom: \"\" },\n};\n\nconst askVyrill = (state: askVyrillState = _nullState, payload: any = {}) => {\n const { data, type } = payload;\n switch (type) {\n case UPDATE_ASK_VYRILL_STATE:\n return { ...state, ...data };\n\n case UPDATE_SINGLE_MESSAGE:\n return {\n ...state,\n messages: state.messages.map((obj) =>\n obj._id === data.id ? { ...obj, ...data.updatedMessage } : obj\n ),\n };\n\n case UPDATE_ASK_VYRILL_MODAL:\n return {\n ...state,\n askVyrillModal: { ...state.askVyrillModal, ...data },\n };\n\n case RESET_ASK_VYRILL_STATE:\n return {\n ..._nullState,\n };\n\n default:\n return state;\n }\n};\n\nexport default askVyrill;\n","import { UPDATE_TRANSCRIPT_MODAL, UPDATE_CONFIRMATION_MODAL, ASK_VYRILL_INTRO_MODAL } from \"./Actions\";\n\nconst _nullState = {\n videoTranscript: {\n shouldOpen: false,\n videoId: \"\",\n videoStartAt: 0,\n pinSentence: \"\",\n pinTime: 0,\n },\n\n confirmationProcess: {\n shouldOpen: false,\n message: \"\",\n },\n // other modals\n askVyrillIntro:{\n showIntro:false\n }\n};\n\nconst modalsState = (state = _nullState, payload = {}) => {\n const { type, data } = payload;\n switch (type) {\n case UPDATE_TRANSCRIPT_MODAL:\n return {\n ...state,\n videoTranscript: { ...state.videoTranscript, ...data },\n };\n\n case UPDATE_CONFIRMATION_MODAL:\n return {\n ...state,\n confirmationProcess: { ...state.confirmationProcess, ...data },\n };\n\n case ASK_VYRILL_INTRO_MODAL:\n return {\n ...state,\n askVyrillIntro: { ...state.askVyrillIntro, ...data },\n };\n\n default:\n return state;\n }\n};\n\nexport default modalsState;\n","import { EditorState, convertFromHTML, ContentState } from \"draft-js\";\nimport { CAMPAIGN_STATES, UPDATE_FORM_FIELDS } from \"./CampaignActions\";\nimport moment from \"moment\";\n\nconst _nullState = {\n // isTutorial: true,\n // activeTutorial: \"home-overview\", // first-video, video-detail, home-overview\n activeStep: 1,\n // isVistComplete: false,\n totalSteps: 5,\n qrModal: false,\n form: {\n _id: \"\",\n campaign_headline: \"\",\n campaign_hashtag: \"\",\n campaign_brand_name: \"\",\n campaign_product: \"\",\n campaign_banner_image: \"\",\n campaign_banner_image_file: null,\n productimageURL: \"\",\n campaign_brand_image_preview: \"\",\n campaign_brand_image: \"\",\n campaign_description: \"\",\n brand_instruction: \"\",\n campaign_headline_editor: \"\",\n campaign_reward: \"\",\n end_date: null,\n time: \"\",\n start_date: moment(),\n start_time: \"\",\n end_time: \"\",\n campaign_timezone: \"GMT-07:00 (Pacific Daylight Time)\",\n currentTime: \"\",\n campaign_reward_type: \"\",\n ongoing: false,\n products: [],\n campaign_video_limit: 200, //Backend\n campaign_video_length: \"\",\n campaign_allow_rating: false,\n banner_with_qr: \"\",\n terms_and_conditions: \"\",\n image_dimensions: \"Fit\",\n description_editor_state: null,\n brand_instruction_editor_state: null,\n terms_and_conditions_editor_state: null,\n headline_editor_state: null,\n hashtag_editor_state: null,\n campaign_hashtag_editor: \"\",\n preview_color_change: \"#526261\",\n // color_change_hashtag: \"#FC80BB\",\n campaign_video_length_type: \"\",\n campaign_button_color: \"#96C392\",\n campaign_button_text_color: \"white\",\n campaign_upload_platform: [],\n },\n campaign_response: null,\n timezones: [\n {\n value: \"GMT-10:00 (Hawaii Standard Time)\",\n label: \"(GMT -10:00) Hawaii Standard Time\",\n },\n {\n value: \"GMT-09:00 (Hawaii-Aleutian Daylight Time)\",\n label: \"(GMT -09:00) Hawaii-Aleutian Daylight Time\",\n },\n {\n value: \"GMT-09:00 (Alaska Daylight Time)\",\n label: \"(GMT -09:00) Alaska Daylight Time\",\n },\n {\n value: \"GMT-07:00 (Pacific Daylight Time)\",\n label: \"(GMT -07:00) Pacific Daylight Time\",\n },\n {\n value: \"GMT-06:00 (Mountain Daylight Time)\",\n label: \"(GMT -06:00) Mountain Daylight Time\",\n },\n {\n value: \"GMT-05:00 (Central Daylight Time)\",\n label: \"(GMT -05:00) Central Daylight Time\",\n },\n {\n value: \"GMT-04:00 (Eastern Daylight Time)\",\n label: \"(GMT -04:00) Eastern Daylight Time\",\n },\n ],\n};\n\nexport const campaign_states = (state = _nullState, { type, status }) => {\n switch (type) {\n case CAMPAIGN_STATES:\n return { ...state, ...status };\n case UPDATE_FORM_FIELDS:\n return {\n ...state,\n form: {\n ...state.form,\n ...status,\n },\n };\n default:\n return state;\n }\n};\n","import {\n ADD_SELECTED_VIDEO,\n REMOVE_SELECTED_VIDEO,\n WIDGET_STATES,\n CLEAR_SELECTED_VIDEOS,\n UPDATE_VIDEO_SETTINGS,\n} from \"./WidgetAction\";\n\nconst _nullState = {\n activeStep: 1,\n createCarousel: false,\n update_widget: false,\n openCodePopup: false,\n openNotesPopup: false,\n openPopup: false,\n enableSearch: true,\n enableSorting: true,\n enableTag: true,\n enableBrandTag: true,\n enableRatingVideo: true,\n productRatingVideo: false,\n enableHighlight: true,\n video_summary: true,\n key_thumbnails: true,\n key_highlights: true,\n is_edit: false,\n video_caption: true,\n product_img: true,\n product_price: true,\n custom_color: false,\n play_button: false,\n powered_by_vyrill: true,\n selected_color: \"#409DB2\",\n play_button_color: \"#fff\",\n selectedVideos: [],\n carousels_data: [],\n single_widget_data: \"\",\n activeRatio: \"Portrait\",\n title: \"\",\n notes: \"\",\n page: \"\",\n discardModal: false,\n showAnnotation: true,\n call_to_action: false,\n button_copy: \"\",\n button_URL: \"\",\n menu_options: [\"most_recent\", \"ratings\", \"verified_shopper\", \"brand_video\"],\n device_options: [\"desktop\", \"mobile\"],\n selected_platform: \"\",\n update_widget_id: \"\",\n playlist_id: \"\",\n selectedTab: \"videocarousel\",\n selectedVideosTab: \"selectedVideosTab\",\n updated_message: \"\",\n gridView: true,\n next_video: 0,\n buy_now_button: false,\n button_color: \"#783AD0\",\n button_text_color: \"black\",\n buy_now_text_color: \"black\",\n button_color_stroke: \"#783AD0\",\n buy_now_color: \"#783AD0\",\n buy_now_color_stroke: \"#783AD0\",\n cta_fill: false,\n cta_stroke: false,\n buy_now_fill: false,\n buy_now_stroke: false,\n video_data: null,\n};\n\nexport const widget_states = (\n state = _nullState,\n { type, status, payload }\n) => {\n switch (type) {\n case ADD_SELECTED_VIDEO:\n return {\n ...state,\n selectedVideos: [\n ...state.selectedVideos,\n {\n video_id: payload.video_id,\n thumbnail_url: payload.thumbnail_url,\n title: payload.title,\n settings: payload.settings || {\n video_summary: true,\n key_thumbnails: true,\n key_highlights: true,\n video_caption: true,\n product_img: true,\n product_price: true,\n productRatingVideo: true,\n call_to_action: false,\n buy_now_button: false,\n button_color: \"#783AD0\",\n button_color_stroke: \"#783AD0\",\n buy_now_color: \"#783AD0\",\n buy_now_color_stroke: \"#783AD0\",\n button_text_color: \"black\",\n buy_now_text_color: \"black\",\n button_copy: \"\",\n button_URL: \"\",\n cta_fill: false,\n cta_stroke: false,\n buy_now_fill: false,\n buy_now_stroke: false,\n },\n },\n ],\n };\n case UPDATE_VIDEO_SETTINGS:\n return {\n ...state,\n selectedVideos: state.selectedVideos.map((video) =>\n video.video_id === payload.videoId\n ? {\n ...video,\n settings: { ...video.settings, ...payload.newSettings },\n }\n : video\n ),\n };\n case REMOVE_SELECTED_VIDEO:\n return {\n ...state,\n selectedVideos: state.selectedVideos.filter(\n (video) => video.video_id !== payload\n ),\n };\n case CLEAR_SELECTED_VIDEOS:\n return {\n ...state,\n selectedVideos: [],\n };\n case WIDGET_STATES:\n return { ...state, ...status };\n default:\n return state;\n }\n};\n","import {\n UPDATE_SENTIMENT_REPORT,\n UPDATE_ACTIVE_DURATION,\n UPDATE_PRODUCT_SORTING,\n UPDATE_PLATFORMS,\n UPDATE_VIDEOS_SORTING,\n UPDATE_VIDEOS_SEARCH\n} from \"./SentimentReportAction\";\n\nconst sentimentReportInitialState = {\n GenericStates: {\n tab: \"overview\",\n },\n SentimentByProduct: {},\n selectedDuration: {\n value: \"1y\",\n label: \"\",\n },\n productSortingOptions: [\n \"highest_sentiment\",\n \"lowest_sentiment\",\n \"new_products\",\n \"highest_video_reviews\",\n ],\n productsSortBy: \"highest_sentiment\",\n platformsOption: [\"All\"],\n videoSortingOptions: [\n \"highest_sentiment\",\n \"lowest_sentiment\",\n \"newest_videos\",\n \"oldest_videos\",\n \"favorite_videos\",\n ],\n videosSortBy: \"highest_sentiment\",\n search: \"\",\n};\n\nconst sentimentReportReducer = (\n state = sentimentReportInitialState,\n action\n) => {\n switch (action.type) {\n case UPDATE_SENTIMENT_REPORT:\n return {\n ...state,\n GenericStates: { ...state.GenericStates, ...action.data },\n };\n case UPDATE_ACTIVE_DURATION:\n return {\n ...state,\n selectedDuration: action.selectedDuration,\n };\n case UPDATE_PRODUCT_SORTING:\n return {\n ...state,\n productsSortBy: action.productsSortBy,\n };\n case UPDATE_VIDEOS_SORTING:\n return {\n ...state,\n videosSortBy: action.videosSortBy,\n };\n case UPDATE_VIDEOS_SEARCH:\n return {\n ...state,\n search: action.search,\n };\n case UPDATE_PLATFORMS:\n return {\n ...state,\n platformsOption: action.platformsOption,\n };\n default:\n return state;\n }\n};\n\nexport default sentimentReportReducer;\n","// ** Reducers Imports\nimport { combineReducers } from \"redux\";\nimport navbar from \"./navbar\";\nimport layout from \"./layout\";\nimport auth from \"./authentication\";\nimport todo from \"@src/views/apps/todo/store\";\nimport chat from \"@src/views/apps/chat/store\";\nimport users from \"@src/views/apps/user/store\";\nimport email from \"@src/views/apps/email/store\";\nimport invoice from \"@src/views/apps/invoice/store\";\nimport calendar from \"@src/views/apps/calendar/store\";\nimport ecommerce from \"@src/views/apps/ecommerce/store\";\nimport dataTables from \"@src/views/tables/data-tables/store\";\nimport permissions from \"@src/views/apps/roles-permissions/store\";\n\n// @Vyrill-Reducers\nimport session from \"../Entry/session_reducer\";\nimport selectedBrandReducer from \"../vyrill-ui-config/layout/sidebar/SwitchBrand/switch_brand_reducer\";\nimport errors from \"../Shared/Errors/errorsReducer\";\nimport serverMessages from \"../Shared/ServerMessages/ServerMessagesReducer\";\nimport {\n videos,\n singleVideoProducts,\n videoData,\n videoParams,\n videoProductsAll,\n vipInfluencerVideoNote,\n vipInfluencerVideoURL,\n vipInfluencerDropboxVideo,\n videoAuthor,\n transcript,\n toggleTranscript,\n downloadTranscript,\n keywordsOnly,\n videoPageStates,\n VideoDetailBreadcrumb,\n videoUploadDetail,\n PublishedPageStates,\n copyTranscriptReducer,\n videoAnalysisStatus,\n} from \"../Pages/Video/VideoReducers\";\n\nimport {\n products,\n productData,\n productParams,\n autoCompleteProductOrHashtagList,\n autoCompleteProductOrHashtagCategories,\n createProduct,\n updateProduct,\n productPageStates,\n} from \"../Pages/Product/ProductsReducers\";\nimport {\n videoNotes,\n productNotes,\n influencerNotes,\n} from \"../Shared/Notes/NotesReducers\";\nimport reports from \"../Pages/Reports/ReportsReducer\";\nimport copiedText from \"../Shared/CopyText/CopyRedux\";\nimport videoList from \"../Shared/modules/videoList\";\nimport videoDetail from \"../Shared/modules/videoDetail\";\nimport videoProducts from \"../Shared/modules/videoProducts\";\nimport videoAssociations from \"../Shared/modules/videoAssociations\";\nimport vip from \"../Pages/Home/vip_reducer\";\nimport home from \"../Pages/Home/home_reducer\";\nimport {\n home_competitor_brands,\n switchGraphStatus,\n switchActiveTab,\n home_Graph_Data,\n} from \"../Pages/Home/home_reducer\";\nimport { navbarStatsReducer } from \"../vyrill-ui-config/layout/sidebar/navbarStatsReducer\";\nimport {\n influencers,\n influencerData,\n influencerParams,\n influencerUser,\n InfluencerPageStates,\n} from \"../Pages/Influencer/influencers_reducers\";\nimport { globalParamStates } from \"../Shared/GlobalParams/GlobalParamsReducers\";\nimport {\n channels,\n messages,\n recipients,\n recipientsFetchedForUser,\n messagesFetchedForChannel,\n newChatRecipient,\n unreadMessageCounts,\n lastMessages,\n} from \"../Pages/Chat/ChatRedux\";\nimport { lastSeenChannels } from \"../Pages/Chat/ChannelsRedux\";\nimport {\n licenseRequestVideo,\n licenseAgreements,\n videoLicenseAgreements,\n licenseHistory,\n purchaseHistory,\n loadingLicenseHistory,\n loadingPurchaseHistory,\n} from \"../Shared/Licensing/licensing_redux\";\nimport register from \"../Entry/register_reducer\";\nimport campaignData from \"../Pages/Campaign/CampaignReducers\";\nimport { tutorials_states } from \"../Shared/Tutorials/TutorialReducers\";\nimport DashboardReducer from \"../Pages/Dashborad/DashboardReducer\";\nimport askVyrill from \"../Pages/AskVyrill/AskVyrillReducer\";\nimport modalsState from \"../Shared/PopUpModals/ModalsReducer\";\nimport { campaign_states } from \"../Pages/CreateCampaign/CamapaignReducers\";\nimport { widget_states } from \"../Pages/Widget/WidgetReducer\";\nimport sentimentReportReducer from \"../Pages/Reports/NewSentimentReport/SentimentReportReducer\";\n\nconst appReducer = combineReducers({\n auth,\n todo,\n chat,\n email,\n users,\n navbar,\n layout,\n invoice,\n calendar,\n ecommerce,\n dataTables,\n permissions,\n\n // @Vyrill\n register,\n sentimentReportReducer,\n selectedBrandReducer,\n session,\n products,\n productData,\n productParams,\n autoCompleteProductOrHashtagList,\n autoCompleteProductOrHashtagCategories,\n createProduct,\n updateProduct,\n productNotes,\n videoNotes,\n influencerNotes,\n errors,\n serverMessages,\n reports,\n copiedText,\n videos,\n singleVideoProducts,\n videoData,\n videoParams,\n videoProductsAll,\n vipInfluencerVideoNote,\n vipInfluencerVideoURL,\n vipInfluencerDropboxVideo,\n videoAuthor,\n transcript,\n toggleTranscript,\n downloadTranscript,\n keywordsOnly,\n videoList,\n videoDetail,\n videoProducts,\n videoAssociations,\n home,\n vip,\n influencers,\n influencerData,\n influencerParams,\n influencerUser,\n home_competitor_brands,\n home_Graph_Data,\n switchGraphStatus,\n switchActiveTab,\n navbarStatsReducer,\n globalParamStates,\n channels,\n messages,\n recipients,\n recipientsFetchedForUser,\n messagesFetchedForChannel,\n newChatRecipient,\n unreadMessageCounts,\n lastMessages,\n lastSeenChannels,\n licenseRequestVideo,\n licenseAgreements,\n videoLicenseAgreements,\n licenseHistory,\n purchaseHistory,\n loadingLicenseHistory,\n loadingPurchaseHistory,\n campaignData,\n videoPageStates,\n VideoDetailBreadcrumb,\n videoUploadDetail,\n productPageStates,\n InfluencerPageStates,\n PublishedPageStates,\n copyTranscriptReducer,\n tutorials_states,\n campaign_states,\n widget_states,\n DashboardReducer,\n videoAnalysisStatus,\n askVyrill,\n modalsState,\n});\n\nconst rootReducer = (state, action) => {\n if (action.type === \"LOGOUT\") {\n return appReducer(undefined, action);\n }\n\n return appReducer(state, action);\n};\n\nexport default rootReducer;\n","import { cloneDeep } from \"lodash\";\nimport {\n RECEIVE_VIDEO_NOTES,\n RECEIVE_VIDEO_NOTE,\n RECEIVE_PRODUCT_NOTES,\n RECEIVE_PRODUCT_NOTE,\n RECEIVE_INFLUENCER_NOTES,\n RECEIVE_INFLUENCER_NOTE,\n} from \"./NoteActions\";\n\nexport const videoNotes = (state = [], payload = {}) => {\n const { type, notes, note } = payload;\n const newState = cloneDeep(state);\n switch (type) {\n case RECEIVE_VIDEO_NOTES:\n return notes;\n case RECEIVE_VIDEO_NOTE:\n const i = state.findIndex((n) => n.video_id === note.video_id);\n if (i === -1) {\n newState.push(note);\n } else {\n newState[i] = note;\n }\n return newState;\n default:\n return state;\n }\n};\n\nexport const productNotes = (state = [], payload = {}) => {\n const { type, notes, note } = payload;\n const newState = cloneDeep(state);\n switch (type) {\n case RECEIVE_PRODUCT_NOTES:\n return notes;\n case RECEIVE_PRODUCT_NOTE:\n const i = state.findIndex((n) => n.product_id === note.product_id);\n if (i === -1) {\n newState.push(note);\n } else {\n newState[i] = note;\n }\n return newState;\n default:\n return state;\n }\n};\n\nexport const influencerNotes = (state = [], payload = {}) => {\n const { type, notes, note } = payload;\n const newState = cloneDeep(state);\n switch (type) {\n case RECEIVE_INFLUENCER_NOTES:\n return notes;\n case RECEIVE_INFLUENCER_NOTE:\n const i = state.findIndex(\n (n) => n.video_author_id === note.video_author_id\n );\n if (i === -1) {\n newState.push(note);\n } else {\n newState[i] = note;\n }\n return newState;\n default:\n return state;\n }\n};\n","import { isEqual } from \"lodash\";\nimport {\n UPDATE_VIDEO_PARAMS,\n RESET_FILTERS_VIDEOS,\n fetchVideos,\n} from \"./VideoActions\";\nimport { _nullParams } from \"./VideoReducers\";\n\nexport default (store) => (next) => (action) => {\n const { videoParams } = store.getState();\n\n if (action.type === UPDATE_VIDEO_PARAMS) {\n if (!isEqual(videoParams, action.params) && !action.params.updateParamsOnly) {\n store.dispatch(fetchVideos({ ...videoParams, ...action.params }));\n }\n }\n\n if (action.type === RESET_FILTERS_VIDEOS) {\n store.dispatch(\n fetchVideos({ ...videoParams, filters: _nullParams.filters })\n );\n }\n\n return next(action);\n};\n","import { isEqual } from \"lodash\";\nimport {\n UPDATE_INFLUENCER_PARAMS,\n RESET_FILTERS_INFLUENCERS,\n fetchInfluencers,\n} from \"./influencer_actions\";\nimport { filters } from \"./influencers_reducers\";\n\nexport default (store) => (next) => (action) => {\n const { influencerParams } = store.getState();\n if (action.type === UPDATE_INFLUENCER_PARAMS) {\n if (!isEqual(influencerParams, action.params)) {\n store.dispatch(\n fetchInfluencers({ ...influencerParams, ...action.params })\n );\n }\n }\n if (action.type === RESET_FILTERS_INFLUENCERS) {\n store.dispatch(fetchInfluencers({ ...influencerParams, filters }));\n }\n return next(action);\n};\n","// import { logout } from '../entry/session_actions'\nimport { RECEIVE_SERVER_ERRORS } from \"./errorActions\";\nimport { isEmpty } from \"../../utilities\";\n\nconst ErrorMiddleware = (store) => (next) => (action) => {\n const state = store.getState();\n if (action.type === RECEIVE_SERVER_ERRORS) {\n if (action.xhr.status === 401 && !isEmpty(state.session.currentUser)) {\n // return store.dispatch(logout())\n }\n }\n return next(action);\n};\n\nexport default ErrorMiddleware;\n","// ** Redux Imports\nimport rootReducer from \"./rootReducer\";\nimport { configureStore } from \"@reduxjs/toolkit\";\nimport videosMiddleware from \"../Pages/Video/VideosMiddleware\";\nimport influencersMiddleware from \"../Pages/Influencer/influencers_middleware\";\nimport errorMiddleware from \"../Shared/Errors/errorMiddleware\";\n\nconst store = configureStore({\n reducer: rootReducer,\n middleware: (getDefaultMiddleware) => {\n return getDefaultMiddleware({\n immutableCheck: false,\n serializableCheck: false,\n }).concat([videosMiddleware, influencersMiddleware, errorMiddleware]);\n },\n});\n\nexport { store };\n","import { Ability } from \"@casl/ability\";\nimport { initialAbility } from \"./initialAbility\";\n\n// Read ability from localStorage\n// * Handles auto fetching previous abilities if already logged in user\n// ? You can update this if you store user abilities to more secure place\n// ! Anyone can update localStorage so be careful and please update this\n\n// const userData = JSON.parse(localStorage.getItem('userData'))\n// const existingAbility = userData ? userData.ability : null\n\nexport default new Ability(initialAbility);\n","// ** Initial user ability\nexport const initialAbility = [\n {\n action: \"manage\",\n subject: \"all\",\n },\n];\n\nexport const _ = undefined;\n","// ** React Imports\nimport { useEffect, useState, createContext } from \"react\";\n\n// ** Create Context\nconst ThemeColors = createContext();\n\nconst ThemeContext = ({ children }) => {\n // ** State\n const [colors, setColors] = useState({});\n\n //** ComponentDidMount\n useEffect(() => {\n if (window !== \"undefined\") {\n //** Get variable value\n const getHex = (color) =>\n window.getComputedStyle(document.body).getPropertyValue(color).trim();\n\n //** Colors obj\n const obj = {\n primary: {\n light: getHex(\"--bs-primary\").concat(\"1a\"),\n main: getHex(\"--bs-primary\"),\n },\n secondary: {\n light: getHex(\"--bs-secondary\").concat(\"1a\"),\n main: getHex(\"--bs-secondary\"),\n },\n success: {\n light: getHex(\"--bs-success\").concat(\"1a\"),\n main: getHex(\"--bs-success\"),\n },\n danger: {\n light: getHex(\"--bs-danger\").concat(\"1a\"),\n main: getHex(\"--bs-danger\"),\n },\n warning: {\n light: getHex(\"--bs-warning\").concat(\"1a\"),\n main: getHex(\"--bs-warning\"),\n },\n info: {\n light: getHex(\"--bs-info\").concat(\"1a\"),\n main: getHex(\"--bs-info\"),\n },\n dark: {\n light: getHex(\"--bs-dark\").concat(\"1a\"),\n main: getHex(\"--bs-dark\"),\n },\n };\n\n setColors({ ...obj });\n }\n }, []);\n\n return (\n {children} \n );\n};\n\nexport { ThemeColors, ThemeContext };\n","// ** I18n Imports\nimport i18n from \"i18next\";\nimport Backend from \"i18next-xhr-backend\";\nimport { initReactI18next } from \"react-i18next\";\nimport LanguageDetector from \"i18next-browser-languagedetector\";\n\ni18n\n\n // Enables the i18next backend\n .use(Backend)\n\n // Enable automatic language detection\n .use(LanguageDetector)\n\n // Enables the hook initialization module\n .use(initReactI18next)\n .init({\n lng: \"en\",\n backend: {\n /* translation file path */\n loadPath: `${process.env.PUBLIC_URL}/assets/data/locales/{{lng}}.json`,\n },\n fallbackLng: \"en\",\n debug: false,\n keySeparator: false,\n react: {\n useSuspense: false,\n },\n interpolation: {\n escapeValue: false,\n formatSeparator: \",\",\n },\n });\n\nexport default i18n;\n","// ** React Imports\nimport { useState, useEffect } from \"react\";\n\n// ** Third Party Components\nimport classnames from \"classnames\";\n\n// ** Reactstrap Imports\nimport { Button } from \"reactstrap\";\n\n// ** Styles\nimport \"./ripple-button.scss\";\n\nconst RippleButton = ({ className, children, onClick, ...rest }) => {\n // ** States\n const [mounted, setMounted] = useState(false);\n const [isRippling, setIsRippling] = useState(false);\n const [coords, setCoords] = useState({ x: -1, y: -1 });\n\n // ** Toggle mounted on mount & unmount\n useEffect(() => {\n setMounted(true);\n return () => setMounted(false);\n }, []);\n\n // ** Check for coords and set ripple\n useEffect(() => {\n if (mounted) {\n if (coords.x !== -1 && coords.y !== -1) {\n setIsRippling(true);\n setTimeout(() => setIsRippling(false), 500);\n } else {\n setIsRippling(false);\n }\n }\n }, [coords]);\n\n // ** Reset Coords on ripple end\n useEffect(() => {\n if (mounted) {\n if (!isRippling) setCoords({ x: -1, y: -1 });\n }\n }, [isRippling]);\n\n return (\n {\n const rect = e.target.getBoundingClientRect();\n setCoords({ x: e.clientX - rect.left, y: e.clientY - rect.top });\n if (onClick) {\n onClick(e);\n }\n }}\n {...rest}\n >\n {children}\n {isRippling ? (\n \n ) : null}\n \n );\n};\n\n// ** PropTypes\nRippleButton.propTypes = {\n ...Button.propTypes,\n};\n\nButton.Ripple = RippleButton;\n","import axios from \"axios\";\nimport MockAdapter from \"axios-mock-adapter\";\n\nconst mock = new MockAdapter(axios);\n\nexport default mock;\n","import mock from \"../mock\";\nimport jwt from \"jsonwebtoken\";\n\nconst data = {\n users: [\n {\n id: 1,\n fullName: \"John Doe\",\n username: \"johndoe\",\n password: \"admin\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-11.jpg\")\n .default,\n email: \"admin@demo.com\",\n role: \"admin\",\n ability: [\n {\n action: \"manage\",\n subject: \"all\",\n },\n ],\n extras: {\n eCommerceCartItemsCount: 5,\n },\n },\n {\n id: 2,\n fullName: \"Jane Doe\",\n username: \"janedoe\",\n password: \"client\",\n avatar: require(\"@src/assets/images/avatars/1-small.png\").default,\n email: \"client@demo.com\",\n role: \"client\",\n ability: [\n {\n action: \"read\",\n subject: \"ACL\",\n },\n {\n action: \"read\",\n subject: \"Auth\",\n },\n ],\n extras: {\n eCommerceCartItemsCount: 5,\n },\n },\n ],\n};\n\n// ! These two secrets shall be in .env file and not in any other file\nconst jwtConfig = {\n secret: \"dd5f3089-40c3-403d-af14-d0c228b05cb4\",\n refreshTokenSecret: \"7c4c1c50-3230-45bf-9eae-c9b2e401c767\",\n expireTime: \"10m\",\n refreshTokenExpireTime: \"10m\",\n};\n\nmock.onPost(\"/jwt/login\").reply((request) => {\n const { email, password } = JSON.parse(request.data);\n\n let error = {\n email: [\"Something went wrong\"],\n };\n\n const user = data.users.find(\n (u) => u.email === email && u.password === password\n );\n\n if (user) {\n try {\n const accessToken = jwt.sign({ id: user.id }, jwtConfig.secret, {\n expiresIn: jwtConfig.expireTime,\n });\n const refreshToken = jwt.sign(\n { id: user.id },\n jwtConfig.refreshTokenSecret,\n {\n expiresIn: jwtConfig.refreshTokenExpireTime,\n }\n );\n\n const userData = { ...user };\n\n delete userData.password;\n\n const response = {\n userData,\n accessToken,\n refreshToken,\n };\n\n return [200, response];\n } catch (e) {\n error = e;\n }\n } else {\n error = {\n email: [\"Email or Password is Invalid\"],\n };\n }\n\n return [400, { error }];\n});\n\nmock.onPost(\"/jwt/register\").reply((request) => {\n if (request.data.length > 0) {\n const { email, password, username } = JSON.parse(request.data);\n const isEmailAlreadyInUse = data.users.find((user) => user.email === email);\n const isUsernameAlreadyInUse = data.users.find(\n (user) => user.username === username\n );\n const error = {\n email: isEmailAlreadyInUse ? \"This email is already in use.\" : null,\n username: isUsernameAlreadyInUse\n ? \"This username is already in use.\"\n : null,\n };\n\n if (!error.username && !error.email) {\n const userData = {\n email,\n password,\n username,\n fullName: \"\",\n avatar: null,\n role: \"admin\",\n ability: [\n {\n action: \"manage\",\n subject: \"all\",\n },\n ],\n };\n\n // Add user id\n const length = data.users.length;\n let lastIndex = 0;\n if (length) {\n lastIndex = data.users[length - 1].id;\n }\n userData.id = lastIndex + 1;\n\n data.users.push(userData);\n\n const accessToken = jwt.sign({ id: userData.id }, jwtConfig.secret, {\n expiresIn: jwtConfig.expireTime,\n });\n\n const user = Object.assign({}, userData);\n delete user[\"password\"];\n const response = { user, accessToken };\n\n return [200, response];\n } else {\n return [200, { error }];\n }\n }\n});\n\nmock.onPost(\"/jwt/refresh-token\").reply((request) => {\n const { refreshToken } = JSON.parse(request.data);\n\n try {\n const { id } = jwt.verify(refreshToken, jwtConfig.refreshTokenSecret);\n\n const userData = { ...data.users.find((user) => user.id === id) };\n\n const newAccessToken = jwt.sign({ id: userData.id }, jwtConfig.secret, {\n expiresIn: jwtConfig.expiresIn,\n });\n const newRefreshToken = jwt.sign(\n { id: userData.id },\n jwtConfig.refreshTokenSecret,\n {\n expiresIn: jwtConfig.refreshTokenExpireTime,\n }\n );\n\n delete userData.password;\n const response = {\n userData,\n accessToken: newAccessToken,\n refreshToken: newRefreshToken,\n };\n\n return [200, response];\n } catch (e) {\n const error = \"Invalid refresh token\";\n return [401, { error }];\n }\n});\n","import mock from \"../mock\";\nconst data = {\n faqData: {\n // payment\n payment: {\n icon: \"CreditCard\",\n title: \"Payment\",\n subtitle: \"Which license do I need?\",\n qandA: [\n {\n question: \"Does my subscription automatically renew?\",\n ans: \"Pastry pudding cookie toffee bonbon jujubes jujubes powder topping. Jelly beans gummi bears sweet roll bonbon muffin liquorice. Wafer lollipop sesame snaps. Brownie macaroon cookie muffin cupcake candy caramels tiramisu. Oat cake chocolate cake sweet jelly-o brownie biscuit marzipan. Jujubes donut marzipan chocolate bar. Jujubes sugar plum jelly beans tiramisu icing cheesecake.\",\n },\n {\n question:\n \"Can I store the item on an intranet so everyone has access?\",\n ans: \"Sweet pie candy jelly. Sesame snaps biscuit sugar plum. Sweet roll topping fruitcake. Caramels liquorice biscuit ice cream fruitcake cotton candy tart. Donut caramels gingerbread jelly-o gingerbread pudding. Gummi bears pastry marshmallow candy canes pie. Pie apple pie carrot cake.\",\n },\n {\n question: \"What does non-exclusive mean?\",\n ans: \"Tart gummies dragée lollipop fruitcake pastry oat cake. Cookie jelly jelly macaroon icing jelly beans soufflé cake sweet. Macaroon sesame snaps cheesecake tart cake sugar plum. Dessert jelly-o sweet muffin chocolate candy pie tootsie roll marzipan.\",\n },\n {\n question:\n \"Is the Regular License the same thing as an editorial license?\",\n ans: \"Cheesecake muffin cupcake dragée lemon drops tiramisu cake gummies chocolate cake. Marshmallow tart croissant. Tart dessert tiramisu marzipan lollipop lemon drops. Cake bonbon bonbon gummi bears topping jelly beans brownie jujubes muffin. Donut croissant jelly-o cake marzipan. Liquorice marzipan cookie wafer tootsie roll. Tootsie roll sweet cupcake.\",\n },\n {\n question:\n \"Which license do I need for an end product that is only accessible to paying users?\",\n ans: \"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.\",\n },\n {\n question: \"Which license do I need to use an item in a commercial?\",\n ans: \"At tempor commodo ullamcorper a lacus vestibulum. Ultrices neque ornare aenean euismod. Dui vivamus arcu felis bibendum. Turpis in eu mi bibendum neque egestas congue. Nullam ac tortor vitae purus faucibus ornare suspendisse sed.\",\n },\n {\n question:\n \"Can I re-distribute an item? What about under an Extended License?\",\n ans: \"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Euismod lacinia at quis risus sed vulputate odio ut enim. Dictum at tempor commodo ullamcorper a lacus vestibulum.\",\n },\n ],\n },\n // delivery\n delivery: {\n icon: \"ShoppingBag\",\n title: \"Delivery\",\n subtitle: \"Which license do I need?\",\n qandA: [\n {\n question: \"Where has my order reached?\",\n ans: \"Pastry pudding cookie toffee bonbon jujubes jujubes powder topping. Jelly beans gummi bears sweet roll bonbon muffin liquorice. Wafer lollipop sesame snaps. Brownie macaroon cookie muffin cupcake candy caramels tiramisu. Oat cake chocolate cake sweet jelly-o brownie biscuit marzipan. Jujubes donut marzipan chocolate bar. Jujubes sugar plum jelly beans tiramisu icing cheesecake.\",\n },\n {\n question:\n \"The shipment status shows that it has been returned/cancelled. What does it mean and who do I contact?\",\n ans: \"Sweet pie candy jelly. Sesame snaps biscuit sugar plum. Sweet roll topping fruitcake. Caramels liquorice biscuit ice cream fruitcake cotton candy tart. Donut caramels gingerbread jelly-o gingerbread pudding. Gummi bears pastry marshmallow candy canes pie. Pie apple pie carrot cake.\",\n },\n {\n question: \"What if my shipment is marked as lost?\",\n ans: \"Tart gummies dragée lollipop fruitcake pastry oat cake. Cookie jelly jelly macaroon icing jelly beans soufflé cake sweet. Macaroon sesame snaps cheesecake tart cake sugar plum. Dessert jelly-o sweet muffin chocolate candy pie tootsie roll marzipan.\",\n },\n {\n question:\n \"My shipment status shows that it’s out for delivery. By when will I receive it?\",\n ans: \"Cheesecake muffin cupcake dragée lemon drops tiramisu cake gummies chocolate cake. Marshmallow tart croissant. Tart dessert tiramisu marzipan lollipop lemon drops. Cake bonbon bonbon gummi bears topping jelly beans brownie jujubes muffin. Donut croissant jelly-o cake marzipan. Liquorice marzipan cookie wafer tootsie roll. Tootsie roll sweet cupcake.\",\n },\n {\n question:\n \"What do I need to do to get the shipment delivered within a specific timeframe?\",\n ans: \"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.\",\n },\n ],\n },\n // cancellation and return\n cancellationReturn: {\n icon: \"RefreshCw\",\n title: \"Cancellation & Return\",\n subtitle: \"Which license do I need?\",\n qandA: [\n {\n question:\n \"Can my security guard or neighbour receive my shipment if I am not available?\",\n ans: \"Pastry pudding cookie toffee bonbon jujubes jujubes powder topping. Jelly beans gummi bears sweet roll bonbon muffin liquorice. Wafer lollipop sesame snaps. Brownie macaroon cookie muffin cupcake candy caramels tiramisu. Oat cake chocolate cake sweet jelly-o brownie biscuit marzipan. Jujubes donut marzipan chocolate bar. Jujubes sugar plum jelly beans tiramisu icing cheesecake.\",\n },\n {\n question: \"How can I get the contact number of my delivery agent?\",\n ans: \"Sweet pie candy jelly. Sesame snaps biscuit sugar plum. Sweet roll topping fruitcake. Caramels liquorice biscuit ice cream fruitcake cotton candy tart. Donut caramels gingerbread jelly-o gingerbread pudding. Gummi bears pastry marshmallow candy canes pie. Pie apple pie carrot cake.\",\n },\n {\n question: \"How can I cancel my shipment?\",\n ans: \"Tart gummies dragée lollipop fruitcake pastry oat cake. Cookie jelly jelly macaroon icing jelly beans soufflé cake sweet. Macaroon sesame snaps cheesecake tart cake sugar plum. Dessert jelly-o sweet muffin chocolate candy pie tootsie roll marzipan.\",\n },\n {\n question:\n \"I have received a defective/damaged product. What do I do?\",\n ans: \"Cheesecake muffin cupcake dragée lemon drops tiramisu cake gummies chocolate cake. Marshmallow tart croissant. Tart dessert tiramisu marzipan lollipop lemon drops. Cake bonbon bonbon gummi bears topping jelly beans brownie jujubes muffin. Donut croissant jelly-o cake marzipan. Liquorice marzipan cookie wafer tootsie roll. Tootsie roll sweet cupcake.\",\n },\n {\n question: \"How do I change my delivery address?\",\n ans: \"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.\",\n },\n {\n question:\n \"What documents do I need to carry for self-collection of my shipment?\",\n ans: \"At tempor commodo ullamcorper a lacus vestibulum. Ultrices neque ornare aenean euismod. Dui vivamus arcu felis bibendum. Turpis in eu mi bibendum neque egestas congue. Nullam ac tortor vitae purus faucibus ornare suspendisse sed. Commodo viverra maecenas accumsan lacus vel facilisis volutpat est velit. Tortor consequat id porta nibh. Id aliquet lectus proin nibh nisl condimentum id venenatis a. Faucibus nisl tincidunt eget nullam non nisi. Enim nunc faucibus a pellentesque. Pellentesque diam volutpat commodo sed egestas egestas fringilla phasellus. Nec nam aliquam sem et tortor consequat id. Fringilla est ullamcorper eget nulla facilisi. Morbi tristique senectus et netus et.\",\n },\n {\n question:\n \"What are the timings for self-collecting shipments from the Delhivery Branch?\",\n ans: \"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Euismod lacinia at quis risus sed vulputate odio ut enim. Dictum at tempor commodo ullamcorper a lacus vestibulum.\",\n },\n ],\n },\n // my orders\n myOrders: {\n icon: \"Package\",\n title: \"My Orders\",\n subtitle: \"Which license do I need?\",\n qandA: [\n {\n question: \"Can I avail of an open delivery?\",\n ans: \"Pastry pudding cookie toffee bonbon jujubes jujubes powder topping. Jelly beans gummi bears sweet roll bonbon muffin liquorice. Wafer lollipop sesame snaps. Brownie macaroon cookie muffin cupcake candy caramels tiramisu. Oat cake chocolate cake sweet jelly-o brownie biscuit marzipan. Jujubes donut marzipan chocolate bar. Jujubes sugar plum jelly beans tiramisu icing cheesecake.\",\n },\n {\n question:\n \"I haven’t received the refund of my returned shipment. What do I do?\",\n ans: \"Sweet pie candy jelly. Sesame snaps biscuit sugar plum. Sweet roll topping fruitcake. Caramels liquorice biscuit ice cream fruitcake cotton candy tart. Donut caramels gingerbread jelly-o gingerbread pudding. Gummi bears pastry marshmallow candy canes pie. Pie apple pie carrot cake.\",\n },\n {\n question: \"How can I ship my order to an international location?\",\n ans: \"Tart gummies dragée lollipop fruitcake pastry oat cake. Cookie jelly jelly macaroon icing jelly beans soufflé cake sweet. Macaroon sesame snaps cheesecake tart cake sugar plum. Dessert jelly-o sweet muffin chocolate candy pie tootsie roll marzipan.\",\n },\n {\n question:\n \"I missed the delivery of my order today. What should I do?\",\n ans: \"Cheesecake muffin cupcake dragée lemon drops tiramisu cake gummies chocolate cake. Marshmallow tart croissant. Tart dessert tiramisu marzipan lollipop lemon drops. Cake bonbon bonbon gummi bears topping jelly beans brownie jujubes muffin. Donut croissant jelly-o cake marzipan. Liquorice marzipan cookie wafer tootsie roll. Tootsie roll sweet cupcake.\",\n },\n {\n question: \"The delivery of my order is delayed. What should I do?\",\n ans: \"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.\",\n },\n ],\n },\n // product and services\n productServices: {\n icon: \"Settings\",\n title: \"Product & Services\",\n subtitle: \"Which license do I need?\",\n qandA: [\n {\n question:\n \"How can I register a complaint against the courier executive who came to deliver my order?\",\n ans: \"Pastry pudding cookie toffee bonbon jujubes jujubes powder topping. Jelly beans gummi bears sweet roll bonbon muffin liquorice. Wafer lollipop sesame snaps. Brownie macaroon cookie muffin cupcake candy caramels tiramisu. Oat cake chocolate cake sweet jelly-o brownie biscuit marzipan. Jujubes donut marzipan chocolate bar. Jujubes sugar plum jelly beans tiramisu icing cheesecake.\",\n },\n {\n question:\n \"The status for my shipment shows as ‘not picked up’. What do I do?\",\n ans: \"Sweet pie candy jelly. Sesame snaps biscuit sugar plum. Sweet roll topping fruitcake. Caramels liquorice biscuit ice cream fruitcake cotton candy tart. Donut caramels gingerbread jelly-o gingerbread pudding. Gummi bears pastry marshmallow candy canes pie. Pie apple pie carrot cake.\",\n },\n {\n question: \"How can I get a proof of delivery for my shipment?\",\n ans: \"Tart gummies dragée lollipop fruitcake pastry oat cake. Cookie jelly jelly macaroon icing jelly beans soufflé cake sweet. Macaroon sesame snaps cheesecake tart cake sugar plum. Dessert jelly-o sweet muffin chocolate candy pie tootsie roll marzipan.\",\n },\n {\n question: \"How can I avail your services?\",\n ans: \"Cheesecake muffin cupcake dragée lemon drops tiramisu cake gummies chocolate cake. Marshmallow tart croissant. Tart dessert tiramisu marzipan lollipop lemon drops. Cake bonbon bonbon gummi bears topping jelly beans brownie jujubes muffin. Donut croissant jelly-o cake marzipan. Liquorice marzipan cookie wafer tootsie roll. Tootsie roll sweet cupcake.\",\n },\n ],\n },\n },\n};\n\nmock.onGet(\"/faq/data\").reply((config) => {\n const { q = \"\" } = config.params;\n const queryLowered = q.toLowerCase();\n\n const filteredData = {};\n\n Object.entries(data.faqData).forEach((entry) => {\n const [categoryName, categoryObj] = entry;\n const filteredQAndAOfCategory = categoryObj.qandA.filter((qAndAObj) => {\n return qAndAObj.question.toLowerCase().includes(queryLowered);\n });\n filteredData[categoryName] = {\n ...categoryObj,\n qandA: filteredQAndAOfCategory.length ? filteredQAndAOfCategory : [],\n };\n });\n\n return [200, filteredData];\n});\n","import mock from \"../mock\";\n/*eslint-disable */\nconst previousDay = new Date(new Date().getTime() - 24 * 60 * 60 * 1000);\nconst dayBeforePreviousDay = new Date(\n new Date().getTime() - 24 * 60 * 60 * 1000 * 2\n);\n\nconst data = {\n profileUser: {\n id: 11,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-11.jpg\")\n .default,\n fullName: \"John Doe\",\n role: \"admin\",\n about:\n \"Dessert chocolate cake lemon drops jujubes. Biscuit cupcake ice cream bear claw brownie brownie marshmallow.\",\n status: \"online\",\n settings: {\n isTwoStepAuthVerificationEnabled: true,\n isNotificationsOn: false,\n },\n },\n contacts: [\n {\n id: 1,\n fullName: \"Felecia Rower\",\n role: \"Frontend Developer\",\n about:\n \"Cake pie jelly jelly beans. Marzipan lemon drops halvah cake. Pudding cookie lemon drops icing\",\n\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-2.jpg\")\n .default,\n status: \"offline\",\n },\n {\n id: 2,\n fullName: \"Adalberto Granzin\",\n role: \"UI/UX Designer\",\n about:\n \"Toffee caramels jelly-o tart gummi bears cake I love ice cream lollipop. Sweet liquorice croissant candy danish dessert icing. Cake macaroon gingerbread toffee sweet.\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-1.jpg\")\n .default,\n status: \"busy\",\n },\n {\n id: 3,\n fullName: \"Joaquina Weisenborn\",\n role: \"Town planner\",\n about:\n \"Soufflé soufflé caramels sweet roll. Jelly lollipop sesame snaps bear claw jelly beans sugar plum sugar plum.\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-3.jpg\")\n .default,\n status: \"busy\",\n },\n {\n id: 4,\n fullName: \"Verla Morgano\",\n role: \"Data scientist\",\n about:\n \"Chupa chups candy canes chocolate bar marshmallow liquorice muffin. Lemon drops oat cake tart liquorice tart cookie. Jelly-o cookie tootsie roll halvah.\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-4.jpg\")\n .default,\n status: \"online\",\n },\n {\n id: 5,\n fullName: \"Margot Henschke\",\n role: \"Dietitian\",\n about:\n \"Cake pie jelly jelly beans. Marzipan lemon drops halvah cake. Pudding cookie lemon drops icing\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n status: \"busy\",\n },\n {\n id: 6,\n fullName: \"Sal Piggee\",\n role: \"Marketing executive\",\n about:\n \"Toffee caramels jelly-o tart gummi bears cake I love ice cream lollipop. Sweet liquorice croissant candy danish dessert icing. Cake macaroon gingerbread toffee sweet.\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-6.jpg\")\n .default,\n status: \"online\",\n },\n {\n id: 7,\n fullName: \"Miguel Guelff\",\n role: \"Special educational needs teacher\",\n about:\n \"Biscuit powder oat cake donut brownie ice cream I love soufflé. I love tootsie roll I love powder tootsie roll.\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n status: \"online\",\n },\n {\n id: 8,\n fullName: \"Mauro Elenbaas\",\n role: \"Advertising copywriter\",\n about:\n \"Bear claw ice cream lollipop gingerbread carrot cake. Brownie gummi bears chocolate muffin croissant jelly I love marzipan wafer.\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-8.jpg\")\n .default,\n status: \"away\",\n },\n {\n id: 9,\n fullName: \"Bridgett Omohundro\",\n role: \"Designer, television/film set\",\n about:\n \"Gummies gummi bears I love candy icing apple pie I love marzipan bear claw. I love tart biscuit I love candy canes pudding chupa chups liquorice croissant.\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n status: \"offline\",\n },\n {\n id: 10,\n fullName: \"Zenia Jacobs\",\n role: \"Building surveyor\",\n about:\n \"Cake pie jelly jelly beans. Marzipan lemon drops halvah cake. Pudding cookie lemon drops icing\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-10.jpg\")\n .default,\n status: \"away\",\n },\n ],\n chats: [\n {\n id: 1,\n userId: 1,\n unseenMsgs: 0,\n chat: [\n {\n message: \"Hi\",\n time: \"Mon Dec 10 2018 07:45:00 GMT+0000 (GMT)\",\n senderId: 11,\n },\n {\n message: \"Hello. How can I help You?\",\n time: \"Mon Dec 11 2018 07:45:15 GMT+0000 (GMT)\",\n senderId: 2,\n },\n {\n message:\n \"Can I get details of my last transaction I made last month?\",\n time: \"Mon Dec 11 2018 07:46:10 GMT+0000 (GMT)\",\n senderId: 11,\n },\n {\n message: \"We need to check if we can provide you such information.\",\n time: \"Mon Dec 11 2018 07:45:15 GMT+0000 (GMT)\",\n senderId: 2,\n },\n {\n message: \"I will inform you as I get update on this.\",\n time: \"Mon Dec 11 2018 07:46:15 GMT+0000 (GMT)\",\n senderId: 2,\n },\n {\n message: \"If it takes long you can mail me at my mail address.\",\n time: dayBeforePreviousDay,\n senderId: 11,\n },\n ],\n },\n {\n id: 2,\n userId: 2,\n unseenMsgs: 1,\n chat: [\n {\n message: \"How can we help? We're here for you!\",\n time: \"Mon Dec 10 2018 07:45:00 GMT+0000 (GMT)\",\n senderId: 11,\n },\n {\n message:\n \"Hey John, I am looking for the best admin template. Could you please help me to find it out?\",\n time: \"Mon Dec 10 2018 07:45:23 GMT+0000 (GMT)\",\n senderId: 1,\n },\n {\n message: \"It should be Bootstrap 5 compatible.\",\n time: \"Mon Dec 10 2018 07:45:55 GMT+0000 (GMT)\",\n senderId: 1,\n },\n {\n message: \"Absolutely!\",\n time: \"Mon Dec 10 2018 07:46:00 GMT+0000 (GMT)\",\n senderId: 11,\n },\n {\n message:\n \"Modern admin is the responsive bootstrap 5 admin template.!\",\n time: \"Mon Dec 10 2018 07:46:05 GMT+0000 (GMT)\",\n senderId: 11,\n },\n {\n message: \"Looks clean and fresh UI.\",\n time: \"Mon Dec 10 2018 07:46:23 GMT+0000 (GMT)\",\n senderId: 1,\n },\n {\n message: \"It's perfect for my next project.\",\n time: \"Mon Dec 10 2018 07:46:33 GMT+0000 (GMT)\",\n senderId: 1,\n },\n {\n message: \"How can I purchase it?\",\n time: \"Mon Dec 10 2018 07:46:43 GMT+0000 (GMT)\",\n senderId: 1,\n },\n {\n message: \"Thanks, from ThemeForest.\",\n time: \"Mon Dec 10 2018 07:46:53 GMT+0000 (GMT)\",\n senderId: 11,\n },\n {\n message: \"I will purchase it for sure. 👍\",\n time: previousDay,\n senderId: 1,\n },\n ],\n },\n ],\n};\n/*eslint-enable */\n\nconst reOrderChats = (arr, from, to) => {\n const item = arr.splice(from, 1);\n\n // Move the item to its new position\n arr.splice(to, 0, item[0]);\n};\n\n// ------------------------------------------------\n// GET: Return Chats Contacts and Contacts\n// ------------------------------------------------\nmock.onGet(\"/apps/chat/chats-and-contacts\").reply(() => {\n const chatsContacts = data.chats.map((chat) => {\n const contact = data.contacts.find((c) => c.id === chat.userId);\n contact.chat = {\n id: chat.id,\n unseenMsgs: chat.unseenMsgs,\n lastMessage: chat.chat[chat.chat.length - 1],\n };\n return contact;\n });\n const profileUserData = {\n id: data.profileUser.id,\n avatar: data.profileUser.avatar,\n fullName: data.profileUser.fullName,\n status: data.profileUser.status,\n };\n return [\n 200,\n { chatsContacts, contacts: data.contacts, profileUser: profileUserData },\n ];\n});\n\n// ------------------------------------------------\n// GET: Return User Profile\n// ------------------------------------------------\nmock\n .onGet(\"/apps/chat/users/profile-user\")\n .reply(() => [200, data.profileUser]);\n\n// ------------------------------------------------\n// GET: Return Single Chat\n// ------------------------------------------------\nmock.onGet(\"/apps/chat/get-chat\").reply((config) => {\n // Get event id from URL\n\n let userId = config.id;\n\n // Convert Id to number\n userId = Number(userId);\n\n const chat = data.chats.find((c) => c.id === userId);\n if (chat) chat.unseenMsgs = 0;\n const contact = data.contacts.find((c) => c.id === userId);\n if (contact.chat) contact.chat.unseenMsgs = 0;\n return [200, { chat, contact }];\n});\n\n// ------------------------------------------------\n// POST: Add new chat message\n// ------------------------------------------------\nmock.onPost(\"/apps/chat/send-msg\").reply((config) => {\n // Get event from post data\n const { obj } = JSON.parse(config.data);\n\n let activeChat = data.chats.find((chat) => chat.userId === obj.contact.id);\n\n const newMessageData = {\n message: obj.message,\n time: new Date(),\n senderId: 11,\n };\n // If there's new chat for user create one\n let isNewChat = false;\n if (activeChat === undefined) {\n isNewChat = true;\n\n // const lastId = data.chats[length - 1].id\n\n data.chats.push({\n id: obj.contact.id,\n userId: obj.contact.id,\n unseenMsgs: 0,\n chat: [newMessageData],\n });\n activeChat = data.chats[data.chats.length - 1];\n } else {\n activeChat.chat.push(newMessageData);\n }\n\n const response = { newMessageData, id: obj.contact.id };\n if (isNewChat) response.chat = activeChat;\n\n reOrderChats(\n data.chats,\n data.chats.findIndex((i) => i.id === response.id),\n 0\n );\n\n return [201, { response }];\n});\n","import mock from \"../mock\";\n\nconst data = {\n tasks: [\n {\n id: 1,\n title: \"Entire change break our wife wide it daughter mention member.\",\n dueDate: \"2020-11-25\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Jacob Ramirez\",\n avatar: require(\"@src/assets/images/avatars/12.png\").default,\n },\n tags: [\"update\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 2,\n title: \"Citizen stand administration step agency century.\",\n dueDate: \"2020-12-14\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Andrew Anderson\",\n avatar: \"\",\n },\n tags: [\"team\", \"medium\"],\n isCompleted: true,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 3,\n title: \"Meet Jane and ask for coffee ❤️\",\n dueDate: \"2020-11-25\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Benjamin Jacobs\",\n avatar: \"\",\n },\n tags: [\"high\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 4,\n title: \"Answer the support tickets and close completed tickets. \",\n dueDate: \"2020-11-20\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Curtis Schmidt\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n tags: [\"medium\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: true,\n },\n {\n id: 5,\n title:\n \"Test functionality of apps developed by dev team for enhancements. \",\n dueDate: \"2020-12-06\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Katherine Perkins\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n tags: [\"medium\"],\n isCompleted: true,\n isDeleted: false,\n isImportant: true,\n },\n {\n id: 6,\n title: \"Conduct a mini awareness meeting regarding health care. \",\n dueDate: \"2020-12-06\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"David Murphy\",\n avatar: \"\",\n },\n tags: [\"high\", \"medium\"],\n isCompleted: true,\n isDeleted: true,\n isImportant: false,\n },\n {\n id: 7,\n title:\n \"Plan new dashboard design with design team for Google app store. \",\n dueDate: \"2020-12-05\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Karina Miller\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n tags: [\"medium\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: true,\n },\n {\n id: 8,\n title: \"Pick up Nats from her school and drop at dance class😁 \",\n dueDate: \"2020-12-08\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Thomas Moses\",\n avatar: require(\"@src/assets/images/avatars/7.png\").default,\n },\n tags: [\"low\", \"medium\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 9,\n title: \"Finish documentation and make it live\",\n dueDate: \"2020-11-25\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Angel Morrow\",\n avatar: \"\",\n },\n tags: [\"high\", \"update\"],\n isCompleted: false,\n isDeleted: true,\n isImportant: false,\n },\n {\n id: 10,\n title: \"List out all the SEO resources and send it to new SEO team. \",\n dueDate: \"2020-12-09\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Karen Carrillo\",\n avatar: \"\",\n },\n tags: [\"low\"],\n isCompleted: true,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 11,\n title: \"Refactor Code and fix the bugs and test it on server \",\n dueDate: \"2020-12-01\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Timothy Brewer\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n tags: [\"low\"],\n isCompleted: true,\n isDeleted: false,\n isImportant: true,\n },\n {\n id: 12,\n title: \"Reminder to mail clients for holidays\",\n dueDate: \"2020-12-09\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Brian Barry\",\n avatar: \"\",\n },\n tags: [\"team\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 13,\n title: \"Submit quotation for Abid's ecommerce website and admin project\",\n dueDate: \"2020-12-01\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Joshua Golden\",\n avatar: require(\"@src/assets/images/avatars/5.png\").default,\n },\n tags: [\"team\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 14,\n title: \"Send PPT with real-time reports\",\n dueDate: \"2020-11-29\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Paula Hammond\",\n avatar: require(\"@src/assets/images/avatars/5.png\").default,\n },\n tags: [\"medium\"],\n isCompleted: true,\n isDeleted: false,\n isImportant: true,\n },\n {\n id: 15,\n title: \"Skype Tommy for project status & report\",\n dueDate: \"2020-11-29\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Tyler Garcia\",\n avatar: \"\",\n },\n tags: [\"medium\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 16,\n title:\n \"Hire 5 new Fresher or Experienced, frontend and backend developers \",\n dueDate: \"2020-12-12\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Darlene Shields\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n tags: [\"low\"],\n isCompleted: true,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 17,\n title: \"Plan a party for development team 🎁\",\n dueDate: \"2020-12-04\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Destiny Michael\",\n avatar: \"\",\n },\n tags: [\"medium\", \"low\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: false,\n },\n {\n id: 18,\n title: \"Fix Responsiveness for new structure 💻\",\n dueDate: \"2020-11-18\",\n description:\n \"Chocolate cake topping bonbon jujubes donut sweet wafer. Marzipan gingerbread powder brownie bear claw. Chocolate bonbon sesame snaps jelly caramels oat cake.\",\n assignee: {\n fullName: \"Danielle Anderson\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n },\n tags: [\"low\"],\n isCompleted: false,\n isDeleted: false,\n isImportant: true,\n },\n ],\n};\n\n// ------------------------------------------------\n// GET: Return Tasks\n// ------------------------------------------------\nmock.onGet(\"/apps/todo/tasks\").reply((config) => {\n // eslint-disable-next-line object-curly-newline\n const { q = \"\", filter, tag, sortBy: sortByParam = \"latest\" } = config.params;\n /* eslint-enable */\n // ------------------------------------------------\n // Get Sort by and Sort Direction\n // ------------------------------------------------\n let sortDesc = true;\n\n const sortBy = (() => {\n if (sortByParam === \"title-asc\") {\n sortDesc = false;\n return \"title\";\n }\n if (sortByParam === \"title-desc\") return \"title\";\n if (sortByParam === \"assignee\") {\n sortDesc = false;\n return \"assignee\";\n }\n if (sortByParam === \"due-date\") {\n sortDesc = false;\n return \"dueDate\";\n }\n return \"id\";\n })();\n\n // ------------------------------------------------\n // Filtering\n // ------------------------------------------------\n const queryLowered = q.toLowerCase();\n\n const hasFilter = (task) => {\n if (filter === \"important\") return task.isImportant && !task.isDeleted;\n if (filter === \"completed\") return task.isCompleted && !task.isDeleted;\n if (filter === \"deleted\") return task.isDeleted;\n return !task.isDeleted;\n };\n\n const includesFilter = (task) =>\n task.tags.includes(queryLowered) ||\n task.tags.some((tag) => tag.includes(queryLowered));\n\n const includesDueDate = (task) => {\n const date = new Date(task.dueDate).getDate().toString().padStart(2, \"0\");\n const month = new Date(task.dueDate)\n .toLocaleString(\"default\", { month: \"short\" })\n .toLowerCase();\n const dateMonth = `${date} ${month}`;\n const monthDate = `${month} ${date}`;\n\n return (\n date.includes(queryLowered) ||\n month.includes(queryLowered) ||\n dateMonth.includes(queryLowered) ||\n monthDate.includes(queryLowered)\n );\n };\n\n /* eslint-disable */\n const filteredData = data.tasks.filter((task) => {\n if (filter || tag) {\n return (\n task.title.toLowerCase().includes(queryLowered) &&\n hasFilter(task) &&\n (tag ? task.tags.includes(tag) : true)\n );\n } else {\n return (\n task.title.toLowerCase().includes(queryLowered) ||\n includesFilter(task) ||\n includesDueDate(task)\n );\n }\n });\n /* eslint-enable */\n\n // ------------------------------------------------\n // Perform sorting\n // ------------------------------------------------\n const sortTasks = (key) => (a, b) => {\n let fieldA;\n let fieldB;\n\n // If sorting is by dueDate => Convert data to date\n if (key === \"dueDate\") {\n fieldA = new Date(a[key]);\n fieldB = new Date(b[key]);\n // eslint-disable-next-line brace-style\n }\n\n // If sorting is by assignee => Use `fullName` of assignee\n else if (key === \"assignee\") {\n fieldA = a.assignee ? a.assignee.fullName : null;\n fieldB = b.assignee ? b.assignee.fullName : null;\n } else {\n fieldA = a[key];\n fieldB = b[key];\n }\n\n let comparison = 0;\n\n if (fieldA === fieldB) {\n comparison = 0;\n } else if (fieldA === null) {\n comparison = 1;\n } else if (fieldB === null) {\n comparison = -1;\n } else if (fieldA > fieldB) {\n comparison = 1;\n } else if (fieldA < fieldB) {\n comparison = -1;\n }\n\n return comparison;\n };\n\n // Sort Data\n const sortedData = filteredData.sort(sortTasks(sortBy));\n if (sortDesc) sortedData.reverse();\n return [200, sortedData];\n});\n\n// ------------------------------------------------\n// POST: Add new task\n// ------------------------------------------------\nmock.onPost(\"/apps/todo/add-tasks\").reply((config) => {\n // Get event from post data\n const { task } = JSON.parse(config.data);\n\n const { length } = data.tasks;\n let lastIndex = 0;\n if (length) {\n lastIndex = data.tasks[length - 1].id;\n }\n task.id = lastIndex + 1;\n\n data.tasks.push(task);\n\n return [201, { task }];\n});\n\n// ------------------------------------------------\n// POST: Update Task\n// ------------------------------------------------\nmock.onPost(\"/apps/todo/update-task\").reply((config) => {\n const taskData = JSON.parse(config.data).task;\n\n // Convert Id to number\n taskData.id = Number(taskData.id);\n\n const task = data.tasks.find((e) => e.id === Number(taskData.id));\n Object.assign(task, taskData);\n\n return [200, { task }];\n});\n\n// ------------------------------------------------\n// DELETE: Remove Task\n// ------------------------------------------------\nmock.onDelete(\"/apps/todo/delete-task\").reply((config) => {\n // Get task id from URL\n let taskId = config.taskId;\n\n // Convert Id to number\n taskId = Number(taskId);\n\n const task = data.tasks.find((t) => t.id === taskId);\n Object.assign(task, { isDeleted: true });\n return [200];\n});\n","import mock from \"../mock\";\n\n/* eslint-disable */\nconst data = {\n emails: [\n {\n id: 1,\n from: {\n email: \"tommys@mail.com\",\n name: \"Tommy Sicilia\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@mail.com\",\n },\n ],\n subject: \"Theme Update\",\n cc: [],\n bcc: [],\n message:\n \"Hi John,
Biscuit lemon drops marshmallow. Cotton candy marshmallow bear claw. Dragée tiramisu cookie cotton candy. Carrot cake sweet roll I love macaroon wafer jelly soufflé I love dragée. Jujubes jelly I love carrot cake topping I love. Sweet candy I love chupa chups dragée. Tart I love gummies. Chocolate bar carrot cake candy wafer candy canes oat cake I love. Sesame snaps icing pudding sweet roll marshmallow. Cupcake brownie sweet roll chocolate bar I love gummies. Biscuit biscuit macaroon sesame snaps macaroon icing I love soufflé caramels. Apple pie candy jelly. I love icing gummi bears jelly-o pie muffin apple pie.
Marshmallow halvah brownie cake marzipan ice cream marshmallow. I love lollipop toffee croissant liquorice wafer muffin. Lollipop jelly beans caramels lollipop tootsie roll pudding pie macaroon tootsie roll. Oat cake jujubes gummies cake cake powder cupcake soufflé muffin. Chocolate caramels muffin tart. Jelly beans caramels dessert cotton candy liquorice chocolate cake. Chupa chups muffin bear claw I love. Biscuit jujubes soufflé tart caramels pie sugar plum. Croissant jelly beans cake. Ice cream chocolate liquorice dessert cookie chocolate cake. Powder tart sweet roll macaroon croissant. Sweet tootsie roll macaroon gummi bears macaroon. Gingerbread cake tart.
Regrads,
Kristeen Sicilia
\",\n attachments: [\n {\n fileName: \"log.txt\",\n thumbnail: require(\"@src/assets/images/icons/txt.png\").default,\n url: \"\",\n size: \"5mb\",\n },\n {\n fileName: \"performance.xls\",\n thumbnail: require(\"@src/assets/images/icons/xls.png\").default,\n url: \"\",\n size: \"10mb\",\n },\n ],\n isStarred: false,\n labels: [\"private\"],\n time: \"Mon Dec 10 2018 07:46:00 GMT+0000 (GMT)\",\n replies: [],\n folder: \"inbox\",\n isRead: true,\n },\n {\n id: 2,\n from: {\n email: \"tressag@mail.com\",\n name: \"Tressa Gass\",\n avatar: require(\"@src/assets/images/avatars/2.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@mail.com\",\n },\n ],\n subject: \"Company Report\",\n cc: [\"vrushankbrahmshatriya@mail.com\"],\n bcc: [\"menka@mail.com\"],\n message:\n \" Hello John,
Chocolate bar chupa chups sweet roll chocolate muffin macaroon liquorice tart. Carrot cake topping jelly-o cupcake sweet apple pie jelly I love. Chocolate cake I love dessert carrot cake tootsie roll chocolate I love. Tootsie roll pie marzipan sesame snaps. Lemon drops cake I love chocolate I love. Cheesecake croissant croissant cheesecake tootsie roll chocolate cake caramels. I love I love cake jelly. Pastry jelly beans I love I love. I love tootsie roll gummies toffee I love cookie cookie. Brownie tart croissant.
I love jelly pie. Croissant jelly beans lemon drops oat cake. Cupcake carrot cake ice cream cake cookie jelly-o fruitcake jelly macaroon. Biscuit muffin cupcake chocolate bar lollipop danish.
Ice cream I love I love lemon drops cotton candy macaroon. Jujubes soufflé oat cake sweet roll bear claw cotton candy cookie toffee tootsie roll. Danish sesame snaps sesame snaps cookie jelly danish chocolate bar.
Fruitcake pastry bear claw chocolate cookie. Biscuit icing bear claw. Sweet roll liquorice jelly-o muffin toffee I love wafer. Candy pastry halvah. Pie pastry candy canes tart. Fruitcake I love liquorice icing sweet roll macaroon. I love ice cream jelly-o biscuit brownie marzipan topping pudding sesame snaps. Chupa chups brownie brownie cotton candy sugar plum toffee. Tiramisu tootsie roll gingerbread biscuit I love ice cream brownie sesame snaps. I love croissant I love I love brownie pie marshmallow.
Regrads
Tressa Gass
\",\n attachments: [],\n isStarred: true,\n labels: [\"company\", \"private\"],\n time: \"Mon Dec 10 2018 07:55:00 GMT+0000 (GMT)\",\n replies: [],\n folder: \"inbox\",\n isRead: true,\n },\n {\n id: 3,\n from: {\n email: \"hettiem@mail.com\",\n name: \"Hettie Mcerlean\",\n avatar: require(\"@src/assets/images/avatars/3.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@mail.com\",\n },\n {\n name: \"Pixinvent\",\n email: \"hello@pixinvent.net\",\n },\n ],\n subject: \"Order Delivered\",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
Chocolate bar chupa chups sweet roll chocolate muffin macaroon liquorice tart. Carrot cake topping jelly-o cupcake sweet apple pie jelly I love. Chocolate cake I love dessert carrot cake tootsie roll chocolate I love. Tootsie roll pie marzipan sesame snaps. Lemon drops cake I love chocolate I love. Cheesecake croissant croissant cheesecake tootsie roll chocolate cake caramels. I love I love cake jelly. Pastry jelly beans I love I love. I love tootsie roll gummies toffee I love cookie cookie. Brownie tart croissant.
I love jelly pie. Croissant jelly beans lemon drops oat cake. Cupcake carrot cake ice cream cake cookie jelly-o fruitcake jelly macaroon. Biscuit muffin cupcake chocolate bar lollipop danish.
Ice cream I love I love lemon drops cotton candy macaroon. Jujubes soufflé oat cake sweet roll bear claw cotton candy cookie toffee tootsie roll. Danish sesame snaps sesame snaps cookie jelly danish chocolate bar.
Fruitcake pastry bear claw chocolate cookie. Biscuit icing bear claw. Sweet roll liquorice jelly-o muffin toffee I love wafer. Candy pastry halvah. Pie pastry candy canes tart. Fruitcake I love liquorice icing sweet roll macaroon. I love ice cream jelly-o biscuit brownie marzipan topping pudding sesame snaps. Chupa chups brownie brownie cotton candy sugar plum toffee. Tiramisu tootsie roll gingerbread biscuit I love ice cream brownie sesame snaps. I love croissant I love I love brownie pie marshmallow.
Regrads
Hettie Mcerlean
\",\n attachments: [],\n isStarred: false,\n labels: [\"company\"],\n time: \"Mon Dec 10 2018 08:35:00 GMT+0000 (GMT)\",\n replies: [],\n folder: \"spam\",\n isRead: true,\n },\n {\n id: 4,\n from: {\n email: \"louettae@mail.com\",\n name: \"Louetta Esses\",\n avatar: require(\"@src/assets/images/avatars/4.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@mail.com\",\n },\n ],\n subject: \"Waterfall Model Update\",\n cc: [],\n bcc: [],\n message:\n \"Hi John,
Biscuit lemon drops marshmallow. Cotton candy marshmallow bear claw. Dragée tiramisu cookie cotton candy. Carrot cake sweet roll I love macaroon wafer jelly soufflé I love dragée. Jujubes jelly I love carrot cake topping I love. Sweet candy I love chupa chups dragée. Tart I love gummies. Chocolate bar carrot cake candy wafer candy canes oat cake I love. Sesame snaps icing pudding sweet roll marshmallow. Cupcake brownie sweet roll chocolate bar I love gummies. Biscuit biscuit macaroon sesame snaps macaroon icing I love soufflé caramels. Apple pie candy jelly. I love icing gummi bears jelly-o pie muffin apple pie.
Marshmallow halvah brownie cake marzipan ice cream marshmallow. I love lollipop toffee croissant liquorice wafer muffin. Lollipop jelly beans caramels lollipop tootsie roll pudding pie macaroon tootsie roll. Oat cake jujubes gummies cake cake powder cupcake soufflé muffin. Chocolate caramels muffin tart. Jelly beans caramels dessert cotton candy liquorice chocolate cake. Chupa chups muffin bear claw I love. Biscuit jujubes soufflé tart caramels pie sugar plum. Croissant jelly beans cake. Ice cream chocolate liquorice dessert cookie chocolate cake. Powder tart sweet roll macaroon croissant. Sweet tootsie roll macaroon gummi bears macaroon. Gingerbread cake tart.
Regrads,
Kristeen Sicilia
\",\n attachments: [\n {\n fileName: \"report.doc\",\n thumbnail: require(\"@src/assets/images/icons/doc.png\").default,\n url: \"\",\n size: \"32mb\",\n },\n ],\n isStarred: false,\n labels: [\"important\"],\n time: \"Mon Dec 11 2018 09:04:10 GMT+0000 (GMT)\",\n replies: [],\n folder: \"inbox\",\n isRead: true,\n },\n {\n id: 5,\n from: {\n email: \"bposvner0@zdnet.com\",\n name: \"Bobbie Posvner\",\n avatar: require(\"@src/assets/images/avatars/11.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@dot.gov\",\n },\n ],\n subject: \"Re-contextualized zero administration toolset\",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
Epiboly henbill hemichorea composedness resequent hearthpenny racialization freeboard Reboulia Albuginaceae Violales Trisagion resinlike plumlet insalubrious Urocoptis Orthoceratidae ogmic plateaux reinsist preconsumption rattener venipuncture Rhadamanthine
perversely corpusculated theophoric uncemented weiring myolipoma gudesire dramatics trichomaphyte adventitious video polychaete glossorrhaphy bestially zoospore nonnotional sawbones unprejudiciable wali collaborative coppled shammish manless predisorder
\",\n attachments: [],\n isStarred: true,\n labels: [\"private\"],\n time: \"Tue Dec 12 2018 11:55:00 GMT+0000 (GMT)\",\n replies: [],\n folder: \"spam\",\n isRead: true,\n },\n {\n id: 6,\n from: {\n email: \"rgilder1@illinois.edu\",\n name: \"Rebecca Gilder\",\n avatar: require(\"@src/assets/images/avatars/6.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@google.co.uk\",\n },\n ],\n subject: \"Integrated bi-directional help-desk\",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
irretraceably indestructibility sisi fiddle pyretic Gerbera vocable hoped Chartreux thinglet whister fetiferous Guhayna overloud yuca suggestibly atmiatrics serioludicrous prehaustorium androgenic betulin chiropterite sprittail atrochal
stopper acinaceous bandcutter unprostituted undependableness Saffarid parasympathetic dishonorer embryogeny overscrupulous deicidal Tapuya roupily devotee alfet sophiologic hydrobromide onlook preverb Dottore primitial frostlike overbig Monocyclica
\",\n attachments: [],\n isStarred: false,\n labels: [\"personal\"],\n time: \"Thu Dec 13 2018 08:25:00 GMT+0000 (GMT)\",\n replies: [],\n folder: \"trash\",\n isRead: true,\n },\n {\n id: 7,\n from: {\n email: \"swilby2@yandex.ru\",\n name: \"Shawn Wilby\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@altervista.org\",\n },\n ],\n subject: \"Devolved regional product\",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
scalpellum unisometrical emend esotrope gether separatical passionwise cringe flawful annotinous jiboa thrombotic essoinment successional backrope oligohemia gitaligenin formulaic bradycinesia paralgesic eumycetic receptoral eyrie yearly
atomistical semischolastic clour discardment pseudelytron cheson path Bennet Herat pinchem Tho extravagantly shaking procidence flocker amidoketone gyric Moi petrolific clink immunization estrepement spalder poitrail
\",\n attachments: [],\n isStarred: false,\n labels: [\"company\"],\n time: \"Fri Dec 14 2018 04:49:23 GMT+0000 (GMT)\",\n replies: [],\n folder: \"draft\",\n isRead: true,\n },\n {\n id: 8,\n from: {\n email: \"wmannering3@mozilla.org\",\n name: \"Waldemar Mannering\",\n avatar: require(\"@src/assets/images/avatars/11.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@sciencedaily.com\",\n },\n ],\n subject: \"Quality-focused methodical flexibility\",\n cc: [],\n bcc: [],\n message:\n \"Hi John,
wartproof ketoheptose incomplicate hyomental organal supermaterial monogene sophister nizamate rightle multifilament phloroglucic overvehement boatloading derelictly probudgeting archantiquary unknighted pallograph Volcanalia Jacobitiana ethyl neth Jugatae
noumenalize irredential energeia phlebotomist galp dactylitis unparticipated solepiece demure metarhyolite toboggan unpleased perilaryngeal binoxalate rabbitry atomic duali dihexahedron Pseudogryphus boomboat obelisk undreaded unadmired podometer
\",\n attachments: [],\n isStarred: false,\n labels: [\"private\"],\n time: \"Tue Dec 15 2018 11:02:28 GMT+0000 (GMT)\",\n replies: [],\n folder: \"inbox\",\n isRead: false,\n },\n {\n id: 9,\n from: {\n email: \"hfrostdyke4@scientificamerican.com\",\n name: \"Heath Frostdyke\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@weibo.com\",\n },\n ],\n subject: \"Secured optimal algorithm\",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
prefertility volumetrical subdivision Alpinist hypostomous foreyard lede knuckling Agade viking protometallic unsting palaeobiologist trierarchic bigheartedness Slartibartfast tabitude popadam idioplasm fabulous arsenite cingle backhandedness denizenship
argo trickish dependingly unhouseled aegeriid ophthalmophlebotomy crazy freedwoman unspinsterlike clinical epistemologically hermodactyl humbugger misogynist plunder Sabbathly tabule feckless cerite porringer benumb duograph propatagian pressman
\",\n attachments: [],\n isStarred: true,\n labels: [\"personal\"],\n time: \"Tue Jan 01 2018 18:31:19 GMT+0000 (GMT)\",\n replies: [],\n folder: \"trash\",\n isRead: false,\n },\n {\n id: 10,\n from: {\n email: \"pjentzsch5@tamu.edu\",\n name: \"Paulita Jentzsch\",\n avatar: require(\"@src/assets/images/avatars/7.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@skype.com\",\n },\n ],\n subject: \"Profound user-facing frame\",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
unstintedly septifarious prevalid implicative esere Kedarite Nekkar encampment Issedones Saururus Turkize Tshi misengrave lamnid benzamine rigidulous octonion hydrophilous coxalgic nasturtium epileptogenic biporose undenominationalism widu
melioration pager infiltrate plouky tribesmanship transudate heinous exhibitionistic klendusic lienocele tractate unemotioned castigate selenate appealable Palladianism chloracetate penna moellon detector halcyon amidofluorid damascene hollaite
\",\n attachments: [\n {\n fileName: \"UtNulla.xls\",\n thumbnail: require(\"@src/assets/images/icons/xls.png\").default,\n url: \"\",\n size: \"1mb\",\n },\n ],\n isStarred: true,\n labels: [\"important\"],\n time: \"Tue Jan 03 2018 08:05:33 GMT+0000 (GMT)\",\n replies: [],\n folder: \"draft\",\n isRead: false,\n },\n {\n id: 11,\n from: {\n email: \"lminghetti6@yale.edu\",\n name: \"Lowell Minghetti\",\n avatar: require(\"@src/assets/images/avatars/4.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@fda.gov\",\n },\n ],\n subject: \"Reactive full-range encryption\",\n cc: [],\n bcc: [],\n message:\n \"Hi John,
Jaime stadimeter reshearer adfix exaristate herby chrysomonad ostentous Abrahamic Marsipobranchii skil linguodental relaster restbalk enhorror glycerizine foremelt difficultness Ostreidae Euphues panduriform howler Finmark primordality
semicurvilinear skeet sociogenetic dicephalism ghalva ethnicon katagenesis tasklike triachenium abuser henbane strubbly streetway Ramaism besetting saccos enzymically wickiup inopulent poetship Miranda hemianesthesia sphericle oariopathy
\",\n attachments: [\n {\n fileName: \"ElementumLigula.js\",\n thumbnail: require(\"@src/assets/images/icons/js.png\").default,\n url: \"\",\n size: \"29mb\",\n },\n ],\n isStarred: false,\n labels: [\"company\"],\n time: \"Tue Jan 03 2018 01:05:20 GMT+0000 (GMT)\",\n replies: [],\n folder: \"trash\",\n isRead: true,\n },\n {\n id: 12,\n from: {\n email: \"efinessy7@sbwire.com\",\n name: \"Eugenie Finessy\",\n avatar: require(\"@src/assets/images/avatars/2.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@odnoklassniki.ru\",\n },\n ],\n subject: \"Polarised holistic protocol\",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
nonmotile generale punctated humanify escharine unlatch alrighty unshepherding standstill upcrane unilobular prefrontal primate fluviatic premundane tritocone compaternity dolina phonautographic cobby corse neurohypnotic cyrtopia wreathy
slanderousness Lemosi myxochondroma haemogram electrothermostat piperonyl spital reappeal pyopneumothorax Yunca eyoty forecourse extensive kickout germanization vigilant Criophoros muss aortostenosis Berchta phonophotoscopic precorrespondence rigidist castling
\",\n attachments: [],\n isStarred: false,\n labels: [\"personal\"],\n time: \"Tue Jan 04 2018 21:26:54 GMT+0000 (GMT)\",\n replies: [],\n folder: \"sent\",\n isRead: true,\n },\n {\n id: 13,\n from: {\n email: \"tmckeurton8@163.com\",\n name: \"Tadio McKeurton\",\n avatar: require(\"@src/assets/images/avatars/10.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@nifty.com\",\n },\n ],\n subject: \"Down-sized transitional intranet\",\n cc: [],\n bcc: [],\n message:\n \"Hey John,
calcimine gramineal nonfreezable interradial setula undertakable Abranchiata ultrasystematic spectroelectric Astarte Abraham bedsite enantiopathia exlex precoincident thiocarbamic mesenteriform daturism thioantimoniate tripudiate unsultry predynastic benzidino doxasticon
overstale confessory glossed jane smoodger modernization Dehkan progymnospermic gangliectomy volumenometry Paulinistically tippy Gelfomino hive preredemption coccygine horrendous unintrusted plainer interrelatedly tearer arrojadite incircumspectly yokemating
\",\n attachments: [],\n isStarred: false,\n labels: [\"important\"],\n time: \"Tue Jan 05 2018 19:00:00 GMT+0000 (GMT)\",\n replies: [],\n folder: \"draft\",\n isRead: true,\n },\n {\n id: 14,\n from: {\n email: \"ebegg9@wikia.com\",\n name: \"Eb Begg\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@51.la\",\n },\n ],\n subject: \"Organized value-added model\",\n cc: [],\n bcc: [],\n message:\n \"Hello Sir,
Lituola restrengthen bathofloric manciple decaffeinize Debby aciliated eatage proscribe prejurisdiction buttle quacky hyposecretion indemonstrableness schelling lymphopathy consumptivity nonappointment filminess spumiform erotogenicity equestrianize boneflower interlardation
allocate ponzite cote guilder tuff strind blamefully cocaine monstrously apocalyptically sublanate cherubimical oligoplasmia Miltonian hydrazyl unbeset statured Unami Cordeau strouthiocamelian geitjie larigo sociometry align
\",\n attachments: [],\n isStarred: false,\n labels: [\"company\"],\n time: \"Tue Jan 06 2018 23:12:13 GMT+0000 (GMT)\",\n replies: [],\n folder: \"inbox\",\n isRead: true,\n },\n {\n id: 15,\n from: {\n email: \"mspata@sina.com.cn\",\n name: \"Modestine Spat\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@oracle.com\",\n },\n ],\n subject: \"Profound systemic alliance 🎉 🎊\",\n cc: [],\n bcc: [],\n message:\n \"Hey John,
Parthenopean logeion chipwood tonsilitic cockleshell substance Stilbum dismayed tape Alderamin Phororhacos bridewain zoonomia lujaurite printline extraction weanedness charterless splitmouth bindoree unfit philological Pythonissa scintillescent
cinchonism sabbaton thyrocricoid dissuasively schematograph immerse pristane stimulability unreligion uncomplemental uteritis nef bavenite Hachiman teleutosorus anterolateral infirmate Nahani Hyla barile farthing crea venesector Cirrostomi
\",\n attachments: [],\n isStarred: false,\n labels: [\"company\"],\n time: \"Tue Jan 07 2018 12:25:03 GMT+0000 (GMT)\",\n replies: [],\n folder: \"inbox\",\n isRead: false,\n },\n {\n id: 16,\n from: {\n email: \"cprandob@rambler.ru\",\n name: \"Chase Prando\",\n avatar: require(\"@src/assets/images/avatars/2.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@vistaprint.com\",\n },\n ],\n subject: \"Centralized intermediate instruction set\",\n cc: [],\n bcc: [],\n message:\n \"Respected Sir,
drainman merman pleurosteal slatted serenader Tantalus slodder cachalot guerdon flannelflower digestibility priggish loa monocarbide endive rented kelep pangamous gummata siris stockproof butlerism polycrystalline begetter
rack unpaining beglue astucious yardstick laniflorous tetrachloride avidious Biblicistic clival myosinogen antilobium unamiability unperforate Elaphurus wrapping deformity revocative kovil unwainscoted councilmanic saccharobiose federalize procellous
\",\n attachments: [],\n isStarred: false,\n labels: [\"company\"],\n time: \"Tue Jan 08 2018 00:36:40 GMT+0000 (GMT)\",\n replies: [],\n folder: \"sent\",\n isRead: true,\n },\n {\n id: 17,\n from: {\n email: \"nbartlesc@merriam-webster.com\",\n name: \"Normand Bartles\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@si.edu\",\n },\n ],\n subject: \"Re-contextualized leading edge projection\",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
orpine anidiomatic protoreptilian lacklusterness macromastia obstetricate Phaneroglossa tripleness laxatively hypophloeous ocellate sinoauricular porch lignitic miche strinkle hyperthyreosis tugui Alascan unrailroaded Cypriote vesuvian gradative hardener
forthink Locarno wattlework Nordicist formoxime demipriest medrick Lomentaria lucible Canossa Manatus anaplasty Spirochaete bonus overgown Amurru Skupshtina opisthorchiasis preworthy Brodie shortchange Nikko Gaviae crosscut
\",\n attachments: [],\n isStarred: false,\n labels: [\"personal\"],\n time: \"Tue Jan 09 2018 22:06:50 GMT+0000 (GMT)\",\n replies: [],\n folder: \"spam\",\n isRead: true,\n },\n {\n id: 18,\n from: {\n email: \"rgennd@dedecms.com\",\n name: \"Robin Genn\",\n avatar: require(\"@src/assets/images/avatars/6.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@about.com\",\n },\n ],\n subject: \"Team-oriented system-worthy intranet\",\n cc: [],\n bcc: [],\n message:\n \"Hi John,
balsamation teachableness enarthrodia dentilation superguarantee Yuapin schedulize antarctically biocoenotic unspottedly stinter admonitorily uncollatedness umquhile grayhead dephase stopgap evenglow photogenically desmacyte rink osiered specking ratwa
hospitize epithymetical montage rhapsodical Ninja superdramatist westerner clubionid haustellate Saltator rodding ophthalmomalacia concupiscibleness tingle hyperuresis Trigoniidae rearousal sanctimonial Munychia counterpaned exhibitable communer triadism Janiform
\",\n attachments: [],\n isStarred: true,\n labels: [\"personal\"],\n time: \"Tue Jan 10 2018 01:51:24 GMT+0000 (GMT)\",\n replies: [],\n folder: \"spam\",\n isRead: true,\n },\n {\n id: 19,\n from: {\n email: \"eramelote@webeden.co.uk\",\n name: \"Emmalynn Ramelot\",\n avatar: require(\"@src/assets/images/avatars/8.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@tinypic.com\",\n },\n ],\n subject: \"Phased eco-centric architecture\",\n cc: [],\n bcc: [],\n message:\n \"Hey John,
hightoby Maja vindicatorship unglobe poduran bronchodilatation uncontorted underwarden cyclometric orgiacs tigerhearted upscale curatize Scylliorhinidae slick unisolated nanocephalous cuirassier heartwise Venusian titanitic requirement antirestoration toluido
Trematosaurus procreant ethos pessimistic antiselene pisk Amphipneusta anconad Corchorus unswabbed sizable Balanites sardonical shovelbill trammeler carpetwork rhexis remade myelinated right bounteous unsin retroduction Montanist
\",\n attachments: [],\n isStarred: true,\n labels: [\"personal\"],\n time: \"Tue Jan 11 2018 14:25:46 GMT+0000 (GMT)\",\n replies: [],\n folder: \"spam\",\n isRead: false,\n },\n {\n id: 20,\n from: {\n email: \"pcuzenf@mediafire.com\",\n name: \"Penni Cuzen\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@google.es\",\n },\n ],\n subject: \"Future-proofed motivating support\",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
yonder secessionalist astringer Ovangangela overcumber supracaecal scutulate Aglaonema Pakawan citril unsubducted cavernal multivalve ladify Cichorium supplication flexion cricothyroidean picaro locally etiogenic timeously scalpeen sapropel
agglutinative hyperideation Flamandize antipragmatic wincer brachyphalangia forenotion Angloman ornamentation merch revulsed windingly tristate orgic sateless orseilline Anchietea pilferer aroid counselor forevermore kulmet maladventure haruspice
\",\n attachments: [\n {\n fileName: \"Augue.js\",\n thumbnail: require(\"@src/assets/images/icons/js.png\").default,\n url: \"\",\n size: \"4mb\",\n },\n ],\n isStarred: false,\n labels: [\"private\"],\n time: \"Tue Jan 12 2018 04:16:10 GMT+0000 (GMT)\",\n replies: [],\n folder: \"spam\",\n isRead: false,\n },\n {\n id: 21,\n from: {\n email: \"abaldersong@utexas.edu\",\n name: \"Ardis Balderson\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@ow.ly\",\n },\n ],\n subject: \"Focused impactful open system 📷 😃\",\n cc: [],\n bcc: [],\n message:\n \"Hey John,
bah kivu decrete epanorthotic unnotched Argyroneta nonius veratrine preimaginary saunders demidolmen Chaldaic allusiveness lorriker unworshipping ribaldish tableman hendiadys outwrest unendeavored fulfillment scientifical Pianokoto Chelonia
Freudian sperate unchary hyperneurotic phlogiston duodecahedron unflown Paguridea catena disrelishable Stygian paleopsychology cantoris phosphoritic disconcord fruited inblow somewhatly ilioperoneal forrard palfrey Satyrinae outfreeman melebiose
\",\n attachments: [],\n isStarred: true,\n labels: [\"company\"],\n time: new Date(new Date().getTime() - 7 * 60 * 60 * 1000),\n replies: [],\n folder: \"inbox\",\n isRead: false,\n },\n {\n id: 22,\n from: {\n email: \"dmallallh@ask.com\",\n name: \"Dagmar Mallall\",\n avatar: require(\"@src/assets/images/avatars/8.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@furl.net\",\n },\n ],\n subject: \"Function-based local productivity 💻\",\n cc: [],\n bcc: [],\n message:\n \"Dear Consumer,
gibbed preconceptual passionwort Goanese confluence ungnaw aubepine coadjacency Romipetal isochronic convener overinsistently psammophyte colpenchyma unlogic instinctivist motorcab wellhole receptacle sinistrocular avifaunal decagram paramountness samhita
sphincterismus Aunjetitz vagabondage parallelotropism unreceipted io wheretoever semivolcanic Chlamydomonadidae spittlestaff spermatogenic Sephardi berrigan lowly grotesquerie Pentameridae unsuccessive archlexicographer Stephanian reimpatriate untossed beth ventriloquial dedicational
\",\n attachments: [],\n isStarred: false,\n labels: [\"company\"],\n time: new Date(new Date().getTime() - 5 * 20 * 60 * 1000),\n replies: [],\n folder: \"draft\",\n isRead: false,\n },\n {\n id: 23,\n from: {\n email: \"nmacgaughyi@aol.com\",\n name: \"Nada MacGaughy\",\n avatar: require(\"@src/assets/images/avatars/3.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@cnet.com\",\n },\n ],\n subject: \"Compatible object-oriented policy \",\n cc: [],\n bcc: [],\n message:\n \"Hello John,
miraculous pirijiri meekheartedness superoxygenation Elric paries epideictical Prajapati reassign stridlins spoach overreadily abusion sailmaking illiterately septangularness retinene Hler exceptionary ferberite possessionalist piperide Oschophoria beau
abnormalize yearnfulness Janiculum sixhaend abstemiousness uterogestation orchestrina gallotannin muckment melanoblast supercivilization inclusionist electroosmotically immatchable stomatoplastic satinity hydrogen unexorable quinamidine milksopism fascinating ratsbane endocline Zolaist
\",\n attachments: [\n {\n fileName: \"Leo.xls\",\n thumbnail: require(\"@src/assets/images/icons/xls.png\").default,\n url: \"\",\n size: \"33mb\",\n },\n ],\n isStarred: false,\n labels: [\"private\"],\n time: new Date(new Date().getTime() - 2 * 60 * 60 * 1000),\n replies: [],\n folder: \"trash\",\n isRead: false,\n },\n {\n id: 24,\n from: {\n email: \"douldcottj@yellowpages.com\",\n name: \"Dalila Ouldcott\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@github.io\",\n },\n ],\n subject: \"User-friendly value-added application 😊\",\n cc: [],\n bcc: [],\n message:\n \"Hey John,
wellish laminable ineunt popshop catalyte prismatize campimetrical lentisk excluding portlet coccinellid impestation Bangash Lollardist perameloid procerebrum presume cashmerette washbasin nainsook Odontolcae Alea holcodont welted
cibarious terrifical uploop naphthaleneacetic containable nonsailor Zwinglian blighty benchful guar porch fallectomy building coinvolve eidolism warmth unclericalize seismographic recongeal ethanethial clog regicidal regainment legific
\",\n attachments: [\n {\n fileName: \"example.doc\",\n thumbnail: require(\"@src/assets/images/icons/doc.png\").default,\n url: \"\",\n size: \"21mb\",\n },\n ],\n isStarred: false,\n labels: [\"personal\"],\n time: new Date(new Date().getTime() - 1 * 30 * 60 * 1000),\n replies: [\n {\n id: 25,\n from: {\n email: \"johndoe@mail.com\",\n name: \"John Doe\",\n avatar: require(\"@src/assets/images/avatars/11.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"hettiem@mail.com\",\n },\n ],\n subject: \"🎯 Focused impactful open system\",\n cc: [],\n bcc: [],\n message:\n \"Hello Hettie,
Marshmallow cookie jelly liquorice. Powder macaroon cake pastry biscuit. Cotton candy cotton candy jelly chocolate bar. Sesame snaps candy gummi bears cake cookie jujubes. Sweet I love sweet roll. Sesame snaps I love marzipan. Jelly powder tootsie roll. Marshmallow pudding cookie fruitcake liquorice powder. I love I love cookie chupa chups fruitcake ice cream I love biscuit I love. Tiramisu apple pie candy canes cookie gummies. Donut toffee bear claw topping jelly-o. Cupcake icing muffin. Cookie brownie wafer pie sweet. Icing sesame snaps halvah toffee marshmallow lemon drops jelly.
Tiramisu candy canes powder. Powder chocolate bar halvah liquorice cake I love danish. Cake wafer apple pie. Bear claw fruitcake I love marzipan dessert marzipan lollipop. Halvah gingerbread jelly chupa chups tiramisu I love wafer gummi bears. Candy powder caramels candy gummies. Tart tart cupcake brownie. Bear claw gummies toffee. Tiramisu donut cake chocolate bar. Halvah chocolate bar donut jelly-o. Icing candy brownie chocolate. Pastry bear claw halvah gummies chocolate bar chocolate. Apple pie danish wafer I love biscuit.
Regrads,
John Doe
\",\n attachments: [],\n isStarred: false,\n labels: [],\n time: \"Mon Dec 10 2018 10:56:00 GMT+0000 (GMT)\",\n replies: [],\n folder: \"inbox\",\n isRead: false,\n },\n {\n id: 26,\n from: {\n email: \"hettiem@mail.com\",\n name: \"Hettie Mcerlean\",\n avatar: require(\"@src/assets/images/avatars/3.png\").default,\n },\n to: [\n {\n name: \"me\",\n email: \"johndoe@mail.com\",\n },\n ],\n subject: \"Profound systemic alliance 🎉 🎊\",\n cc: [],\n bcc: [],\n message:\n \"Oat cake tart danish jelly beans brownie I love. Liquorice I love lollipop chocolate cake carrot cake toffee. Tart muffin candy canes croissant sugar plum lollipop. Macaroon cheesecake marshmallow powder sweet roll bonbon candy apple pie candy canes.
Regrads,
Hettie Mcerlean
\",\n attachments: [],\n isStarred: false,\n labels: [],\n time: \"Mon Dec 10 2018 11:25:00 GMT+0000 (GMT)\",\n replies: [],\n folder: \"inbox\",\n isRead: false,\n },\n ],\n folder: \"inbox\",\n isRead: true,\n },\n ],\n};\n\n// ------------------------------------------------\n// GET: Return Emails\n// ------------------------------------------------\nmock.onGet(\"/apps/email/emails\").reply((config) => {\n const { q = \"\", folder = \"inbox\", label } = config.params;\n\n const queryLowered = q.toLowerCase();\n\n function isInFolder(email) {\n if (folder === \"trash\") return email.folder === \"trash\";\n if (folder === \"starred\")\n return email.isStarred && email.folder !== \"trash\";\n return (\n email.folder === (folder || email.folder) && email.folder !== \"trash\"\n );\n }\n\n const filteredData = data.emails.filter(\n (email) =>\n /* eslint-disable operator-linebreak, implicit-arrow-linebreak */\n (email.from.name.toLowerCase().includes(queryLowered) ||\n email.subject.toLowerCase().includes(queryLowered)) &&\n isInFolder(email) &&\n (label ? email.labels.includes(label) : true)\n );\n /* eslint-enable */\n\n // ------------------------------------------------\n // Email Meta\n // ------------------------------------------------\n const emailsMeta = {\n inbox: data.emails.filter(\n (email) => !email.isDeleted && !email.isRead && email.folder === \"inbox\"\n ).length,\n draft: data.emails.filter((email) => email.folder === \"draft\").length,\n spam: data.emails.filter(\n (email) => !email.isDeleted && !email.isRead && email.folder === \"spam\"\n ).length,\n };\n\n return [\n 200,\n {\n emails: filteredData.reverse(),\n emailsMeta,\n },\n ];\n});\n\n// ------------------------------------------------\n// POST: Update Email\n// ------------------------------------------------\nmock.onPost(\"/apps/email/update-emails\").reply((config) => {\n const { emailIds, dataToUpdate } = JSON.parse(config.data);\n function updateMailData(email) {\n Object.assign(email, dataToUpdate);\n }\n\n data.emails.forEach((email) => {\n if (emailIds.includes(email.id)) updateMailData(email);\n });\n\n return [200];\n});\n\n// ------------------------------------------------\n// POST: Update Emails Label\n// ------------------------------------------------\nmock.onPost(\"/apps/email/update-emails-label\").reply((config) => {\n const { emailIds, label } = JSON.parse(config.data);\n\n function updateMailLabels(email) {\n const labelIndex = email.labels.indexOf(label);\n\n if (labelIndex === -1) email.labels.push(label);\n else email.labels.splice(labelIndex, 1);\n }\n\n data.emails.forEach((email) => {\n if (emailIds.includes(email.id)) updateMailLabels(email);\n });\n\n return [200];\n});\n\n// ------------------------------------------------\n// GET: GET Single Email\n// ------------------------------------------------\nmock.onGet(\"/apps/email/get-email\").reply((config) => {\n const { id } = config;\n\n const emailId = Number(id);\n\n const mail = data.emails.find((i) => i.id === emailId);\n const mailIndex = data.emails.findIndex((i) => i.id === mail.id);\n mailIndex === 0\n ? (mail.hasPreviousMail = true)\n : (mail.hasPreviousMail = false);\n mailIndex === data.emails.length - 1\n ? (mail.hasNextMail = true)\n : (mail.hasNextMail = false);\n\n return mail ? [200, mail] : [404];\n});\n\n// ------------------------------------------------\n// GET: Paginate Existing Email\n// ------------------------------------------------\nmock.onGet(\"/apps/email/paginate-email\").reply((config) => {\n const { dir, emailId } = config.params;\n\n const currentEmailIndex = data.emails.findIndex((e) => e.id === emailId);\n\n const newEmailIndex =\n dir === \"previous\" ? currentEmailIndex - 1 : currentEmailIndex + 1;\n\n const newEmail = data.emails[newEmailIndex];\n\n return newEmail ? [200, newEmail] : [404];\n});\n/* eslint-enable */\n","// ** Returns paginated array\nexport const paginateArray = (array, perPage, page) =>\n array.slice((page - 1) * perPage, page * perPage);\n\n// ** Returns sorted array\nexport const sortCompare = (key) => (a, b) => {\n const fieldA = a[key];\n const fieldB = b[key];\n\n let comparison = 0;\n if (fieldA > fieldB) {\n comparison = 1;\n } else if (fieldA < fieldB) {\n comparison = -1;\n }\n return comparison;\n};\n\n// ** Returns number range\nexport const getRandomInt = (min, max) => {\n if (min > max) {\n const temp = max;\n /* eslint-disable no-param-reassign */\n max = min;\n min = temp;\n /* eslint-enable */\n }\n\n if (min <= 0) {\n return Math.floor(Math.random() * (max + Math.abs(min) + 1)) + min;\n }\n return Math.floor(Math.random() * max) + min;\n};\n\n// ** Returns random date\nexport const randomDate = (start, end) => {\n const diff = end.getTime() - start.getTime();\n const newDiff = diff * Math.random();\n const date = new Date(start.getTime() + newDiff);\n return date;\n};\n","import mock from \"../mock\";\n\n// ** Utils\nimport { paginateArray } from \"../utils\";\n\nconst data = {\n invoices: [\n {\n id: 4987,\n issuedDate: \"13 Dec 2019\",\n client: {\n address: \"7777 Mendez Plains\",\n company: \"Hall-Robbins PLC\",\n companyEmail: \"don85@johnson.com\",\n country: \"USA\",\n contact: \"(616) 865-4180\",\n name: \"Jordan Stevenson\",\n },\n service: \"Software Development\",\n total: 3428,\n avatar: \"\",\n invoiceStatus: \"Paid\",\n balance: \"$724\",\n dueDate: \"23 Apr 2019\",\n },\n {\n id: 4988,\n issuedDate: \"17 Jul 2019\",\n client: {\n address: \"04033 Wesley Wall Apt. 961\",\n company: \"Mccann LLC and Sons\",\n companyEmail: \"brenda49@taylor.info\",\n country: \"Haiti\",\n contact: \"(226) 204-8287\",\n name: \"Stephanie Burns\",\n },\n service: \"UI/UX Design & Development\",\n total: 5219,\n avatar: require(\"@src/assets/images/avatars/10-small.png\").default,\n invoiceStatus: \"Downloaded\",\n balance: 0,\n dueDate: \"15 Dec 2019\",\n },\n {\n id: 4989,\n issuedDate: \"19 Oct 2019\",\n client: {\n address: \"5345 Robert Squares\",\n company: \"Leonard-Garcia and Sons\",\n companyEmail: \"smithtiffany@powers.com\",\n country: \"Denmark\",\n contact: \"(955) 676-1076\",\n name: \"Tony Herrera\",\n },\n service: \"Unlimited Extended License\",\n total: 3719,\n avatar: require(\"@src/assets/images/avatars/1-small.png\").default,\n invoiceStatus: \"Paid\",\n balance: 0,\n dueDate: \"03 Nov 2019\",\n },\n {\n id: 4990,\n issuedDate: \"06 Mar 2020\",\n client: {\n address: \"19022 Clark Parks Suite 149\",\n company: \"Smith, Miller and Henry LLC\",\n companyEmail: \"mejiageorge@lee-perez.com\",\n country: \"Cambodia\",\n contact: \"(832) 323-6914\",\n name: \"Kevin Patton\",\n },\n service: \"Software Development\",\n total: 4749,\n avatar: require(\"@src/assets/images/avatars/9-small.png\").default,\n invoiceStatus: \"Sent\",\n balance: 0,\n dueDate: \"11 Feb 2020\",\n },\n {\n id: 4991,\n issuedDate: \"08 Feb 2020\",\n client: {\n address: \"8534 Saunders Hill Apt. 583\",\n company: \"Garcia-Cameron and Sons\",\n companyEmail: \"brandon07@pierce.com\",\n country: \"Martinique\",\n contact: \"(970) 982-3353\",\n name: \"Mrs. Julie Donovan MD\",\n },\n service: \"UI/UX Design & Development\",\n total: 4056,\n avatar: require(\"@src/assets/images/avatars/10-small.png\").default,\n invoiceStatus: \"Draft\",\n balance: \"$815\",\n dueDate: \"30 Jun 2019\",\n },\n {\n id: 4992,\n issuedDate: \"26 Aug 2019\",\n client: {\n address: \"661 Perez Run Apt. 778\",\n company: \"Burnett-Young PLC\",\n companyEmail: \"guerrerobrandy@beasley-harper.com\",\n country: \"Botswana\",\n contact: \"(511) 938-9617\",\n name: \"Amanda Phillips\",\n },\n service: \"UI/UX Design & Development\",\n total: 2771,\n avatar: \"\",\n invoiceStatus: \"Paid\",\n balance: 0,\n dueDate: \"24 Jun 2019\",\n },\n {\n id: 4993,\n issuedDate: \"17 Sep 2019\",\n client: {\n address: \"074 Long Union\",\n company: \"Wilson-Lee LLC\",\n companyEmail: \"williamshenry@moon-smith.com\",\n country: \"Montserrat\",\n contact: \"(504) 859-2893\",\n name: \"Christina Collier\",\n },\n service: \"UI/UX Design & Development\",\n total: 2713,\n avatar: \"\",\n invoiceStatus: \"Draft\",\n balance: \"$407\",\n dueDate: \"22 Nov 2019\",\n },\n {\n id: 4994,\n issuedDate: \"11 Feb 2020\",\n client: {\n address: \"5225 Ford Cape Apt. 840\",\n company: \"Schwartz, Henry and Rhodes Group\",\n companyEmail: \"margaretharvey@russell-murray.com\",\n country: \"Oman\",\n contact: \"(758) 403-7718\",\n name: \"David Flores\",\n },\n service: \"Template Customization\",\n total: 4309,\n avatar: require(\"@src/assets/images/avatars/9-small.png\").default,\n invoiceStatus: \"Paid\",\n balance: \"-$205\",\n dueDate: \"10 Feb 2020\",\n },\n {\n id: 4995,\n issuedDate: \"26 Jan 2020\",\n client: {\n address: \"23717 James Club Suite 277\",\n company: \"Henderson-Holder PLC\",\n companyEmail: \"dianarodriguez@villegas.com\",\n country: \"Cambodia\",\n contact: \"(292) 873-8254\",\n name: \"Valerie Perez\",\n },\n service: \"Software Development\",\n total: 3367,\n avatar: require(\"@src/assets/images/avatars/2-small.png\").default,\n invoiceStatus: \"Downloaded\",\n balance: 0,\n dueDate: \"24 Dec 2019\",\n },\n {\n id: 4996,\n issuedDate: \"15 Jan 2020\",\n client: {\n address: \"4528 Myers Gateway\",\n company: \"Page-Wise PLC\",\n companyEmail: \"bwilson@norris-brock.com\",\n country: \"Guam\",\n contact: \"(956) 803-2008\",\n name: \"Susan Dickerson\",\n },\n service: \"Software Development\",\n total: 4776,\n avatar: require(\"@src/assets/images/avatars/9-small.png\").default,\n invoiceStatus: \"Downloaded\",\n balance: \"$305\",\n dueDate: \"02 Jun 2019\",\n },\n {\n id: 4997,\n issuedDate: \"27 Sep 2019\",\n client: {\n address: \"4234 Mills Club Suite 107\",\n company: \"Turner PLC Inc\",\n companyEmail: \"markcampbell@bell.info\",\n country: \"United States Virgin Islands\",\n contact: \"(716) 962-8635\",\n name: \"Kelly Smith\",\n },\n service: \"Unlimited Extended License\",\n total: 3789,\n avatar: require(\"@src/assets/images/avatars/4-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: \"$666\",\n dueDate: \"18 Mar 2020\",\n },\n {\n id: 4998,\n issuedDate: \"31 Jul 2019\",\n client: {\n address: \"476 Keith Meadow\",\n company: \"Levine-Dorsey PLC\",\n companyEmail: \"mary61@rosario.com\",\n country: \"Syrian Arab Republic\",\n contact: \"(523) 449-0782\",\n name: \"Jamie Jones\",\n },\n service: \"Unlimited Extended License\",\n total: 5200,\n avatar: require(\"@src/assets/images/avatars/5-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: 0,\n dueDate: \"17 Jan 2020\",\n },\n {\n id: 4999,\n issuedDate: \"14 Feb 2020\",\n client: {\n address: \"56381 Ashley Village Apt. 332\",\n company: \"Hall, Thompson and Ramirez LLC\",\n companyEmail: \"sean22@cook.com\",\n country: \"Ukraine\",\n contact: \"(583) 470-8356\",\n name: \"Ruben Garcia\",\n },\n service: \"Software Development\",\n total: 4558,\n avatar: require(\"@src/assets/images/avatars/7-small.png\").default,\n invoiceStatus: \"Paid\",\n balance: 0,\n dueDate: \"01 Oct 2019\",\n },\n {\n id: 5000,\n issuedDate: \"21 May 2019\",\n client: {\n address: \"6946 Gregory Plaza Apt. 310\",\n company: \"Lambert-Thomas Group\",\n companyEmail: \"mccoymatthew@lopez-jenkins.net\",\n country: \"Vanuatu\",\n contact: \"(366) 906-6467\",\n name: \"Ryan Meyer\",\n },\n service: \"Template Customization\",\n total: 3503,\n avatar: require(\"@src/assets/images/avatars/9-small.png\").default,\n invoiceStatus: \"Paid\",\n balance: 0,\n dueDate: \"22 May 2019\",\n },\n {\n id: 5001,\n issuedDate: \"30 Jun 2019\",\n client: {\n address: \"64351 Andrew Lights\",\n company: \"Gregory-Haynes PLC\",\n companyEmail: \"novakshannon@mccarty-murillo.com\",\n country: \"Romania\",\n contact: \"(320) 616-3915\",\n name: \"Valerie Valdez\",\n },\n service: \"Unlimited Extended License\",\n total: 5285,\n avatar: require(\"@src/assets/images/avatars/2-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: \"-$202\",\n dueDate: \"02 Aug 2019\",\n },\n {\n id: 5002,\n issuedDate: \"21 Jun 2019\",\n client: {\n address: \"5702 Sarah Heights\",\n company: \"Wright-Schmidt LLC\",\n companyEmail: \"smithrachel@davis-rose.net\",\n country: \"Costa Rica\",\n contact: \"(435) 899-1963\",\n name: \"Melissa Wheeler\",\n },\n service: \"UI/UX Design & Development\",\n total: 3668,\n avatar: require(\"@src/assets/images/avatars/6-small.png\").default,\n invoiceStatus: \"Downloaded\",\n balance: \"$731\",\n dueDate: \"15 Dec 2019\",\n },\n {\n id: 5003,\n issuedDate: \"30 Dec 2019\",\n client: {\n address: \"668 Robert Flats\",\n company: \"Russell-Abbott Ltd\",\n companyEmail: \"scott96@mejia.net\",\n country: \"Congo\",\n contact: \"(254) 399-4728\",\n name: \"Alan Jimenez\",\n },\n service: \"Unlimited Extended License\",\n total: 4372,\n avatar: \"\",\n invoiceStatus: \"Sent\",\n balance: \"-$344\",\n dueDate: \"17 Sep 2019\",\n },\n {\n id: 5004,\n issuedDate: \"27 May 2019\",\n client: {\n address: \"55642 Chang Extensions Suite 373\",\n company: \"Williams LLC Inc\",\n companyEmail: \"cramirez@ross-bass.biz\",\n country: \"Saint Pierre and Miquelon\",\n contact: \"(648) 500-4338\",\n name: \"Jennifer Morris\",\n },\n service: \"Template Customization\",\n total: 3198,\n avatar: require(\"@src/assets/images/avatars/7-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: \"-$253\",\n dueDate: \"16 Aug 2019\",\n },\n {\n id: 5005,\n issuedDate: \"30 Jul 2019\",\n client: {\n address: \"56694 Eric Orchard\",\n company: \"Hudson, Bell and Phillips PLC\",\n companyEmail: \"arielberg@wolfe-smith.com\",\n country: \"Uruguay\",\n contact: \"(896) 544-3796\",\n name: \"Timothy Stevenson\",\n },\n service: \"Unlimited Extended License\",\n total: 5293,\n avatar: \"\",\n invoiceStatus: \"Past Due\",\n balance: 0,\n dueDate: \"01 Aug 2019\",\n },\n {\n id: 5006,\n issuedDate: \"10 Jun 2019\",\n client: {\n address: \"3727 Emma Island Suite 879\",\n company: \"Berry, Gonzalez and Heath Inc\",\n companyEmail: \"yrobinson@nichols.com\",\n country: \"Israel\",\n contact: \"(236) 784-5142\",\n name: \"Erik Hayden\",\n },\n service: \"Template Customization\",\n total: 5612,\n avatar: require(\"@src/assets/images/avatars/6-small.png\").default,\n invoiceStatus: \"Downloaded\",\n balance: \"$883\",\n dueDate: \"12 Apr 2019\",\n },\n {\n id: 5007,\n issuedDate: \"01 Feb 2020\",\n client: {\n address: \"953 Miller Common Suite 580\",\n company: \"Martinez, Fuller and Chavez and Sons\",\n companyEmail: \"tatejennifer@allen.net\",\n country: \"Cook Islands\",\n contact: \"(436) 717-2419\",\n name: \"Katherine Kennedy\",\n },\n service: \"Software Development\",\n total: 2230,\n avatar: require(\"@src/assets/images/avatars/1-small.png\").default,\n invoiceStatus: \"Sent\",\n balance: 0,\n dueDate: \"19 Nov 2019\",\n },\n {\n id: 5008,\n issuedDate: \"22 Mar 2020\",\n client: {\n address: \"808 Sullivan Street Apt. 135\",\n company: \"Wilson and Sons LLC\",\n companyEmail: \"gdurham@lee.com\",\n country: \"Nepal\",\n contact: \"(489) 946-3041\",\n name: \"Monica Fuller\",\n },\n service: \"Unlimited Extended License\",\n total: 2032,\n avatar: require(\"@src/assets/images/avatars/8-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: 0,\n dueDate: \"30 Nov 2019\",\n },\n {\n id: 5009,\n issuedDate: \"30 Nov 2019\",\n client: {\n address: \"25135 Christopher Creek\",\n company: \"Hawkins, Johnston and Mcguire PLC\",\n companyEmail: \"jenny96@lawrence-thompson.com\",\n country: \"Kiribati\",\n contact: \"(274) 246-3725\",\n name: \"Stacey Carter\",\n },\n service: \"UI/UX Design & Development\",\n total: 3128,\n avatar: require(\"@src/assets/images/avatars/3-small.png\").default,\n invoiceStatus: \"Paid\",\n balance: 0,\n dueDate: \"10 Sep 2019\",\n },\n {\n id: 5010,\n issuedDate: \"06 Jan 2020\",\n client: {\n address: \"81285 Rebecca Estates Suite 046\",\n company: \"Huynh-Mills and Sons\",\n companyEmail: \"jgutierrez@jackson.com\",\n country: \"Swaziland\",\n contact: \"(258) 211-5970\",\n name: \"Chad Davis\",\n },\n service: \"Software Development\",\n total: 2060,\n avatar: require(\"@src/assets/images/avatars/2-small.png\").default,\n invoiceStatus: \"Downloaded\",\n balance: 0,\n dueDate: \"08 Dec 2019\",\n },\n {\n id: 5011,\n issuedDate: \"01 Jun 2019\",\n client: {\n address: \"3102 Briggs Dale Suite 118\",\n company: \"Jones-Cooley and Sons\",\n companyEmail: \"hunter14@jones.com\",\n country: \"Congo\",\n contact: \"(593) 965-4100\",\n name: \"Chris Reyes\",\n },\n service: \"UI/UX Design & Development\",\n total: 4077,\n avatar: \"\",\n invoiceStatus: \"Draft\",\n balance: 0,\n dueDate: \"01 Feb 2020\",\n },\n {\n id: 5012,\n issuedDate: \"30 Oct 2019\",\n client: {\n address: \"811 Jill Skyway\",\n company: \"Jones PLC Ltd\",\n companyEmail: \"pricetodd@johnson-jenkins.com\",\n country: \"Brazil\",\n contact: \"(585) 829-2603\",\n name: \"Laurie Summers\",\n },\n service: \"Template Customization\",\n total: 2872,\n avatar: require(\"@src/assets/images/avatars/4-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: 0,\n dueDate: \"18 Oct 2019\",\n },\n {\n id: 5013,\n issuedDate: \"05 Feb 2020\",\n client: {\n address: \"2223 Brandon Inlet Suite 597\",\n company: \"Jordan, Gomez and Ross Group\",\n companyEmail: \"perrydavid@chapman-rogers.com\",\n country: \"Congo\",\n contact: \"(527) 351-5517\",\n name: \"Lindsay Wilson\",\n },\n service: \"Software Development\",\n total: 3740,\n avatar: require(\"@src/assets/images/avatars/10-small.png\").default,\n invoiceStatus: \"Draft\",\n balance: 0,\n dueDate: \"01 Nov 2019\",\n },\n {\n id: 5014,\n issuedDate: \"01 Dec 2019\",\n client: {\n address: \"08724 Barry Causeway\",\n company: \"Gonzalez, Moody and Glover LLC\",\n companyEmail: \"leahgriffin@carpenter.com\",\n country: \"Equatorial Guinea\",\n contact: \"(628) 903-0132\",\n name: \"Jenna Castro\",\n },\n service: \"Unlimited Extended License\",\n total: 3623,\n avatar: \"\",\n invoiceStatus: \"Downloaded\",\n balance: 0,\n dueDate: \"23 Sep 2019\",\n },\n {\n id: 5015,\n issuedDate: \"16 Apr 2019\",\n client: {\n address: \"073 Holt Ramp Apt. 755\",\n company: \"Ashley-Pacheco Ltd\",\n companyEmail: \"esparzadaniel@allen.com\",\n country: \"Seychelles\",\n contact: \"(847) 396-9904\",\n name: \"Wendy Weber\",\n },\n service: \"Software Development\",\n total: 2477,\n avatar: require(\"@src/assets/images/avatars/7-small.png\").default,\n invoiceStatus: \"Draft\",\n balance: 0,\n dueDate: \"01 Apr 2019\",\n },\n {\n id: 5016,\n issuedDate: \"24 Jan 2020\",\n client: {\n address: \"984 Sherry Trail Apt. 953\",\n company: \"Berry PLC Group\",\n companyEmail: \"todd34@owens-morgan.com\",\n country: \"Ireland\",\n contact: \"(852) 249-4539\",\n name: \"April Yates\",\n },\n service: \"Unlimited Extended License\",\n total: 3904,\n avatar: \"\",\n invoiceStatus: \"Paid\",\n balance: \"$951\",\n dueDate: \"30 Sep 2019\",\n },\n {\n id: 5017,\n issuedDate: \"24 Feb 2020\",\n client: {\n address: \"093 Jonathan Camp Suite 953\",\n company: \"Allen Group Ltd\",\n companyEmail: \"roydavid@bailey.com\",\n country: \"Netherlands\",\n contact: \"(917) 984-2232\",\n name: \"Daniel Marshall PhD\",\n },\n service: \"UI/UX Design & Development\",\n total: 3102,\n avatar: require(\"@src/assets/images/avatars/1-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: \"-$153\",\n dueDate: \"25 Aug 2019\",\n },\n {\n id: 5018,\n issuedDate: \"29 Feb 2020\",\n client: {\n address: \"4735 Kristie Islands Apt. 259\",\n company: \"Chapman-Schneider LLC\",\n companyEmail: \"baldwinjoel@washington.com\",\n country: \"Cocos (Keeling) Islands\",\n contact: \"(670) 409-3703\",\n name: \"Randy Rich\",\n },\n service: \"UI/UX Design & Development\",\n total: 2483,\n avatar: require(\"@src/assets/images/avatars/5-small.png\").default,\n invoiceStatus: \"Draft\",\n balance: 0,\n dueDate: \"10 Jul 2019\",\n },\n {\n id: 5019,\n issuedDate: \"07 Aug 2019\",\n client: {\n address: \"92218 Andrew Radial\",\n company: \"Mcclure, Hernandez and Simon Ltd\",\n companyEmail: \"psmith@morris.info\",\n country: \"Macao\",\n contact: \"(646) 263-0257\",\n name: \"Mrs. Jodi Chapman\",\n },\n service: \"Unlimited Extended License\",\n total: 2825,\n avatar: require(\"@src/assets/images/avatars/8-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: \"-$459\",\n dueDate: \"14 Oct 2019\",\n },\n {\n id: 5020,\n issuedDate: \"10 May 2019\",\n client: {\n address: \"2342 Michelle Valley\",\n company: \"Hamilton PLC and Sons\",\n companyEmail: \"lori06@morse.com\",\n country: \"Somalia\",\n contact: \"(751) 213-4288\",\n name: \"Steven Myers\",\n },\n service: \"Unlimited Extended License\",\n total: 2029,\n avatar: require(\"@src/assets/images/avatars/4-small.png\").default,\n invoiceStatus: \"Past Due\",\n balance: 0,\n dueDate: \"28 Mar 2019\",\n },\n {\n id: 5021,\n issuedDate: \"02 Apr 2019\",\n client: {\n address: \"16039 Brittany Terrace Apt. 128\",\n company: \"Silva-Reeves LLC\",\n companyEmail: \"zpearson@miller.com\",\n country: \"Slovakia (Slovak Republic)\",\n contact: \"(655) 649-7872\",\n name: \"Charles Alexander\",\n },\n service: \"Software Development\",\n total: 3208,\n avatar: \"\",\n invoiceStatus: \"Sent\",\n balance: 0,\n dueDate: \"06 Sep 2019\",\n },\n {\n id: 5022,\n issuedDate: \"02 May 2019\",\n client: {\n address: \"37856 Olsen Lakes Apt. 852\",\n company: \"Solis LLC Ltd\",\n companyEmail: \"strongpenny@young.net\",\n country: \"Brazil\",\n contact: \"(402) 935-0735\",\n name: \"Elizabeth Jones\",\n },\n service: \"Software Development\",\n total: 3077,\n avatar: \"\",\n invoiceStatus: \"Sent\",\n balance: 0,\n dueDate: \"09 May 2019\",\n },\n {\n id: 5023,\n issuedDate: \"23 Mar 2020\",\n client: {\n address: \"11489 Griffin Plaza Apt. 927\",\n company: \"Munoz-Peters and Sons\",\n companyEmail: \"carrietorres@acosta.com\",\n country: \"Argentina\",\n contact: \"(915) 448-6271\",\n name: \"Heidi Walton\",\n },\n service: \"Software Development\",\n total: 5578,\n avatar: require(\"@src/assets/images/avatars/9-small.png\").default,\n invoiceStatus: \"Draft\",\n balance: 0,\n dueDate: \"23 Jul 2019\",\n },\n {\n id: 5024,\n issuedDate: \"28 Sep 2019\",\n client: {\n address: \"276 Michael Gardens Apt. 004\",\n company: \"Shea, Velez and Garcia LLC\",\n companyEmail: \"zjohnson@nichols-powers.com\",\n country: \"Philippines\",\n contact: \"(817) 700-2984\",\n name: \"Christopher Allen\",\n },\n service: \"Software Development\",\n total: 2787,\n avatar: require(\"@src/assets/images/avatars/1-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: 0,\n dueDate: \"25 Sep 2019\",\n },\n {\n id: 5025,\n issuedDate: \"21 Feb 2020\",\n client: {\n address: \"633 Bell Well Apt. 057\",\n company: \"Adams, Simmons and Brown Group\",\n companyEmail: \"kayla09@thomas.com\",\n country: \"Martinique\",\n contact: \"(266) 611-9482\",\n name: \"Joseph Oliver\",\n },\n service: \"UI/UX Design & Development\",\n total: 5591,\n avatar: \"\",\n invoiceStatus: \"Downloaded\",\n balance: 0,\n dueDate: \"07 Jun 2019\",\n },\n {\n id: 5026,\n issuedDate: \"24 May 2019\",\n client: {\n address: \"1068 Lopez Fall\",\n company: \"Williams-Lawrence and Sons\",\n companyEmail: \"melvindavis@allen.info\",\n country: \"Mexico\",\n contact: \"(739) 745-9728\",\n name: \"Megan Roberts\",\n },\n service: \"Template Customization\",\n total: 2783,\n avatar: require(\"@src/assets/images/avatars/6-small.png\").default,\n invoiceStatus: \"Draft\",\n balance: 0,\n dueDate: \"22 Oct 2019\",\n },\n {\n id: 5027,\n issuedDate: \"13 Jan 2020\",\n client: {\n address: \"86691 Mackenzie Light Suite 568\",\n company: \"Deleon Inc LLC\",\n companyEmail: \"gjordan@fernandez-coleman.com\",\n country: \"Costa Rica\",\n contact: \"(682) 804-6506\",\n name: \"Mary Garcia\",\n },\n service: \"Template Customization\",\n total: 2719,\n avatar: \"\",\n invoiceStatus: \"Sent\",\n balance: 0,\n dueDate: \"04 Feb 2020\",\n },\n {\n id: 5028,\n issuedDate: \"18 May 2019\",\n client: {\n address: \"86580 Sarah Bridge\",\n company: \"Farmer, Johnson and Anderson Group\",\n companyEmail: \"robertscott@garcia.com\",\n country: \"Cameroon\",\n contact: \"(775) 366-0411\",\n name: \"Crystal Mays\",\n },\n service: \"Template Customization\",\n total: 3325,\n avatar: \"\",\n invoiceStatus: \"Paid\",\n balance: \"$361\",\n dueDate: \"02 Mar 2020\",\n },\n {\n id: 5029,\n issuedDate: \"29 Oct 2019\",\n client: {\n address: \"49709 Edwin Ports Apt. 353\",\n company: \"Sherman-Johnson PLC\",\n companyEmail: \"desiree61@kelly.com\",\n country: \"Macedonia\",\n contact: \"(510) 536-6029\",\n name: \"Nicholas Tanner\",\n },\n service: \"Template Customization\",\n total: 3851,\n avatar: \"\",\n invoiceStatus: \"Paid\",\n balance: 0,\n dueDate: \"25 Aug 2019\",\n },\n {\n id: 5030,\n issuedDate: \"07 Apr 2019\",\n client: {\n address: \"3856 Mathis Squares Apt. 584\",\n company: \"Byrd LLC PLC\",\n companyEmail: \"jeffrey25@martinez-hodge.com\",\n country: \"Congo\",\n contact: \"(253) 230-4657\",\n name: \"Mr. Justin Richardson\",\n },\n service: \"Template Customization\",\n total: 5565,\n avatar: \"\",\n invoiceStatus: \"Draft\",\n balance: 0,\n dueDate: \"06 Mar 2020\",\n },\n {\n id: 5031,\n issuedDate: \"21 Aug 2019\",\n client: {\n address: \"141 Adrian Ridge Suite 550\",\n company: \"Stone-Zimmerman Group\",\n companyEmail: \"john77@anderson.net\",\n country: \"Falkland Islands (Malvinas)\",\n contact: \"(612) 546-3485\",\n name: \"Jennifer Summers\",\n },\n service: \"Template Customization\",\n total: 3313,\n avatar: require(\"@src/assets/images/avatars/3-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: 0,\n dueDate: \"09 Jun 2019\",\n },\n {\n id: 5032,\n issuedDate: \"31 May 2019\",\n client: {\n address: \"01871 Kristy Square\",\n company: \"Yang, Hansen and Hart PLC\",\n companyEmail: \"ywagner@jones.com\",\n country: \"Germany\",\n contact: \"(203) 601-8603\",\n name: \"Richard Payne\",\n },\n service: \"Template Customization\",\n total: 5181,\n avatar: \"\",\n invoiceStatus: \"Past Due\",\n balance: 0,\n dueDate: \"22 Oct 2019\",\n },\n {\n id: 5033,\n issuedDate: \"12 Jul 2019\",\n client: {\n address: \"075 Smith Views\",\n company: \"Jenkins-Rosales Inc\",\n companyEmail: \"calvin07@joseph-edwards.org\",\n country: \"Colombia\",\n contact: \"(895) 401-4255\",\n name: \"Lori Wells\",\n },\n service: \"Template Customization\",\n total: 2869,\n avatar: require(\"@src/assets/images/avatars/1-small.png\").default,\n invoiceStatus: \"Partial Payment\",\n balance: 0,\n dueDate: \"22 Mar 2020\",\n },\n {\n id: 5034,\n issuedDate: \"10 Jul 2019\",\n client: {\n address: \"2577 Pearson Overpass Apt. 314\",\n company: \"Mason-Reed PLC\",\n companyEmail: \"eric47@george-castillo.com\",\n country: \"Paraguay\",\n contact: \"(602) 336-9806\",\n name: \"Tammy Sanchez\",\n },\n service: \"Unlimited Extended License\",\n total: 4836,\n avatar: \"\",\n invoiceStatus: \"Paid\",\n balance: 0,\n dueDate: \"22 Oct 2019\",\n },\n {\n id: 5035,\n issuedDate: \"20 Jul 2019\",\n client: {\n address: \"1770 Sandra Mountains Suite 636\",\n company: \"Foster-Pham PLC\",\n companyEmail: \"jamesjoel@chapman.net\",\n country: \"Western Sahara\",\n contact: \"(936) 550-1638\",\n name: \"Dana Carey\",\n },\n service: \"UI/UX Design & Development\",\n total: 4263,\n avatar: \"\",\n invoiceStatus: \"Draft\",\n balance: \"$762\",\n dueDate: \"12 Jun 2019\",\n },\n {\n id: 5036,\n issuedDate: \"19 Apr 2019\",\n client: {\n address: \"78083 Laura Pines\",\n company: \"Richardson and Sons LLC\",\n companyEmail: \"pwillis@cross.org\",\n country: \"Bhutan\",\n contact: \"(687) 660-2473\",\n name: \"Andrew Burns\",\n },\n service: \"Unlimited Extended License\",\n total: 3171,\n avatar: require(\"@src/assets/images/avatars/9-small.png\").default,\n invoiceStatus: \"Paid\",\n balance: \"-$205\",\n dueDate: \"25 Sep 2019\",\n },\n ],\n};\n\n// ------------------------------------------------\n// GET: Return Invoice List\n// ------------------------------------------------\nmock.onGet(\"/apps/invoice/invoices\").reply((config) => {\n // eslint-disable-next-line object-curly-newline\n const {\n q = \"\",\n perPage = 10,\n page = 1,\n status = null,\n sort,\n sortColumn,\n } = config;\n /* eslint-enable */\n\n const dataAsc = data.invoices.sort((a, b) => {\n if (a[sortColumn]) {\n return a[sortColumn] < b[sortColumn] ? -1 : 1;\n } else {\n const splitColumn = sortColumn.split(\".\");\n const columnA = a[splitColumn[0]][splitColumn[1]];\n const columnB = b[splitColumn[0]][splitColumn[1]];\n return columnA < columnB ? -1 : 1;\n }\n });\n\n const dataToFilter = sort === \"asc\" ? dataAsc : dataAsc.reverse();\n\n const queryLowered = q.toLowerCase();\n const filteredData = dataToFilter.filter((invoice) => {\n if (String(\"paid\").includes(queryLowered) && invoice.balance === 0) {\n return invoice.balance === 0;\n } else {\n /* eslint-disable operator-linebreak, implicit-arrow-linebreak */\n return (\n (invoice.client.companyEmail.toLowerCase().includes(queryLowered) ||\n invoice.client.name.toLowerCase().includes(queryLowered) ||\n String(invoice.id).toLowerCase().includes(queryLowered) ||\n String(invoice.total).toLowerCase().includes(queryLowered) ||\n String(invoice.balance).toLowerCase().includes(queryLowered) ||\n invoice.dueDate.toLowerCase().includes(queryLowered)) &&\n invoice.invoiceStatus.toLowerCase() ===\n (status.toLowerCase() || invoice.invoiceStatus.toLowerCase())\n );\n }\n });\n /* eslint-enable */\n\n return [\n 200,\n {\n allData: data.invoices,\n total: filteredData.length,\n invoices:\n filteredData.length <= perPage\n ? filteredData\n : paginateArray(filteredData, perPage, page),\n },\n ];\n});\n\n// ------------------------------------------------\n// GET: Return Single Invoice\n// ------------------------------------------------\nmock.onGet(/\\/api\\/invoice\\/invoices\\/\\d+/).reply((config) => {\n // // Get event id from URL\n const invoiceId = Number(\n config.url.substring(config.url.lastIndexOf(\"/\") + 1)\n );\n\n const invoiceIndex = data.invoices.findIndex((e) => e.id === invoiceId);\n const responseData = {\n invoice: data.invoices[invoiceIndex],\n paymentDetails: {\n totalDue: \"$12,110.55\",\n bankName: \"American Bank\",\n country: \"United States\",\n iban: \"ETD95476213874685\",\n swiftCode: \"BR91905\",\n },\n };\n return [200, responseData];\n});\n\n// ------------------------------------------------\n// DELETE: Deletes Invoice\n// ------------------------------------------------\nmock.onDelete(\"/apps/invoice/delete\").reply((config) => {\n // Get invoice id from URL\n let invoiceId = config.id;\n\n // Convert Id to number\n invoiceId = Number(invoiceId);\n\n const invoiceIndex = data.invoices.findIndex((t) => t.id === invoiceId);\n data.invoices.splice(invoiceIndex, 1);\n\n return [200];\n});\n\n// ------------------------------------------------\n// GET: Return Clients\n// ------------------------------------------------\nmock.onGet(\"/api/invoice/clients\").reply(() => {\n const clients = data.invoices.map((invoice) => invoice.client);\n return [200, clients.slice(0, 5)];\n});\n","/*eslint-disable */\nimport mock from \"../mock\";\n\nconst date = new Date();\nconst prevDay = new Date().getDate() - 1;\nconst nextDay = new Date(new Date().getTime() + 24 * 60 * 60 * 1000);\n\n// prettier-ignore\nconst nextMonth = date.getMonth() === 11 ? new Date(date.getFullYear() + 1, 0, 1) : new Date(date.getFullYear(), date.getMonth() + 1, 1)\n// prettier-ignore\nconst prevMonth = date.getMonth() === 11 ? new Date(date.getFullYear() - 1, 0, 1) : new Date(date.getFullYear(), date.getMonth() - 1, 1)\n\nconst data = {\n events: [\n {\n id: 1,\n url: \"\",\n title: \"Design Review\",\n start: date,\n end: nextDay,\n allDay: false,\n extendedProps: {\n calendar: \"Business\",\n },\n },\n {\n id: 2,\n url: \"\",\n title: \"Meeting With Client\",\n start: new Date(date.getFullYear(), date.getMonth() + 1, -11),\n end: new Date(date.getFullYear(), date.getMonth() + 1, -10),\n allDay: true,\n extendedProps: {\n calendar: \"Business\",\n },\n },\n {\n id: 3,\n url: \"\",\n title: \"Family Trip\",\n allDay: true,\n start: new Date(date.getFullYear(), date.getMonth() + 1, -9),\n end: new Date(date.getFullYear(), date.getMonth() + 1, -7),\n extendedProps: {\n calendar: \"Holiday\",\n },\n },\n {\n id: 4,\n url: \"\",\n title: \"Doctor's Appointment\",\n start: new Date(date.getFullYear(), date.getMonth() + 1, -11),\n end: new Date(date.getFullYear(), date.getMonth() + 1, -10),\n allDay: true,\n extendedProps: {\n calendar: \"Personal\",\n },\n },\n {\n id: 5,\n url: \"\",\n title: \"Dart Game?\",\n start: new Date(date.getFullYear(), date.getMonth() + 1, -13),\n end: new Date(date.getFullYear(), date.getMonth() + 1, -12),\n allDay: true,\n extendedProps: {\n calendar: \"ETC\",\n },\n },\n {\n id: 6,\n url: \"\",\n title: \"Meditation\",\n start: new Date(date.getFullYear(), date.getMonth() + 1, -13),\n end: new Date(date.getFullYear(), date.getMonth() + 1, -12),\n allDay: true,\n extendedProps: {\n calendar: \"Personal\",\n },\n },\n {\n id: 7,\n url: \"\",\n title: \"Dinner\",\n start: new Date(date.getFullYear(), date.getMonth() + 1, -13),\n end: new Date(date.getFullYear(), date.getMonth() + 1, -12),\n allDay: true,\n extendedProps: {\n calendar: \"Family\",\n },\n },\n {\n id: 8,\n url: \"\",\n title: \"Product Review\",\n start: new Date(date.getFullYear(), date.getMonth() + 1, -13),\n end: new Date(date.getFullYear(), date.getMonth() + 1, -12),\n allDay: true,\n extendedProps: {\n calendar: \"Business\",\n },\n },\n {\n id: 9,\n url: \"\",\n title: \"Monthly Meeting\",\n start: nextMonth,\n end: nextMonth,\n allDay: true,\n extendedProps: {\n calendar: \"Business\",\n },\n },\n {\n id: 10,\n url: \"\",\n title: \"Monthly Checkup\",\n start: prevMonth,\n end: prevMonth,\n allDay: true,\n extendedProps: {\n calendar: \"Personal\",\n },\n },\n ],\n};\n\n// ------------------------------------------------\n// GET: Return calendar events\n// ------------------------------------------------\nmock.onGet(\"/apps/calendar/events\").reply((config) => {\n // Get requested calendars as Array\n const calendars = config.calendars;\n\n return [\n 200,\n data.events.filter((event) =>\n calendars.includes(event.extendedProps.calendar)\n ),\n ];\n});\n\n// ------------------------------------------------\n// POST: Add new event\n// ------------------------------------------------\nmock.onPost(\"/apps/calendar/add-event\").reply((config) => {\n // Get event from post data\n const { event } = JSON.parse(config.data);\n\n const { length } = data.events;\n let lastIndex = 0;\n if (length) {\n lastIndex = data.events[length - 1].id;\n }\n event.id = lastIndex + 1;\n\n data.events.push(event);\n\n return [201, { event }];\n});\n\n// ------------------------------------------------\n// POST: Update Event\n// ------------------------------------------------\nmock.onPost(\"/apps/calendar/update-event\").reply((config) => {\n const { event: eventData } = JSON.parse(config.data);\n\n // Convert Id to number\n eventData.id = Number(eventData.id);\n\n const event = data.events.find((ev) => ev.id === Number(eventData.id));\n Object.assign(event, eventData);\n\n return [200, { event }];\n});\n\n// ------------------------------------------------\n// DELETE: Remove Event\n// ------------------------------------------------\nmock.onDelete(\"/apps/calendar/remove-event\").reply((config) => {\n // Get event id from URL\n let { id } = config;\n\n // Convert Id to number\n const eventId = Number(id);\n\n const eventIndex = data.events.findIndex((ev) => ev.id === eventId);\n data.events.splice(eventIndex, 1);\n return [200];\n});\n","import mock from \"../mock\";\n\n// ** Utils\nimport { paginateArray } from \"../utils\";\n\nconst data = {\n users: [\n {\n id: 1,\n billing: \"Manual - Credit Card\",\n fullName: \"Galen Slixby\",\n company: \"Yotz PVT LTD\",\n role: \"editor\",\n username: \"gslixby0\",\n country: \"El Salvador\",\n contact: \"(479) 232-9151\",\n email: \"gslixby0@abc.net.au\",\n currentPlan: \"enterprise\",\n status: \"inactive\",\n avatar: \"\",\n avatarColor: \"light-primary\",\n },\n {\n id: 2,\n billing: \"Manual - Paypal\",\n fullName: \"Halsey Redmore\",\n company: \"Skinder PVT LTD\",\n role: \"author\",\n username: \"hredmore1\",\n country: \"Albania\",\n contact: \"(472) 607-9137\",\n email: \"hredmore1@imgur.com\",\n currentPlan: \"team\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/10.png\").default,\n },\n {\n id: 3,\n billing: \"Auto Debit\",\n fullName: \"Marjory Sicely\",\n company: \"Oozz PVT LTD\",\n role: \"maintainer\",\n username: \"msicely2\",\n country: \"Russia\",\n contact: \"(321) 264-4599\",\n email: \"msicely2@who.int\",\n currentPlan: \"enterprise\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n {\n id: 4,\n billing: \"Manual - Credit Card\",\n fullName: \"Cyrill Risby\",\n company: \"Oozz PVT LTD\",\n role: \"maintainer\",\n username: \"crisby3\",\n country: \"China\",\n contact: \"(923) 690-6806\",\n email: \"crisby3@wordpress.com\",\n currentPlan: \"team\",\n status: \"inactive\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n {\n id: 5,\n billing: \"Auto Debit\",\n fullName: \"Maggy Hurran\",\n company: \"Aimbo PVT LTD\",\n role: \"subscriber\",\n username: \"mhurran4\",\n country: \"Pakistan\",\n contact: \"(669) 914-1078\",\n email: \"mhurran4@yahoo.co.jp\",\n currentPlan: \"enterprise\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/10.png\").default,\n },\n {\n id: 6,\n billing: \"Auto Debit\",\n fullName: \"Silvain Halstead\",\n company: \"Jaxbean PVT LTD\",\n role: \"author\",\n username: \"shalstead5\",\n country: \"China\",\n contact: \"(958) 973-3093\",\n email: \"shalstead5@shinystat.com\",\n currentPlan: \"company\",\n status: \"active\",\n avatar: \"\",\n avatarColor: \"light-success\",\n },\n {\n id: 7,\n billing: \"Manual - Paypal\",\n fullName: \"Breena Gallemore\",\n company: \"Jazzy PVT LTD\",\n role: \"subscriber\",\n username: \"bgallemore6\",\n country: \"Canada\",\n contact: \"(825) 977-8152\",\n email: \"bgallemore6@boston.com\",\n currentPlan: \"company\",\n status: \"pending\",\n avatar: \"\",\n avatarColor: \"light-danger\",\n },\n {\n id: 8,\n billing: \"Manual - Cash\",\n fullName: \"Kathryne Liger\",\n company: \"Pixoboo PVT LTD\",\n role: \"author\",\n username: \"kliger7\",\n country: \"France\",\n contact: \"(187) 440-0934\",\n email: \"kliger7@vinaora.com\",\n currentPlan: \"enterprise\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n {\n id: 9,\n billing: \"Auto Debit\",\n fullName: \"Franz Scotfurth\",\n company: \"Tekfly PVT LTD\",\n role: \"subscriber\",\n username: \"fscotfurth8\",\n country: \"China\",\n contact: \"(978) 146-5443\",\n email: \"fscotfurth8@dailymotion.com\",\n currentPlan: \"team\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/2.png\").default,\n },\n {\n id: 10,\n billing: \"Auto Debit\",\n fullName: \"Jillene Bellany\",\n company: \"Gigashots PVT LTD\",\n role: \"maintainer\",\n username: \"jbellany9\",\n country: \"Jamaica\",\n contact: \"(589) 284-6732\",\n email: \"jbellany9@kickstarter.com\",\n currentPlan: \"company\",\n status: \"inactive\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n {\n id: 11,\n billing: \"Manual - Paypal\",\n fullName: \"Jonah Wharlton\",\n company: \"Eare PVT LTD\",\n role: \"subscriber\",\n username: \"jwharltona\",\n country: \"United States\",\n contact: \"(176) 532-6824\",\n email: \"jwharltona@oakley.com\",\n currentPlan: \"team\",\n status: \"inactive\",\n avatar: require(\"@src/assets/images/avatars/4.png\").default,\n },\n {\n id: 12,\n billing: \"Manual - Credit Card\",\n fullName: \"Seth Hallam\",\n company: \"Yakitri PVT LTD\",\n role: \"subscriber\",\n username: \"shallamb\",\n country: \"Peru\",\n contact: \"(234) 464-0600\",\n email: \"shallamb@hugedomains.com\",\n currentPlan: \"team\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/5.png\").default,\n },\n {\n id: 13,\n billing: \"Auto Debit\",\n fullName: \"Yoko Pottie\",\n company: \"Leenti PVT LTD\",\n role: \"subscriber\",\n username: \"ypottiec\",\n country: \"Philippines\",\n contact: \"(907) 284-5083\",\n email: \"ypottiec@privacy.gov.au\",\n currentPlan: \"basic\",\n status: \"inactive\",\n avatar: require(\"@src/assets/images/avatars/7.png\").default,\n },\n {\n id: 14,\n billing: \"Auto Debit\",\n fullName: \"Maximilianus Krause\",\n company: \"Digitube PVT LTD\",\n role: \"author\",\n username: \"mkraused\",\n country: \"Democratic Republic of the Congo\",\n contact: \"(167) 135-7392\",\n email: \"mkraused@stanford.edu\",\n currentPlan: \"team\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n {\n id: 15,\n billing: \"Auto Debit\",\n fullName: \"Zsazsa McCleverty\",\n company: \"Kaymbo PVT LTD\",\n role: \"maintainer\",\n username: \"zmcclevertye\",\n country: \"France\",\n contact: \"(317) 409-6565\",\n email: \"zmcclevertye@soundcloud.com\",\n currentPlan: \"enterprise\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/2.png\").default,\n },\n {\n id: 16,\n billing: \"Auto Debit\",\n fullName: \"Bentlee Emblin\",\n company: \"Yambee PVT LTD\",\n role: \"author\",\n username: \"bemblinf\",\n country: \"Spain\",\n contact: \"(590) 606-1056\",\n email: \"bemblinf@wired.com\",\n currentPlan: \"company\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/6.png\").default,\n },\n {\n id: 17,\n billing: \"Manual - Paypal\",\n fullName: \"Brockie Myles\",\n company: \"Wikivu PVT LTD\",\n role: \"maintainer\",\n username: \"bmylesg\",\n country: \"Poland\",\n contact: \"(553) 225-9905\",\n email: \"bmylesg@amazon.com\",\n currentPlan: \"basic\",\n status: \"active\",\n avatar: \"\",\n avatarColor: \"light-warning\",\n },\n {\n id: 18,\n billing: \"Manual - Cash\",\n fullName: \"Bertha Biner\",\n company: \"Twinte PVT LTD\",\n role: \"editor\",\n username: \"bbinerh\",\n country: \"Yemen\",\n contact: \"(901) 916-9287\",\n email: \"bbinerh@mozilla.com\",\n currentPlan: \"team\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/7.png\").default,\n },\n {\n id: 19,\n billing: \"Manual - Cash\",\n fullName: \"Travus Bruntjen\",\n company: \"Cogidoo PVT LTD\",\n role: \"admin\",\n username: \"tbruntjeni\",\n country: \"France\",\n contact: \"(524) 586-6057\",\n email: \"tbruntjeni@sitemeter.com\",\n currentPlan: \"enterprise\",\n status: \"active\",\n avatar: \"\",\n avatarColor: \"light-info\",\n },\n {\n id: 20,\n billing: \"Auto Debit\",\n fullName: \"Wesley Burland\",\n company: \"Bubblemix PVT LTD\",\n role: \"editor\",\n username: \"wburlandj\",\n country: \"Honduras\",\n contact: \"(569) 683-1292\",\n email: \"wburlandj@uiuc.edu\",\n currentPlan: \"team\",\n status: \"inactive\",\n avatar: require(\"@src/assets/images/avatars/6.png\").default,\n },\n {\n id: 21,\n billing: \"Auto Debit\",\n fullName: \"Selina Kyle\",\n company: \"Wayne Enterprises\",\n role: \"admin\",\n username: \"catwomen1940\",\n country: \"USA\",\n contact: \"(829) 537-0057\",\n email: \"irena.dubrovna@wayne.com\",\n currentPlan: \"team\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n {\n id: 22,\n billing: \"Auto Debit\",\n fullName: \"Jameson Lyster\",\n company: \"Quaxo PVT LTD\",\n role: \"editor\",\n username: \"jlysterl\",\n country: \"Ukraine\",\n contact: \"(593) 624-0222\",\n email: \"jlysterl@guardian.co.uk\",\n currentPlan: \"company\",\n status: \"inactive\",\n avatar: require(\"@src/assets/images/avatars/8.png\").default,\n },\n {\n id: 23,\n billing: \"Manual - Paypal\",\n fullName: \"Kare Skitterel\",\n company: \"Ainyx PVT LTD\",\n role: \"maintainer\",\n username: \"kskitterelm\",\n country: \"Poland\",\n contact: \"(254) 845-4107\",\n email: \"kskitterelm@washingtonpost.com\",\n currentPlan: \"basic\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/3.png\").default,\n },\n {\n id: 24,\n billing: \"Manual - Paypal\",\n fullName: \"Cleavland Hatherleigh\",\n company: \"Flipopia PVT LTD\",\n role: \"admin\",\n username: \"chatherleighn\",\n country: \"Brazil\",\n contact: \"(700) 783-7498\",\n email: \"chatherleighn@washington.edu\",\n currentPlan: \"team\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/2.png\").default,\n },\n {\n id: 25,\n billing: \"Manual - Credit Card\",\n fullName: \"Adeline Micco\",\n company: \"Topicware PVT LTD\",\n role: \"admin\",\n username: \"amiccoo\",\n country: \"France\",\n contact: \"(227) 598-1841\",\n email: \"amiccoo@whitehouse.gov\",\n currentPlan: \"enterprise\",\n status: \"pending\",\n avatar: \"\",\n avatarColor: \"light-primary\",\n },\n {\n id: 26,\n billing: \"Manual - Cash\",\n fullName: \"Hugh Hasson\",\n company: \"Skinix PVT LTD\",\n role: \"admin\",\n username: \"hhassonp\",\n country: \"China\",\n contact: \"(582) 516-1324\",\n email: \"hhassonp@bizjournals.com\",\n currentPlan: \"basic\",\n status: \"inactive\",\n avatar: require(\"@src/assets/images/avatars/4.png\").default,\n },\n {\n id: 27,\n billing: \"Manual - Cash\",\n fullName: \"Germain Jacombs\",\n company: \"Youopia PVT LTD\",\n role: \"editor\",\n username: \"gjacombsq\",\n country: \"Zambia\",\n contact: \"(137) 467-5393\",\n email: \"gjacombsq@jigsy.com\",\n currentPlan: \"enterprise\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/10.png\").default,\n },\n {\n id: 28,\n billing: \"Manual - Credit Card\",\n fullName: \"Bree Kilday\",\n company: \"Jetpulse PVT LTD\",\n role: \"maintainer\",\n username: \"bkildayr\",\n country: \"Portugal\",\n contact: \"(412) 476-0854\",\n email: \"bkildayr@mashable.com\",\n currentPlan: \"team\",\n status: \"active\",\n avatar: \"\",\n avatarColor: \"light-success\",\n },\n {\n id: 29,\n billing: \"Auto Debit\",\n fullName: \"Candice Pinyon\",\n company: \"Kare PVT LTD\",\n role: \"maintainer\",\n username: \"cpinyons\",\n country: \"Sweden\",\n contact: \"(170) 683-1520\",\n email: \"cpinyons@behance.net\",\n currentPlan: \"team\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/7.png\").default,\n },\n {\n id: 30,\n billing: \"Manual - Credit Card\",\n fullName: \"Isabel Mallindine\",\n company: \"Voomm PVT LTD\",\n role: \"subscriber\",\n username: \"imallindinet\",\n country: \"Slovenia\",\n contact: \"(332) 803-1983\",\n email: \"imallindinet@shinystat.com\",\n currentPlan: \"team\",\n status: \"pending\",\n avatar: \"\",\n avatarColor: \"light-warning\",\n },\n {\n id: 31,\n billing: \"Manual - Cash\",\n fullName: \"Gwendolyn Meineken\",\n company: \"Oyondu PVT LTD\",\n role: \"admin\",\n username: \"gmeinekenu\",\n country: \"Moldova\",\n contact: \"(551) 379-7460\",\n email: \"gmeinekenu@hc360.com\",\n currentPlan: \"basic\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n {\n id: 32,\n billing: \"Manual - Paypal\",\n fullName: \"Rafaellle Snowball\",\n company: \"Fivespan PVT LTD\",\n role: \"editor\",\n username: \"rsnowballv\",\n country: \"Philippines\",\n contact: \"(974) 829-0911\",\n email: \"rsnowballv@indiegogo.com\",\n currentPlan: \"basic\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/5.png\").default,\n },\n {\n id: 33,\n billing: \"Auto Debit\",\n fullName: \"Rochette Emer\",\n company: \"Thoughtworks PVT LTD\",\n role: \"admin\",\n username: \"remerw\",\n country: \"North Korea\",\n contact: \"(841) 889-3339\",\n email: \"remerw@blogtalkradio.com\",\n currentPlan: \"basic\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/8.png\").default,\n },\n {\n id: 34,\n billing: \"Manual - Cash\",\n fullName: \"Ophelie Fibbens\",\n company: \"Jaxbean PVT LTD\",\n role: \"subscriber\",\n username: \"ofibbensx\",\n country: \"Indonesia\",\n contact: \"(764) 885-7351\",\n email: \"ofibbensx@booking.com\",\n currentPlan: \"company\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/4.png\").default,\n },\n {\n id: 35,\n billing: \"Manual - Paypal\",\n fullName: \"Stephen MacGilfoyle\",\n company: \"Browseblab PVT LTD\",\n role: \"maintainer\",\n username: \"smacgilfoyley\",\n country: \"Japan\",\n contact: \"(350) 589-8520\",\n email: \"smacgilfoyley@bigcartel.com\",\n currentPlan: \"company\",\n status: \"pending\",\n avatar: \"\",\n avatarColor: \"light-danger\",\n },\n {\n id: 36,\n billing: \"Manual - Paypal\",\n fullName: \"Bradan Rosebotham\",\n company: \"Agivu PVT LTD\",\n role: \"subscriber\",\n username: \"brosebothamz\",\n country: \"Belarus\",\n contact: \"(882) 933-2180\",\n email: \"brosebothamz@tripadvisor.com\",\n currentPlan: \"team\",\n status: \"inactive\",\n avatar: \"\",\n avatarColor: \"light-info\",\n },\n {\n id: 37,\n billing: \"Manual - Cash\",\n fullName: \"Skip Hebblethwaite\",\n company: \"Katz PVT LTD\",\n role: \"admin\",\n username: \"shebblethwaite10\",\n country: \"Canada\",\n contact: \"(610) 343-1024\",\n email: \"shebblethwaite10@arizona.edu\",\n currentPlan: \"company\",\n status: \"inactive\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n {\n id: 38,\n billing: \"Manual - Credit Card\",\n fullName: \"Moritz Piccard\",\n company: \"Twitternation PVT LTD\",\n role: \"maintainer\",\n username: \"mpiccard11\",\n country: \"Croatia\",\n contact: \"(365) 277-2986\",\n email: \"mpiccard11@vimeo.com\",\n currentPlan: \"enterprise\",\n status: \"inactive\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n {\n id: 39,\n billing: \"Manual - Cash\",\n fullName: \"Tyne Widmore\",\n company: \"Yombu PVT LTD\",\n role: \"subscriber\",\n username: \"twidmore12\",\n country: \"Finland\",\n contact: \"(531) 731-0928\",\n email: \"twidmore12@bravesites.com\",\n currentPlan: \"team\",\n status: \"pending\",\n avatar: \"\",\n avatarColor: \"light-primary\",\n },\n {\n id: 40,\n billing: \"Manual - Cash\",\n fullName: \"Florenza Desporte\",\n company: \"Kamba PVT LTD\",\n role: \"author\",\n username: \"fdesporte13\",\n country: \"Ukraine\",\n contact: \"(312) 104-2638\",\n email: \"fdesporte13@omniture.com\",\n currentPlan: \"company\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/6.png\").default,\n },\n {\n id: 41,\n billing: \"Manual - Credit Card\",\n fullName: \"Edwina Baldetti\",\n company: \"Dazzlesphere PVT LTD\",\n role: \"maintainer\",\n username: \"ebaldetti14\",\n country: \"Haiti\",\n contact: \"(315) 329-3578\",\n email: \"ebaldetti14@theguardian.com\",\n currentPlan: \"team\",\n status: \"pending\",\n avatar: \"\",\n avatarColor: \"light-success\",\n },\n {\n id: 42,\n billing: \"Manual - Cash\",\n fullName: \"Benedetto Rossiter\",\n company: \"Mybuzz PVT LTD\",\n role: \"editor\",\n username: \"brossiter15\",\n country: \"Indonesia\",\n contact: \"(323) 175-6741\",\n email: \"brossiter15@craigslist.org\",\n currentPlan: \"team\",\n status: \"inactive\",\n avatar: \"\",\n avatarColor: \"light-danger\",\n },\n {\n id: 43,\n billing: \"Manual - Credit Card\",\n fullName: \"Micaela McNirlan\",\n company: \"Tambee PVT LTD\",\n role: \"admin\",\n username: \"mmcnirlan16\",\n country: \"Indonesia\",\n contact: \"(242) 952-0916\",\n email: \"mmcnirlan16@hc360.com\",\n currentPlan: \"basic\",\n status: \"inactive\",\n avatar: \"\",\n avatarColor: \"light-warning\",\n },\n {\n id: 44,\n billing: \"Manual - Paypal\",\n fullName: \"Vladamir Koschek\",\n company: \"Centimia PVT LTD\",\n role: \"author\",\n username: \"vkoschek17\",\n country: \"Guatemala\",\n contact: \"(531) 758-8335\",\n email: \"vkoschek17@abc.net.au\",\n currentPlan: \"team\",\n status: \"active\",\n avatar: \"\",\n avatarColor: \"light-info\",\n },\n {\n id: 45,\n billing: \"Manual - Paypal\",\n fullName: \"Corrie Perot\",\n company: \"Flipopia PVT LTD\",\n role: \"subscriber\",\n username: \"cperot18\",\n country: \"China\",\n contact: \"(659) 385-6808\",\n email: \"cperot18@goo.ne.jp\",\n currentPlan: \"team\",\n status: \"pending\",\n avatar: require(\"@src/assets/images/avatars/3.png\").default,\n },\n {\n id: 46,\n billing: \"Auto Debit\",\n fullName: \"Saunder Offner\",\n company: \"Skalith PVT LTD\",\n role: \"maintainer\",\n username: \"soffner19\",\n country: \"Poland\",\n contact: \"(200) 586-2264\",\n email: \"soffner19@mac.com\",\n currentPlan: \"enterprise\",\n status: \"pending\",\n avatar: \"\",\n avatarColor: \"light-primary\",\n },\n {\n id: 47,\n billing: \"Manual - Paypal\",\n fullName: \"Karena Courtliff\",\n company: \"Feedfire PVT LTD\",\n role: \"admin\",\n username: \"kcourtliff1a\",\n country: \"China\",\n contact: \"(478) 199-0020\",\n email: \"kcourtliff1a@bbc.co.uk\",\n currentPlan: \"basic\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/1.png\").default,\n },\n {\n id: 48,\n billing: \"Manual - Paypal\",\n fullName: \"Onfre Wind\",\n company: \"Thoughtmix PVT LTD\",\n role: \"admin\",\n username: \"owind1b\",\n country: \"Ukraine\",\n contact: \"(344) 262-7270\",\n email: \"owind1b@yandex.ru\",\n currentPlan: \"basic\",\n status: \"pending\",\n avatar: \"\",\n avatarColor: \"light-success\",\n },\n {\n id: 49,\n billing: \"Manual - Cash\",\n fullName: \"Paulie Durber\",\n company: \"Babbleblab PVT LTD\",\n role: \"subscriber\",\n username: \"pdurber1c\",\n country: \"Sweden\",\n contact: \"(694) 676-1275\",\n email: \"pdurber1c@gov.uk\",\n currentPlan: \"team\",\n status: \"inactive\",\n avatar: \"\",\n avatarColor: \"light-danger\",\n },\n {\n id: 50,\n billing: \"Auto Debit\",\n fullName: \"Beverlie Krabbe\",\n company: \"Kaymbo PVT LTD\",\n role: \"editor\",\n username: \"bkrabbe1d\",\n country: \"China\",\n contact: \"(397) 294-5153\",\n email: \"bkrabbe1d@home.pl\",\n currentPlan: \"company\",\n status: \"active\",\n avatar: require(\"@src/assets/images/avatars/9.png\").default,\n },\n ],\n};\n\n// GET ALL DATA\nmock.onGet(\"/api/users/list/all-data\").reply(200, data.users);\n\n// POST: Add new user\nmock.onPost(\"/apps/users/add-user\").reply((config) => {\n // Get event from post data\n const user = JSON.parse(config.data);\n const highestValue = data.users.reduce((a, b) => (a.id > b.id ? a : b)).id;\n\n user.id = highestValue + 1;\n\n data.users.push(user);\n\n return [201, { user }];\n});\n\n// GET Updated DATA\nmock.onGet(\"/api/users/list/data\").reply((config) => {\n const {\n q = \"\",\n page = 1,\n role = null,\n perPage = 10,\n sort = \"asc\",\n status = null,\n currentPlan = null,\n sortColumn = \"fullName\",\n } = config;\n\n /* eslint-disable */\n const queryLowered = q.toLowerCase();\n\n const dataAsc = data.users.sort((a, b) =>\n a[sortColumn] < b[sortColumn] ? -1 : 1\n );\n\n const dataToFilter = sort === \"asc\" ? dataAsc : dataAsc.reverse();\n\n const filteredData = dataToFilter.filter(\n (user) =>\n (user.email.toLowerCase().includes(queryLowered) ||\n user.fullName.toLowerCase().includes(queryLowered) ||\n user.billing.toLowerCase().includes(queryLowered)) &&\n user.role === (role || user.role) &&\n user.currentPlan === (currentPlan || user.currentPlan) &&\n user.status === (status || user.status)\n );\n /* eslint-enable */\n\n return [\n 200,\n {\n total: filteredData.length,\n users: paginateArray(filteredData, perPage, page),\n },\n ];\n});\n\n// GET USER\nmock.onGet(\"/api/users/user\").reply((config) => {\n const { id } = config;\n const user = data.users.find((i) => i.id === id);\n return [200, { user }];\n});\n\n// DELETE: Deletes User\nmock.onDelete(\"/apps/users/delete\").reply((config) => {\n // Get user id from URL\n let userId = config.id;\n\n // Convert Id to number\n userId = Number(userId);\n\n const userIndex = data.users.findIndex((t) => t.id === userId);\n data.users.splice(userIndex, 1);\n\n return [200];\n});\n","import mock from \"../mock\";\nconst data = {\n profileData: {\n header: {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-2.jpg\")\n .default,\n username: \"Kitty Allanson\",\n designation: \"UI/UX Designer\",\n coverImg: require(\"@src/assets/images/profile/user-uploads/timeline.jpg\")\n .default,\n },\n userAbout: {\n about:\n \"Tart I love sugar plum I love oat cake. Sweet ⭐️ roll caramels I love jujubes. Topping cake wafer.\",\n joined: \"November 15, 2015\",\n lives: \"New York, USA\",\n email: \"bucketful@fiendhead.org\",\n website: \"www.pixinvent.com\",\n },\n suggestedPages: [\n {\n avatar: require(\"@src/assets/images/avatars/12-small.png\").default,\n username: \"Peter Reed\",\n subtitle: \"Company\",\n favorite: false,\n },\n {\n avatar: require(\"@src/assets/images/avatars/1-small.png\").default,\n username: \"Harriett Adkins\",\n subtitle: \"Company\",\n favorite: false,\n },\n {\n avatar: require(\"@src/assets/images/avatars/10-small.png\").default,\n username: \"Juan Weaver\",\n subtitle: \"Company\",\n favorite: false,\n },\n {\n avatar: require(\"@src/assets/images/avatars/3-small.png\").default,\n username: \"Claudia Chandler\",\n subtitle: \"Company\",\n favorite: false,\n },\n {\n avatar: require(\"@src/assets/images/avatars/5-small.png\").default,\n username: \"Earl Briggs\",\n subtitle: \"Company\",\n favorite: true,\n },\n {\n avatar: require(\"@src/assets/images/avatars/6-small.png\").default,\n username: \"Jonathan Lyons\",\n subtitle: \"Beauty Store\",\n favorite: false,\n },\n ],\n twitterFeeds: [\n {\n imgUrl: require(\"@src/assets/images/avatars/5-small.png\").default,\n title: \"Gertrude Stevens\",\n id: \"tiana59 \",\n tags: \"#design #fasion\",\n desc: \"I love cookie chupa chups sweet tart apple pie ⭐️ chocolate bar.\",\n favorite: false,\n },\n {\n imgUrl: require(\"@src/assets/images/avatars/12-small.png\").default,\n title: \"Lura Jones\",\n id: \"tiana59 \",\n tags: \"#vuejs #code #coffeez\",\n desc: \"Halvah I love powder jelly I love cheesecake cotton candy. 😍\",\n favorite: true,\n },\n {\n imgUrl: require(\"@src/assets/images/avatars/1-small.png\").default,\n title: \"Norman Gross\",\n id: \"tiana59 \",\n tags: \"#sketch #uiux #figma\",\n desc: \"Candy jelly beans powder brownie biscuit. Jelly marzipan oat cake cake.\",\n favorite: false,\n },\n ],\n post: [\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-18.jpg\")\n .default,\n username: \"Leeanna Alvord\",\n postTime: \"12 Dec 2018 at 1:16 AM\",\n postText:\n \"Wonderful Machine· A well-written bio allows viewers to get to know a photographer beyond the work. This can make the difference when presenting to clients who are looking for the perfect fit.\",\n postImg: require(\"@src/assets/images/profile/post-media/2.jpg\").default,\n likes: \"1.25k\",\n youLiked: true,\n comments: \"1.25k\",\n share: \"1.25k\",\n likedUsers: [\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-1.jpg\")\n .default,\n username: \"Trine Lynes\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-2.jpg\")\n .default,\n username: \"Lilian Nenes\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-3.jpg\")\n .default,\n username: \"Alberto Glotzbach\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n username: \"George Nordic\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-4.jpg\")\n .default,\n username: \"Vinnie Mostowy\",\n },\n ],\n likedCount: 140,\n detailedComments: [\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-6.jpg\")\n .default,\n username: \"Kitty Allanson\",\n comment:\n \"Easy & smart fuzzy search🕵🏻 functionality which enables users to search quickly.\",\n commentsLikes: 34,\n youLiked: false,\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-8.jpg\")\n .default,\n username: \"Jackey Potter\",\n comment:\n \"Unlimited color🖌 options allows you to set your application color as per your branding 🤪.\",\n commentsLikes: 61,\n youLiked: true,\n },\n ],\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-22.jpg\")\n .default,\n username: \"Rosa Walters\",\n postTime: \"11 Dec 2019 at 1:16 AM\",\n postText:\n \"Wonderful Machine· A well-written bio allows viewers to get to know a photographer beyond the work. This can make the difference when presenting to clients who are looking for the perfect fit.\",\n postImg: require(\"@src/assets/images/profile/post-media/25.jpg\")\n .default,\n likes: \"1.25k\",\n youLiked: true,\n comments: \"1.25k\",\n share: \"1.25k\",\n likedUsers: [\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-1.jpg\")\n .default,\n username: \"Kori Scargle\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-2.jpg\")\n .default,\n username: \"Florinda Mollison\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-3.jpg\")\n .default,\n username: \"Beltran Endley\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n username: \"Kara Gerred\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-4.jpg\")\n .default,\n username: \"Sophey Bru\",\n },\n ],\n likedCount: 271,\n detailedComments: [\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-3.jpg\")\n .default,\n username: \"Kitty Allanson\",\n comment:\n \"Easy & smart fuzzy search🕵🏻 functionality which enables users to search quickly.\",\n commentsLikes: 34,\n youLiked: false,\n },\n ],\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-15.jpg\")\n .default,\n username: \"Charles Watson\",\n postTime: \"12 Dec 2019 at 1:16 AM\",\n postText:\n \"Wonderful Machine· A well-written bio allows viewers to get to know a photographer beyond the work. This can make the difference when presenting to clients who are looking for the perfect fit.\",\n postVid: \"https://www.youtube.com/embed/6stlCkUDG_s\",\n likes: \"1.25k\",\n youLiked: true,\n comments: \"1.25k\",\n share: \"1.25k\",\n likedUsers: [\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-1.jpg\")\n .default,\n username: \"Dehlia Bolderson\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-2.jpg\")\n .default,\n username: \"De Lamy\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-3.jpg\")\n .default,\n username: \"Vallie Kingsley\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n username: \"Nadia Armell\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-4.jpg\")\n .default,\n username: \"Romonda Aseef\",\n },\n ],\n likedCount: 264,\n detailedComments: [\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-3.jpg\")\n .default,\n username: \"Kitty Allanson\",\n comment:\n \"Easy & smart fuzzy search🕵🏻 functionality which enables users to search quickly.\",\n commentsLikes: 34,\n youLiked: false,\n },\n ],\n },\n ],\n latestPhotos: [\n {\n img: require(\"@src/assets/images/profile/user-uploads/user-13.jpg\")\n .default,\n },\n {\n img: require(\"@src/assets/images/profile/user-uploads/user-02.jpg\")\n .default,\n },\n {\n img: require(\"@src/assets/images/profile/user-uploads/user-03.jpg\")\n .default,\n },\n {\n img: require(\"@src/assets/images/profile/user-uploads/user-04.jpg\")\n .default,\n },\n {\n img: require(\"@src/assets/images/profile/user-uploads/user-05.jpg\")\n .default,\n },\n {\n img: require(\"@src/assets/images/profile/user-uploads/user-06.jpg\")\n .default,\n },\n {\n img: require(\"@src/assets/images/profile/user-uploads/user-07.jpg\")\n .default,\n },\n {\n img: require(\"@src/assets/images/profile/user-uploads/user-08.jpg\")\n .default,\n },\n {\n img: require(\"@src/assets/images/profile/user-uploads/user-09.jpg\")\n .default,\n },\n ],\n suggestions: [\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n name: \"Peter Reed\",\n mutualFriend: \"6 Mutual Friends\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-6.jpg\")\n .default,\n name: \"Harriett Adkins\",\n mutualFriend: \"3 Mutual Friends\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n name: \"Juan Weaver\",\n mutualFriend: \"1 Mutual Friends\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-8.jpg\")\n .default,\n name: \"Claudia Chandler\",\n mutualFriend: \"16 Mutual Friends\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-1.jpg\")\n .default,\n name: \"Earl Briggs\",\n mutualFriend: \"4 Mutual Friends\",\n },\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-10.jpg\")\n .default,\n name: \"Jonathan Lyons\",\n mutualFriend: \"25 Mutual Friends\",\n },\n ],\n polls: [\n {\n name: \"RDJ\",\n result: \"82%\",\n votedUser: [\n {\n img: require(\"@src/assets/images/portrait/small/avatar-s-12.jpg\")\n .default,\n username: \"Tonia Seabold\",\n },\n {\n img: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n username: \"Carissa Dolle\",\n },\n {\n img: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n username: \"Kelle Herrick\",\n },\n {\n img: require(\"@src/assets/images/portrait/small/avatar-s-10.jpg\")\n .default,\n username: \"Len Bregantini\",\n },\n {\n img: require(\"@src/assets/images/portrait/small/avatar-s-11.jpg\")\n .default,\n username: \"John Doe\",\n },\n ],\n },\n {\n name: \"Chris Hemsworth\",\n result: \"67%\",\n votedUser: [\n {\n img: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n username: \"Diana Prince\",\n },\n {\n img: require(\"@src/assets/images/portrait/small/avatar-s-1.jpg\")\n .default,\n username: \"Lois Lane\",\n },\n {\n img: require(\"@src/assets/images/portrait/small/avatar-s-8.jpg\")\n .default,\n username: \"Bruce Wayne\",\n },\n ],\n },\n ],\n },\n};\n\nmock.onGet(\"/profile/data\").reply(() => [200, data.profileData]);\n","import mock from \"../mock\";\n/* eslint-disable */\n// ** Utils\nimport { paginateArray, sortCompare, randomDate, getRandomInt } from \"../utils\";\n\nconst nextDay = new Date(new Date().getTime() + 24 * 60 * 60 * 1000);\nconst nextWeek = new Date(nextDay.getTime() + 7 * 24 * 60 * 60 * 1000);\n\nconst data = {\n products: [\n {\n id: 1,\n name: \"VicTsing Wireless Mouse,\",\n slug: \"3-year-unlimited-cloud-storage-service-activation-card-other-1\",\n description:\n \"After thousands of samples of palm data, we designed this ergonomic mouse. The laptop mouse has a streamlined arc and thumb rest to help reduce the stress caused by prolonged use of the laptop mouse.\",\n brand: \"VicTsing\",\n price: 10.99,\n image: require(\"@src/assets/images/pages/eCommerce/27.png\").default,\n hasFreeShipping: true,\n rating: 2,\n },\n {\n id: 2,\n name: \"Bose Frames Tenor - Rectangular Polarized, Bluetooth Audio Sunglasses\",\n slug: \"360fly-panoramic-360-hd-video-camera-black-2\",\n description:\n \"Redesigned for luxury — Thoughtfully refined and strikingly elegant, the latest Bose sunglasses blend enhanced features and designs for an elevated way to listen\",\n brand: \"Bose\",\n price: 249.0,\n image: require(\"@src/assets/images/pages/eCommerce/26.png\").default,\n hasFreeShipping: false,\n rating: 5,\n },\n {\n id: 3,\n name: \"Willful Smart Watch for Men Women 2020,\",\n slug: \"3-dr-backpack-for-solo-black-3\",\n description:\n \"Are you looking for a smart watch, which can not only easily keep tracking of your steps, calories, heart rate and sleep quality, but also keep you informed of incoming calls.\",\n brand: \"Willful\",\n price: 29.99,\n image: require(\"@src/assets/images/pages/eCommerce/25.png\").default,\n hasFreeShipping: false,\n rating: 5,\n },\n {\n id: 4,\n name: \"Ronyes Unisex College Bag Bookbags for Women\",\n slug: \"3-dr-propellers-for-3-dr-solo-drones-2-pack-black-4\",\n description:\n \"Made of high quality water-resistant material; padded and adjustable shoulder straps; external USB with built-in charging cable offers a convenient charging\",\n brand: \"Ronyes\",\n price: 23.99,\n image: require(\"@src/assets/images/pages/eCommerce/24.png\").default,\n hasFreeShipping: false,\n rating: 2,\n },\n {\n id: 5,\n name: \"Toshiba Canvio Advance 2TB Portable External Hard Drive\",\n slug: \"3-dr-solo-gimbal-black-5\",\n description:\n \"Up to 3TB of storage capacity to store your growing files and content\",\n brand: \"Toshiba\",\n price: 69.99,\n image: require(\"@src/assets/images/pages/eCommerce/23.png\").default,\n hasFreeShipping: false,\n rating: 2,\n },\n {\n id: 6,\n name: \"Tile Pro - High Performance Bluetooth Tracker\",\n slug: \"3-dr-solo-smart-rechargeable-battery-black-6\",\n description:\n \"FIND KEYS, BAGS & MORE -- Pro is our high-performance finder ideal for keys, backpacks, luggage or any other items you want to keep track of. The easy-to-use finder and free app work with iOS and Android.\",\n brand: \"Tile\",\n price: 29.99,\n image: require(\"@src/assets/images/pages/eCommerce/22.png\").default,\n hasFreeShipping: false,\n rating: 4,\n },\n {\n id: 7,\n name: \"Bugani M90 Portable Bluetooth Speaker\",\n slug: \"3-m-eureka-rr-pet-micro-allergen-vacuum-bag-for-select-eureka-vacuums-3-pack-7\",\n description:\n \"Bluetooth Speakers-The M90 Bluetooth speaker uses the latest Bluetooth 5.0 technology and the latest Bluetooth ATS chip, Connecting over Bluetooth in seconds to iPhone, iPad, Smart-phones, Tablets, Windows, and other Bluetooth devices.\",\n brand: \"Bugani\",\n price: 56.0,\n image: require(\"@src/assets/images/pages/eCommerce/21.png\").default,\n hasFreeShipping: false,\n rating: 3,\n },\n {\n id: 8,\n name: \"PlayStation 4 Console\",\n slug: \"3-m-filtrete-bissell-replacement-belt-8\",\n description:\n \"All the greatest, games, TV, music and more. Connect with your friends to broadcast and celebrate your epic moments at the press of the Share button to Twitch, YouTube, Facebook and Twitter.\",\n brand: \"Sony\",\n price: 339.95,\n image: require(\"@src/assets/images/pages/eCommerce/20.png\").default,\n hasFreeShipping: false,\n rating: 1,\n },\n {\n id: 9,\n name: \"Giotto 32oz Leakproof BPA Free Drinking Water\",\n slug: \"3-m-filtrete-devil-tattoo-vacuum-bag-3-pack-9\",\n description:\n \"With unique inspirational quote and time markers on it,this water bottle is great for measuring your daily intake of water,reminding you stay hydrated and drink enough water throughout the day.A must have for any fitness goals including weight loss,appetite control and overall health.\",\n brand: \"3M\",\n price: 16.99,\n image: require(\"@src/assets/images/pages/eCommerce/19.png\").default,\n hasFreeShipping: false,\n rating: 5,\n },\n {\n id: 10,\n name: \"Oculus Quest All-in-one VR\",\n slug: \"3-m-filtrete-eureka-r-replacement-belt-for-select-eureka-vacuums-10\",\n description:\n \"All-in-one VR: No PC. No wires. No limits. Oculus quest is an all-in-one gaming system built for virtual reality. Now you can play almost anywhere with just a VR headset and controllers. Oculus touch controllers: arm yourself with the award-winning Oculus touch controllers. Your slashes, throws and grab appear in VR with intuitive, realistic Precision, transporting your hands and gestures right into the game\",\n brand: \"Oculus\",\n price: 645.0,\n image: require(\"@src/assets/images/pages/eCommerce/18.png\").default,\n hasFreeShipping: false,\n rating: 1,\n },\n {\n id: 11,\n name: \"Handbags for Women Large Designer bag\",\n slug: \"3-m-filtrete-eureka-u-replacement-belt-11\",\n description:\n \"Classic Hobo Purse: Top zipper closure, with 2 side zipper pockets design and elegant tassels decoration, fashionable and practical handbags for women, perfect for shopping, dating, travel and business\",\n brand: \"Hobo\",\n price: 39.99,\n image: require(\"@src/assets/images/pages/eCommerce/17.png\").default,\n hasFreeShipping: false,\n rating: 3,\n },\n {\n id: 12,\n name: \"Adidas Mens Tech Response Shoes\",\n slug: \"3-m-filtrete-hoover-a-micro-allergen-vacuum-bag-12\",\n description:\n \"Comfort + performance. Designed with materials that are durable, lightweight and extremely comfortable. Core performance delivers the perfect mix of fit, style and all-around performance.\",\n brand: \"Adidas\",\n price: 54.59,\n image: require(\"@src/assets/images/pages/eCommerce/16.png\").default,\n hasFreeShipping: false,\n rating: 5,\n },\n {\n id: 13,\n name: \"Laptop Bag\",\n slug: \"3-m-filtrete-hoover-w2-micro-allergen-vacuum-bag-3-pack-13\",\n description:\n \"TSA FRIENDLY- A separate DIGI SMART compartment can hold 15.6 inch Laptop as well as 15 inch, 14 inch Macbook, 12.9 inch iPad, and tech accessories like charger for quick TSA checkpoint when traveling\",\n brand: \"TAS\",\n price: 29.99,\n image: require(\"@src/assets/images/pages/eCommerce/15.png\").default,\n hasFreeShipping: false,\n rating: 5,\n },\n {\n id: 14,\n name: \"Wireless Charger 5W Max\",\n slug: \"3-m-filtrete-hoover-windtunnel-replacement-belt-14\",\n description:\n \"Charge with case: transmits charging power directly through protective cases. Rubber/plastic/TPU cases under 5 mm thickness . Do not use any magnetic and metal attachments or cards, or it will prevent charging.\",\n brand: \"3M\",\n price: 10.83,\n image: require(\"@src/assets/images/pages/eCommerce/14.png\").default,\n hasFreeShipping: false,\n rating: 3,\n },\n {\n id: 15,\n name: \"Vankyo leisure 3 mini projector\",\n slug: \"3-m-filtrete-vacuum-belt-for-select-hoover-t-series-upright-vacuums-15\",\n description:\n \"SUPERIOR VIEWING EXPERIENCE: Supporting 1920x1080 resolution, VANKYO Leisure 3 projector is powered by MStar Advanced Color Engine, which is ideal for home entertainment. 2020 upgraded LED lighting provides a superior viewing experience for you.\",\n brand: \"Vankyo Store\",\n price: 99.99,\n image: require(\"@src/assets/images/pages/eCommerce/13.png\").default,\n hasFreeShipping: false,\n rating: 2,\n },\n {\n id: 16,\n name: \"New Apple iPad Pro\",\n slug: \"3-m-hoover-y-z-pet-micro-allergen-vacuum-bag-for-select-hoover-vacuums-3-pack-16\",\n description:\n \"Up to 10 hours of surfing the web on Wi‑Fi, watching video, or listening to music. Up to 9 hours of surfing the web using cellular data network, Compatible with Smart Keyboard Folio and Bluetooth keyboards\",\n brand: \"Apple\",\n price: 799.99,\n image: require(\"@src/assets/images/pages/eCommerce/12.png\").default,\n hasFreeShipping: false,\n rating: 3,\n },\n {\n id: 17,\n name: \"Nike Air Max\",\n slug: \"72-9301-speaker-wire-harness-adapter-for-most-plymouth-dodge-and-mitsubishi-vehicles-multi-17\",\n description:\n \"With a bold application of colorblocking inspired by modern art styles, the Nike Air Max 270 React sneaker is constructed with layers of lightweight material to achieve its artful look and comfortable feel.\",\n brand: \"Nike\",\n price: 98.95,\n image: require(\"@src/assets/images/pages/eCommerce/11.png\").default,\n hasFreeShipping: false,\n rating: 1,\n },\n {\n id: 18,\n name: \"Logitech K380 Wireless Keyboard\",\n slug: \"acer-11-6-chromebook-intel-celeron-2-gb-memory-16-gb-e-mmc-flash-memory-moonstone-white-18\",\n description:\n \"Logitech K380 Bluetooth Wireless Keyboard gives you the comfort and convenience of desktop typing on your smartphone, and tablet. It is a wireless keyboard that connects to all Bluetooth wireless devices that support external keyboards. Take this compact, lightweight, Bluetooth keyboard anywhere in your home. Type wherever you like, on any compatible computer, phone or tablet.\",\n brand: \"Logitech\",\n price: 81.99,\n image: require(\"@src/assets/images/pages/eCommerce/10.png\").default,\n hasFreeShipping: false,\n rating: 4,\n },\n {\n id: 19,\n name: \"OnePlus 7 Pro \",\n slug: \"one-plus-7-pro-19\",\n brand: \"Philips\",\n price: 14.99,\n image: require(\"@src/assets/images/pages/eCommerce/9.png\").default,\n hasFreeShipping: false,\n rating: 4,\n description: `The OnePlus 7 Pro features a brand new design, with a glass back and front and curved sides. The phone feels\n very premium but’s it’s also very heavy. The Nebula Blue variant looks slick but it’s quite slippery, which\n makes single-handed use a real challenge. It has a massive 6.67-inch ‘Fluid AMOLED’ display with a QHD+\n resolution, 90Hz refresh rate and support for HDR 10+ content. The display produces vivid colours, deep blacks\n and has good viewing angles.`,\n },\n {\n id: 20,\n name: \"Sony 4K Ultra HD LED TV \",\n slug: \"sony-4-k-ultra-hd-led-tv-20\",\n brand: \"Apple\",\n price: 7999.99,\n image: require(\"@src/assets/images/pages/eCommerce/8.png\").default,\n hasFreeShipping: false,\n rating: 5,\n description: `Sony 4K Ultra HD LED TV has 4K HDR Support. The TV provides clear visuals and provides distinct sound quality\n and an immersive experience. This TV has Yes HDMI ports & Yes USB ports. Connectivity options included are HDMI.\n You can connect various gadgets such as your laptop using the HDMI port. The TV comes with a 1 Year warranty.`,\n },\n {\n id: 21,\n name: \"Google - Google Home - White/Slate fabric\",\n slug: \"google-google-home-white-slate-fabric-21\",\n brand: \"Google\",\n price: 129.29,\n image: require(\"@src/assets/images/pages/eCommerce/7.png\").default,\n hasFreeShipping: true,\n rating: 4,\n description: `Simplify your everyday life with the Google Home, a voice-activated speaker powered by the Google Assistant. Use\n voice commands to enjoy music, get answers from Google and manage everyday tasks. Google Home is compatible with\n Android and iOS operating systems, and can control compatible smart devices such as Chromecast or Nest.`,\n },\n {\n id: 22,\n name: \"Switch Pro Controller\",\n slug: \"switch-pro-controller-22\",\n brand: \"Sharp\",\n price: 429.99,\n image: require(\"@src/assets/images/pages/eCommerce/6.png\").default,\n hasFreeShipping: false,\n rating: 3,\n description: `The Nintendo Switch Pro Controller is one of the priciest \"baseline\" controllers in the current console\n generation, but it's also sturdy, feels good to play with, has an excellent direction pad, and features\n impressive motion sensors and vibration systems. On top of all of that, it uses Bluetooth, so you don't need an\n adapter to use it with your PC.`,\n },\n {\n id: 23,\n name: 'Apple - MacBook Air® (Latest Model) - 13.3\" Display - Silver',\n slug: \"apple-mac-book-air-latest-model-13-3-display-silver-23\",\n brand: \"Apple\",\n price: 999.99,\n image: require(\"@src/assets/images/pages/eCommerce/5.png\").default,\n hasFreeShipping: false,\n rating: 4,\n description: `MacBook Air is a thin, lightweight laptop from Apple. MacBook Air features up to 8GB of memory, a\n fifth-generation Intel Core processor, Thunderbolt 2, great built-in apps, and all-day battery life.1 Its thin,\n light, and durable enough to take everywhere you go-and powerful enough to do everything once you get there,\n better.`,\n },\n {\n id: 24,\n name: \"OneOdio A71 Wired Headphones\",\n slug: \"one-odio-a71-wired-headphones-24\",\n brand: \"OneOdio\",\n price: 49.99,\n image: require(\"@src/assets/images/pages/eCommerce/4.png\").default,\n hasFreeShipping: true,\n rating: 3,\n description: `Omnidirectional detachable boom mic upgrades the headphones into a professional headset for gaming, business,\n podcasting and taking calls on the go. Better pick up your voice. Control most electric devices through voice\n activation, or schedule a ride with Uber and order a pizza. OneOdio A71 Wired Headphones voice-controlled device\n turns any home into a smart device on a smartphone or tablet.`,\n },\n {\n id: 25,\n name: \"Apple iMac 27-inch\",\n slug: \"apple-i-mac-27-inch-25\",\n brand: \"Apple\",\n price: 999.99,\n image: require(\"@src/assets/images/pages/eCommerce/3.png\").default,\n hasFreeShipping: true,\n rating: 4,\n description: `The all-in-one for all. If you can dream it, you can do it on iMac. It’s beautifully & incredibly intuitive and\n packed with tools that let you take any idea to the next level. And the new 27-inch model elevates the\n experience in way, with faster processors and graphics, expanded memory and storage, enhanced audio and video\n capabilities, and an even more stunning Retina 5K display. It’s the desktop that does it all — better and faster\n than ever.`,\n },\n {\n id: 26,\n name: \"Apple iPhone 11 (64GB, Black)\",\n slug: \"apple-i-phone-11-64-gb-black-26\",\n brand: \"Apple\",\n price: 669.99,\n image: require(\"@src/assets/images/pages/eCommerce/2.png\").default,\n hasFreeShipping: true,\n rating: 5,\n description: `The Apple iPhone 11 is a great smartphone, which was loaded with a lot of quality features. It comes with a\n waterproof and dustproof body which is the key attraction of the device. The excellent set of cameras offer\n excellent images as well as capable of recording crisp videos. However, expandable storage and a fingerprint\n scanner would have made it a perfect option to go for around this price range.`,\n },\n {\n id: 27,\n name: \"Apple Watch Series 5\",\n slug: \"apple-watch-series-5-27\",\n brand: \"Apple\",\n price: 339.99,\n image: require(\"@src/assets/images/pages/eCommerce/1.png\").default,\n hasFreeShipping: true,\n rating: 4,\n description: `On Retina display that never sleeps, so it’s easy to see the time and other important information, without\n raising or tapping the display. New location features, from a built-in compass to current elevation, help users\n better navigate their day, while international emergency calling1 allows customers to call emergency services\n directly from Apple Watch in over 150 countries, even without iPhone nearby. Apple Watch Series 5 is available\n in a wider range of materials, including aluminium, stainless steel, ceramic and an all-new titanium.`,\n },\n ],\n userWishlist: [\n { id: 1, productId: 26 },\n { id: 2, productId: 23 },\n ],\n userCart: [\n { id: 1, productId: 27, qty: 1 },\n { id: 2, productId: 21, qty: 1 },\n { id: 3, productId: 26, qty: 1 },\n { id: 4, productId: 25, qty: 1 },\n { id: 5, productId: 23, qty: 1 },\n ],\n};\n/* eslint-enable */\n\n// ------------------------------------------------\n// GET: Return products\n// ------------------------------------------------\nmock.onGet(\"/apps/ecommerce/products\").reply((config) => {\n // eslint-disable-next-line object-curly-newline\n const { q = \"\", sortBy = \"featured\", perPage = 9, page = 1 } = config.params;\n\n const queryLowered = q.toLowerCase();\n\n const filteredData = data.products.filter((product) =>\n product.name.toLowerCase().includes(queryLowered)\n );\n\n let sortDesc = false;\n const sortByKey = (() => {\n if (sortBy === \"price-desc\") {\n sortDesc = true;\n return \"price\";\n }\n if (sortBy === \"price-asc\") {\n return \"price\";\n }\n sortDesc = true;\n return \"id\";\n })();\n\n const sortedData = filteredData.sort(sortCompare(sortByKey));\n if (sortDesc) sortedData.reverse();\n\n const paginatedData = JSON.parse(\n JSON.stringify(paginateArray(sortedData, perPage, page))\n );\n\n paginatedData.forEach((product) => {\n /* eslint-disable no-param-reassign */\n product.isInWishlist =\n data.userWishlist.findIndex((p) => p.productId === product.id) > -1;\n product.isInCart =\n data.userCart.findIndex((p) => p.productId === product.id) > -1;\n /* eslint-enable */\n });\n\n return [\n 200,\n {\n products: paginatedData,\n total: filteredData.length,\n userWishlist: data.userWishlist,\n userCart: data.userCart,\n },\n ];\n});\n\n// ------------------------------------------------\n// GET: Return Single Product\n// ------------------------------------------------\nmock.onGet(/\\/apps\\/ecommerce\\/products\\/\\d+/).reply((config) => {\n // Get product id from URL\n let productId = config.url.substring(config.url.lastIndexOf(\"/\") + 1);\n\n // Convert Id to number\n productId = Number(productId);\n\n const productIndex = data.products.findIndex((p) => p.id === productId);\n const product = data.products[productIndex];\n\n if (product) {\n // Add data of wishlist and cart\n product.isInWishlist =\n data.userWishlist.findIndex((p) => p.productId === product.id) > -1;\n product.isInCart =\n data.userCart.findIndex((p) => p.productId === product.id) > -1;\n\n // * Add Dummy data for details page\n product.colorOptions = [\"primary\", \"success\", \"warning\", \"danger\", \"info\"];\n\n return [200, { product }];\n }\n return [404];\n});\n\n// ------------------------------------------------\n// GET: Return Wishlist Products\n// ------------------------------------------------\nmock.onGet(\"/apps/ecommerce/wishlist\").reply(() => {\n const products = data.userWishlist.map((wishlistProduct) => {\n const product = data.products.find(\n (p) => p.id === wishlistProduct.productId\n );\n product.isInCart =\n data.userCart.findIndex(\n (p) => p.productId === wishlistProduct.productId\n ) > -1;\n return product;\n });\n\n return [200, { products }];\n});\n\n// ------------------------------------------------\n// GET: Return Cart Products\n// ------------------------------------------------\nmock.onGet(\"/apps/ecommerce/cart\").reply(() => {\n const products = data.userCart.map((cartProduct) => {\n const product = data.products.find((p) => p.id === cartProduct.productId);\n\n // Other data\n product.isInWishlist =\n data.userWishlist.findIndex(\n (p) => p.productId === cartProduct.productId\n ) > -1;\n product.qty = cartProduct.qty;\n product.shippingDate = randomDate(nextDay, nextWeek);\n product.offers = getRandomInt(1, 4);\n product.discountPercentage = getRandomInt(3, 20);\n\n return product;\n });\n\n return [200, { products }];\n});\n\n// ------------------------------------------------\n// POST: Add Item in user Cart\n// ------------------------------------------------\nmock.onPost(\"/apps/ecommerce/cart\").reply((config) => {\n // Get product from post data\n const { productId } = JSON.parse(config.data);\n\n const { length } = data.userCart;\n let lastId = 0;\n if (length) lastId = data.userCart[length - 1].i;\n\n data.userCart.push({\n id: lastId + 1,\n productId,\n qty: 1,\n });\n\n return [201];\n});\n\n// ------------------------------------------------\n// DELETE: Remove Item from user Cart\n// ------------------------------------------------\nmock.onDelete(/\\/apps\\/ecommerce\\/cart\\/\\d+/).reply((config) => {\n // Get product id from URL\n let productId = config.url.substring(config.url.lastIndexOf(\"/\") + 1);\n\n // Convert Id to number\n productId = Number(productId);\n\n const productIndex = data.userCart.findIndex(\n (i) => i.productId === productId\n );\n if (productIndex > -1) data.userCart.splice(productIndex, 1);\n\n return [200];\n});\n\n// ------------------------------------------------\n// POST: Add Item in user Wishlist\n// ------------------------------------------------\nmock.onPost(\"/apps/ecommerce/wishlist\").reply((config) => {\n // Get product from post data\n const { productId } = JSON.parse(config.data);\n\n const { length } = data.userWishlist;\n let lastId = 0;\n if (length) lastId = data.userWishlist[length - 1].i;\n\n data.userWishlist.push({\n id: lastId + 1,\n productId: Number(productId),\n });\n\n return [201];\n});\n\n// ------------------------------------------------\n// DELETE: Remove Item from user Wishlist\n// ------------------------------------------------\nmock.onDelete(/\\/apps\\/ecommerce\\/wishlist\\/\\d+/).reply((config) => {\n // Get product id from URL\n let productId = config.url.substring(config.url.lastIndexOf(\"/\") + 1);\n\n // Convert Id to number\n productId = Number(productId);\n\n const productIndex = data.userWishlist.findIndex(\n (i) => i.productId === productId\n );\n if (productIndex > -1) data.userWishlist.splice(productIndex, 1);\n\n return [200];\n});\n","import mock from \"../mock\";\n\nconst data = {\n // blog list\n blogList: [\n {\n img: require(\"@src/assets/images/slider/02.jpg\").default,\n title: \"The Best Features Coming to iOS and Web design\",\n id: 1,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n blogPosted: \"Jan 10, 2020\",\n tags: [\"Quote\", \"Fashion\"],\n excerpt:\n \"Donut fruitcake soufflé apple pie candy canes jujubes croissant chocolate bar ice cream.\",\n comment: 76,\n },\n {\n img: require(\"@src/assets/images/slider/06.jpg\").default,\n title: \"Latest Quirky Opening Sentence or Paragraph\",\n id: 2,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n userFullName: \"Jorge Griffin\",\n blogPosted: \"Jan 10, 2020\",\n tags: [\"Gaming\", \"Video\"],\n excerpt:\n \"Apple pie caramels lemon drops halvah liquorice carrot cake. Tiramisu brownie lemon drops.\",\n comment: 2100,\n },\n {\n img: require(\"@src/assets/images/slider/04.jpg\").default,\n title: \"Share an Amazing and Shocking Fact or Statistic\",\n id: 3,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-3.jpg\")\n .default,\n userFullName: \"Claudia Neal\",\n blogPosted: \"Jan 10, 2020\",\n tags: [\"Gaming\", \"Food\"],\n excerpt:\n \"Tiramisu jelly-o chupa chups tootsie roll donut wafer marshmallow cheesecake topping.\",\n comment: 243,\n },\n {\n img: require(\"@src/assets/images/slider/03.jpg\").default,\n title: \"Withhold a Compelling Piece of Information\",\n id: 4,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-14.jpg\")\n .default,\n userFullName: \"Fred Boone\",\n blogPosted: \"Jan 10, 2020\",\n tags: [\"Video\"],\n excerpt:\n \"Croissant apple pie lollipop gingerbread. Cookie jujubes chocolate cake icing cheesecake.\",\n comment: 10,\n },\n {\n img: require(\"@src/assets/images/slider/09.jpg\").default,\n title: \"Unadvertised Bonus Opening: Share a Quote\",\n id: 5,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-13.jpg\")\n .default,\n userFullName: \"Billy French\",\n blogPosted: \"Jan 10, 2020\",\n tags: [\"Quote\", \"Fashion\"],\n excerpt:\n \"Muffin liquorice candy soufflé bear claw apple pie icing halvah. Pie marshmallow jelly.\",\n comment: 319,\n },\n {\n img: require(\"@src/assets/images/slider/10.jpg\").default,\n title: \"Ships at a distance have Every Man’s Wish on Board\",\n id: 6,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-13.jpg\")\n .default,\n userFullName: \"Helena Hunt\",\n blogPosted: \"Jan 10, 2020\",\n tags: [\"Fashion\", \"Video\"],\n excerpt:\n \"A little personality goes a long way, especially on a business blog. So don’t be afraid to let loose.\",\n comment: 1500,\n },\n ],\n\n // sidebar\n blogSidebar: {\n recentPosts: [\n {\n img: require(\"@src/assets/images/banner/banner-22.jpg\").default,\n title: \"Why Should Forget Facebook?\",\n id: 7,\n createdTime: \"Jan 14 2020\",\n },\n {\n img: require(\"@src/assets/images/banner/banner-27.jpg\").default,\n title: \"Publish your passions, your way\",\n id: 8,\n createdTime: \"Mar 04 2020\",\n },\n {\n img: require(\"@src/assets/images/banner/banner-39.jpg\").default,\n title: \"The Best Ways to Retain More\",\n id: 9,\n createdTime: \"Feb 18 2020\",\n },\n {\n img: require(\"@src/assets/images/banner/banner-35.jpg\").default,\n title: \"Share a Shocking Fact or Statistic\",\n id: 10,\n createdTime: \"Oct 08 2020\",\n },\n ],\n categories: [\n { category: \"Fashion\", icon: \"Watch\" },\n { category: \"Food\", icon: \"ShoppingCart\" },\n { category: \"Gaming\", icon: \"Command\" },\n { category: \"Quote\", icon: \"Hash\" },\n { category: \"Video\", icon: \"Video\" },\n ],\n },\n\n // detail\n blogDetail: {\n blog: {\n img: require(\"@src/assets/images/banner/banner-12.jpg\").default,\n title: \"The Best Features Coming to iOS and Web design\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n createdTime: \"Jan 10, 2020\",\n tags: [\"Gaming\", \"Video\"],\n content:\n 'Before you get into the nitty-gritty of coming up with a perfect title, start with a rough draft: your working title. What is that, exactly? A lot of people confuse working titles with topics. Let\\'s clear that Topics are very general and could yield several different blog posts. Think \"raising healthy kids,\" or \"kitchen storage.\" A writer might look at either of those topics and choose to take them in very, very different directions.A working title, on the other hand, is very specific and guides the creation of a single blog post. For example, from the topic \"raising healthy kids,\" you could derive the following working title See how different and specific each of those is? That\\'s what makes them working titles, instead of overarching topics.
Unprecedented Challenge Preliminary thinking systems Bandwidth efficient Green space Social impact Thought partnership Fully ethical life ',\n comments: 19100,\n bookmarked: 139,\n },\n comments: [\n {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n userFullName: \"Chad Alexander\",\n commentedAt: \"May 24, 2020\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n\n // edit\n blogEdit: {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\").default,\n userFullName: \"Chad Alexander\",\n createdTime: \"May 24, 2020\",\n blogTitle: \"The Best Features Coming to iOS and Web design\",\n blogCategories: [\n { value: \"fashion\", label: \"Fashion\" },\n { value: \"gaming\", label: \"Gaming\" },\n ],\n slug: \"the-best-features-coming-to-ios-and-web-design\",\n status: \"Published\",\n excerpt:\n \"Cupcake ipsum dolor sit. Amet dessert donut candy chocolate bar cotton dessert candy chocolate. Candy muffin danish. Macaroon brownie jelly beans marzipan cheesecake oat cake. Carrot cake macaroon chocolate cake. Jelly brownie jelly. Marzipan pie sweet roll.
Liquorice dragée cake chupa chups pie cotton candy jujubes bear claw sesame snaps. Fruitcake chupa chups chocolate bonbon lemon drops croissant caramels lemon drops. Candy jelly cake marshmallow jelly beans dragée macaroon. Gummies sugar plum fruitcake. Candy canes candy cupcake caramels cotton candy jujubes fruitcake.
\",\n featuredImage: require(\"@src/assets/images/slider/03.jpg\").default,\n },\n};\n\nmock.onGet(\"/blog/list/data\").reply(() => [200, data.blogList]);\nmock.onGet(\"/blog/list/data/sidebar\").reply(() => [200, data.blogSidebar]);\nmock.onGet(\"/blog/list/data/detail\").reply(() => [200, data.blogDetail]);\nmock.onGet(\"/blog/list/data/edit\").reply(() => [200, data.blogEdit]);\n","import mock from \"../mock\";\n\n// ** Utils\nimport { paginateArray } from \"../utils\";\n\nconst data = [\n {\n responsive_id: \"\",\n id: 1,\n avatar: \"10.jpg\",\n full_name: \"Korrie O'Crevy\",\n post: \"Nuclear Power Engineer\",\n email: \"kocrevy0@thetimes.co.uk\",\n city: \"Krasnosilka\",\n start_date: \"09/23/2016\",\n salary: \"$23896.35\",\n age: \"61\",\n experience: \"1 Year\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 2,\n avatar: \"1.jpg\",\n full_name: \"Bailie Coulman\",\n post: \"VP Quality Control\",\n email: \"bcoulman1@yolasite.com\",\n city: \"Hinigaran\",\n start_date: \"05/20/2018\",\n salary: \"$13633.69\",\n age: \"63\",\n experience: \"3 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 3,\n avatar: \"9.jpg\",\n full_name: \"Stella Ganderton\",\n post: \"Operator\",\n email: \"sganderton2@tuttocitta.it\",\n city: \"Golcowa\",\n start_date: \"03/24/2018\",\n salary: \"$13076.28\",\n age: \"66\",\n experience: \"6 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 4,\n avatar: \"10.jpg\",\n full_name: \"Dorolice Crossman\",\n post: \"Cost Accountant\",\n email: \"dcrossman3@google.co.jp\",\n city: \"Paquera\",\n start_date: \"12/03/2017\",\n salary: \"$12336.17\",\n age: \"22\",\n experience: \"2 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 5,\n avatar: \"\",\n full_name: \"Harmonia Nisius\",\n post: \"Senior Cost Accountant\",\n email: \"hnisius4@gnu.org\",\n city: \"Lucan\",\n start_date: \"08/25/2017\",\n salary: \"$10909.52\",\n age: \"33\",\n experience: \"3 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 6,\n avatar: \"\",\n full_name: \"Genevra Honeywood\",\n post: \"Geologist\",\n email: \"ghoneywood5@narod.ru\",\n city: \"Maofan\",\n start_date: \"06/01/2017\",\n salary: \"$17803.80\",\n age: \"61\",\n experience: \"1 Year\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 7,\n avatar: \"\",\n full_name: \"Eileen Diehn\",\n post: \"Environmental Specialist\",\n email: \"ediehn6@163.com\",\n city: \"Lampuyang\",\n start_date: \"10/15/2017\",\n salary: \"$18991.67\",\n age: \"59\",\n experience: \"9 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 8,\n avatar: \"9.jpg\",\n full_name: \"Richardo Aldren\",\n post: \"Senior Sales Associate\",\n email: \"raldren7@mtv.com\",\n city: \"Skoghall\",\n start_date: \"11/05/2016\",\n salary: \"$19230.13\",\n age: \"55\",\n experience: \"5 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 9,\n avatar: \"2.jpg\",\n full_name: \"Allyson Moakler\",\n post: \"Safety Technician\",\n email: \"amoakler8@shareasale.com\",\n city: \"Mogilany\",\n start_date: \"12/29/2018\",\n salary: \"$11677.32\",\n age: \"39\",\n experience: \"9 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 10,\n avatar: \"9.jpg\",\n full_name: \"Merline Penhalewick\",\n post: \"Junior Executive\",\n email: \"mpenhalewick9@php.net\",\n city: \"Kanuma\",\n start_date: \"04/19/2019\",\n salary: \"$15939.52\",\n age: \"23\",\n experience: \"3 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 11,\n avatar: \"\",\n full_name: \"De Falloon\",\n post: \"Sales Representative\",\n email: \"dfalloona@ifeng.com\",\n city: \"Colima\",\n start_date: \"06/12/2018\",\n salary: \"$19252.12\",\n age: \"30\",\n experience: \"0 Year\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 12,\n avatar: \"\",\n full_name: \"Cyrus Gornal\",\n post: \"Senior Sales Associate\",\n email: \"cgornalb@fda.gov\",\n city: \"Boro Utara\",\n start_date: \"12/09/2017\",\n salary: \"$16745.47\",\n age: \"22\",\n experience: \"2 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 13,\n avatar: \"\",\n full_name: \"Tallou Balf\",\n post: \"Staff Accountant\",\n email: \"tbalfc@sina.com.cn\",\n city: \"Siliana\",\n start_date: \"01/21/2016\",\n salary: \"$15488.53\",\n age: \"36\",\n experience: \"6 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 14,\n avatar: \"\",\n full_name: \"Othilia Extill\",\n post: \"Associate Professor\",\n email: \"oextilld@theatlantic.com\",\n city: \"Brzyska\",\n start_date: \"02/01/2016\",\n salary: \"$18442.34\",\n age: \"43\",\n experience: \"3 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 15,\n avatar: \"\",\n full_name: \"Wilmar Bourton\",\n post: \"Administrative Assistant\",\n email: \"wbourtone@sakura.ne.jp\",\n city: \"Bích Động\",\n start_date: \"04/25/2018\",\n salary: \"$13304.45\",\n age: \"19\",\n experience: \"9 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 16,\n avatar: \"4.jpg\",\n full_name: \"Robinson Brazenor\",\n post: \"General Manager\",\n email: \"rbrazenorf@symantec.com\",\n city: \"Gendiwu\",\n start_date: \"12/23/2017\",\n salary: \"$11953.08\",\n age: \"66\",\n experience: \"6 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 17,\n avatar: \"\",\n full_name: \"Nadia Bettenson\",\n post: \"Environmental Tech\",\n email: \"nbettensong@joomla.org\",\n city: \"Chabařovice\",\n start_date: \"07/11/2018\",\n salary: \"$20484.44\",\n age: \"64\",\n experience: \"4 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 18,\n avatar: \"\",\n full_name: \"Titus Hayne\",\n post: \"Web Designer\",\n email: \"thayneh@kickstarter.com\",\n city: \"Yangon\",\n start_date: \"05/25/2019\",\n salary: \"$16871.48\",\n age: \"59\",\n experience: \"9 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 19,\n avatar: \"5.jpg\",\n full_name: \"Roxie Huck\",\n post: \"Administrative Assistant\",\n email: \"rhucki@ed.gov\",\n city: \"Polýkastro\",\n start_date: \"04/04/2019\",\n salary: \"$19653.56\",\n age: \"41\",\n experience: \"1 Year\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 20,\n avatar: \"7.jpg\",\n full_name: \"Latashia Lewtey\",\n post: \"Actuary\",\n email: \"llewteyj@sun.com\",\n city: \"Hougong\",\n start_date: \"08/03/2017\",\n salary: \"$18303.87\",\n age: \"35\",\n experience: \"5 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 21,\n avatar: \"\",\n full_name: \"Natalina Tyne\",\n post: \"Software Engineer\",\n email: \"ntynek@merriam-webster.com\",\n city: \"Yanguan\",\n start_date: \"03/16/2019\",\n salary: \"$15256.40\",\n age: \"30\",\n experience: \"0 Year\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 22,\n avatar: \"\",\n full_name: \"Faun Josefsen\",\n post: \"Analog Circuit Design manager\",\n email: \"fjosefsenl@samsung.com\",\n city: \"Wengyang\",\n start_date: \"07/08/2017\",\n salary: \"$11209.16\",\n age: \"40\",\n experience: \"0 Year\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 23,\n avatar: \"9.jpg\",\n full_name: \"Rosmunda Steed\",\n post: \"Assistant Media Planner\",\n email: \"rsteedm@xing.com\",\n city: \"Manzanares\",\n start_date: \"12/23/2017\",\n salary: \"$13778.34\",\n age: \"21\",\n experience: \"1 Year\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 24,\n avatar: \"\",\n full_name: \"Scott Jiran\",\n post: \"Graphic Designer\",\n email: \"sjirann@simplemachines.org\",\n city: \"Pinglin\",\n start_date: \"05/26/2016\",\n salary: \"$23081.71\",\n age: \"23\",\n experience: \"3 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 25,\n avatar: \"\",\n full_name: \"Carmita Medling\",\n post: \"Accountant\",\n email: \"cmedlingo@hp.com\",\n city: \"Bourges\",\n start_date: \"07/31/2019\",\n salary: \"$13602.24\",\n age: \"47\",\n experience: \"7 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 26,\n avatar: \"2.jpg\",\n full_name: \"Morgen Benes\",\n post: \"Senior Sales Associate\",\n email: \"mbenesp@ted.com\",\n city: \"Cà Mau\",\n start_date: \"04/10/2016\",\n salary: \"$16969.63\",\n age: \"42\",\n experience: \"2 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 27,\n avatar: \"\",\n full_name: \"Onfroi Doughton\",\n post: \"Civil Engineer\",\n email: \"odoughtonq@aboutads.info\",\n city: \"Utrecht (stad)\",\n start_date: \"09/29/2018\",\n salary: \"$23796.62\",\n age: \"28\",\n experience: \"8 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 28,\n avatar: \"\",\n full_name: \"Kliment McGinney\",\n post: \"Chief Design Engineer\",\n email: \"kmcginneyr@paginegialle.it\",\n city: \"Xiaocheng\",\n start_date: \"07/09/2018\",\n salary: \"$24027.81\",\n age: \"28\",\n experience: \"8 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 29,\n avatar: \"\",\n full_name: \"Devin Bridgland\",\n post: \"Tax Accountant\",\n email: \"dbridglands@odnoklassniki.ru\",\n city: \"Baoli\",\n start_date: \"07/17/2016\",\n salary: \"$13508.15\",\n age: \"48\",\n experience: \"8 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 30,\n avatar: \"6.jpg\",\n full_name: \"Gilbert McFade\",\n post: \"Biostatistician\",\n email: \"gmcfadet@irs.gov\",\n city: \"Deje\",\n start_date: \"08/28/2018\",\n salary: \"$21632.30\",\n age: \"20\",\n experience: \"0 Year\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 31,\n avatar: \"\",\n full_name: \"Teressa Bleakman\",\n post: \"Senior Editor\",\n email: \"tbleakmanu@phpbb.com\",\n city: \"Žebrák\",\n start_date: \"09/03/2016\",\n salary: \"$24875.41\",\n age: \"37\",\n experience: \"7 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 32,\n avatar: \"\",\n full_name: \"Marcelia Alleburton\",\n post: \"Safety Technician\",\n email: \"malleburtonv@amazon.com\",\n city: \"Basail\",\n start_date: \"06/02/2016\",\n salary: \"$23888.98\",\n age: \"53\",\n experience: \"3 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 33,\n avatar: \"7.jpg\",\n full_name: \"Aili De Coursey\",\n post: \"Environmental Specialist\",\n email: \"adew@etsy.com\",\n city: \"Łazy\",\n start_date: \"09/30/2016\",\n salary: \"$14082.44\",\n age: \"27\",\n experience: \"7 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 34,\n avatar: \"6.jpg\",\n full_name: \"Charlton Chatres\",\n post: \"Analyst Programmer\",\n email: \"cchatresx@goo.gl\",\n city: \"Reguengos de Monsaraz\",\n start_date: \"04/07/2016\",\n salary: \"$21386.52\",\n age: \"22\",\n experience: \"2 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 35,\n avatar: \"1.jpg\",\n full_name: \"Nat Hugonnet\",\n post: \"Financial Advisor\",\n email: \"nhugonnety@wufoo.com\",\n city: \"Pimentel\",\n start_date: \"09/11/2019\",\n salary: \"$13835.97\",\n age: \"46\",\n experience: \"6 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 36,\n avatar: \"\",\n full_name: \"Lorine Hearsum\",\n post: \"Payment Adjustment Coordinator\",\n email: \"lhearsumz@google.co.uk\",\n city: \"Shuiying\",\n start_date: \"03/05/2019\",\n salary: \"$22093.91\",\n age: \"47\",\n experience: \"7 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 37,\n avatar: \"8.jpg\",\n full_name: \"Sheila-kathryn Haborn\",\n post: \"Environmental Specialist\",\n email: \"shaborn10@about.com\",\n city: \"Lewolang\",\n start_date: \"11/10/2018\",\n salary: \"$24624.23\",\n age: \"51\",\n experience: \"1 Year\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 38,\n avatar: \"3.jpg\",\n full_name: \"Alma Harvatt\",\n post: \"Administrative Assistant\",\n email: \"aharvatt11@addtoany.com\",\n city: \"Ulundi\",\n start_date: \"11/04/2016\",\n salary: \"$21782.82\",\n age: \"41\",\n experience: \"1 Year\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 39,\n avatar: \"2.jpg\",\n full_name: \"Beatrix Longland\",\n post: \"VP Quality Control\",\n email: \"blongland12@gizmodo.com\",\n city: \"Damu\",\n start_date: \"07/18/2016\",\n salary: \"$22794.60\",\n age: \"62\",\n experience: \"2 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 40,\n avatar: \"4.jpg\",\n full_name: \"Hammad Condell\",\n post: \"Project Manager\",\n email: \"hcondell13@tiny.cc\",\n city: \"Bulung’ur\",\n start_date: \"11/04/2018\",\n salary: \"$10872.83\",\n age: \"37\",\n experience: \"7 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 41,\n avatar: \"\",\n full_name: \"Parker Bice\",\n post: \"Technical Writer\",\n email: \"pbice14@ameblo.jp\",\n city: \"Shanlian\",\n start_date: \"03/02/2016\",\n salary: \"$17471.92\",\n age: \"65\",\n experience: \"5 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 42,\n avatar: \"\",\n full_name: \"Lowrance Orsi\",\n post: \"Biostatistician\",\n email: \"lorsi15@wp.com\",\n city: \"Dengteke\",\n start_date: \"12/10/2018\",\n salary: \"$24719.51\",\n age: \"64\",\n experience: \"4 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 43,\n avatar: \"10.jpg\",\n full_name: \"Ddene Chaplyn\",\n post: \"Environmental Tech\",\n email: \"dchaplyn16@nymag.com\",\n city: \"Lattes\",\n start_date: \"01/23/2019\",\n salary: \"$11958.33\",\n age: \"38\",\n experience: \"8 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 44,\n avatar: \"\",\n full_name: \"Washington Bygraves\",\n post: \"Human Resources Manager\",\n email: \"wbygraves17@howstuffworks.com\",\n city: \"Zlaté Hory\",\n start_date: \"09/07/2016\",\n salary: \"$10552.43\",\n age: \"37\",\n experience: \"7 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 45,\n avatar: \"7.jpg\",\n full_name: \"Meghann Bodechon\",\n post: \"Operator\",\n email: \"mbodechon18@1und1.de\",\n city: \"Itō\",\n start_date: \"07/23/2018\",\n salary: \"$23024.28\",\n age: \"61\",\n experience: \"1 Year\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 46,\n avatar: \"1.jpg\",\n full_name: \"Moshe De Ambrosis\",\n post: \"Recruiting Manager\",\n email: \"mde19@purevolume.com\",\n city: \"San Diego\",\n start_date: \"02/10/2018\",\n salary: \"$10409.90\",\n age: \"47\",\n experience: \"7 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 47,\n avatar: \"5.jpg\",\n full_name: \"Had Chatelot\",\n post: \"Cost Accountant\",\n email: \"hchatelot1a@usatoday.com\",\n city: \"Mercedes\",\n start_date: \"11/23/2016\",\n salary: \"$11446.30\",\n age: \"64\",\n experience: \"4 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 48,\n avatar: \"\",\n full_name: \"Georgia McCrum\",\n post: \"Registered Nurse\",\n email: \"gmccrum1b@icio.us\",\n city: \"Nggalak\",\n start_date: \"04/19/2018\",\n salary: \"$14002.31\",\n age: \"63\",\n experience: \"3 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 49,\n avatar: \"8.jpg\",\n full_name: \"Krishnah Stilldale\",\n post: \"VP Accounting\",\n email: \"kstilldale1c@chronoengine.com\",\n city: \"Slavs’ke\",\n start_date: \"03/18/2017\",\n salary: \"$10704.29\",\n age: \"56\",\n experience: \"6 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 50,\n avatar: \"4.jpg\",\n full_name: \"Mario Umbert\",\n post: \"Research Assistant\",\n email: \"mumbert1d@digg.com\",\n city: \"Chorotis\",\n start_date: \"05/13/2019\",\n salary: \"$21813.54\",\n age: \"43\",\n experience: \"3 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 51,\n avatar: \"\",\n full_name: \"Edvard Dixsee\",\n post: \"Graphic Designer\",\n email: \"edixsee1e@unblog.fr\",\n city: \"Rancharia\",\n start_date: \"04/23/2019\",\n salary: \"$18053.11\",\n age: \"46\",\n experience: \"6 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 52,\n avatar: \"9.jpg\",\n full_name: \"Tammie Davydoch\",\n post: \"VP Quality Control\",\n email: \"tdavydoch1f@examiner.com\",\n city: \"Mamedkala\",\n start_date: \"04/19/2016\",\n salary: \"$17617.08\",\n age: \"47\",\n experience: \"7 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 53,\n avatar: \"\",\n full_name: \"Benito Rodolico\",\n post: \"Safety Technician\",\n email: \"brodolico1g@sciencedirect.com\",\n city: \"Wonosobo\",\n start_date: \"10/06/2018\",\n salary: \"$18866.55\",\n age: \"21\",\n experience: \"1 Year\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 54,\n avatar: \"\",\n full_name: \"Marco Pennings\",\n post: \"Compensation Analyst\",\n email: \"mpennings1h@bizjournals.com\",\n city: \"Umag\",\n start_date: \"06/15/2017\",\n salary: \"$13722.18\",\n age: \"30\",\n experience: \"0 Year\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 55,\n avatar: \"\",\n full_name: \"Tommie O'Corr\",\n post: \"Quality Engineer\",\n email: \"tocorr1i@nyu.edu\",\n city: \"Olhos de Água\",\n start_date: \"09/26/2018\",\n salary: \"$15228.80\",\n age: \"51\",\n experience: \"1 Year\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 56,\n avatar: \"1.jpg\",\n full_name: \"Cybill Poyle\",\n post: \"Cost Accountant\",\n email: \"cpoyle1j@amazon.com\",\n city: \"Hamm\",\n start_date: \"01/03/2016\",\n salary: \"$13951.96\",\n age: \"29\",\n experience: \"9 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 57,\n avatar: \"6.jpg\",\n full_name: \"Norry Stoller\",\n post: \"Human Resources Manager\",\n email: \"nstoller1k@noaa.gov\",\n city: \"Ruukki\",\n start_date: \"02/04/2018\",\n salary: \"$15100.00\",\n age: \"27\",\n experience: \"7 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 58,\n avatar: \"\",\n full_name: \"Wendi Somerlie\",\n post: \"Systems Administrator\",\n email: \"wsomerlie1l@accuweather.com\",\n city: \"Meicheng\",\n start_date: \"04/22/2016\",\n salary: \"$20023.52\",\n age: \"28\",\n experience: \"9 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 59,\n avatar: \"\",\n full_name: \"Ferdie Georgeon\",\n post: \"Geologist\",\n email: \"fgeorgeon1m@nhs.uk\",\n city: \"Tanahbeureum\",\n start_date: \"04/08/2019\",\n salary: \"$12630.26\",\n age: \"28\",\n experience: \"1 Year\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 60,\n avatar: \"\",\n full_name: \"Jules Auten\",\n post: \"Desktop Support Technician\",\n email: \"jauten1n@foxnews.com\",\n city: \"Mojo\",\n start_date: \"08/13/2019\",\n salary: \"$13870.62\",\n age: \"48\",\n experience: \"5 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 61,\n avatar: \"3.jpg\",\n full_name: \"Nichole Dacres\",\n post: \"Mechanical Systems Engineer\",\n email: \"ndacres1o@apache.org\",\n city: \"Kimanuit\",\n start_date: \"11/06/2017\",\n salary: \"$18220.51\",\n age: \"20\",\n experience: \"0 Year\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 62,\n avatar: \"1.jpg\",\n full_name: \"Holly Edgworth\",\n post: \"Junior Executive\",\n email: \"hedgworth1p@craigslist.org\",\n city: \"Pedreira\",\n start_date: \"08/05/2017\",\n salary: \"$13999.88\",\n age: \"37\",\n experience: \"0 Year\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 63,\n avatar: \"9.jpg\",\n full_name: \"Henriette Croft\",\n post: \"Food Chemist\",\n email: \"hcroft1q@desdev.cn\",\n city: \"Taizhou\",\n start_date: \"09/12/2019\",\n salary: \"$11049.79\",\n age: \"53\",\n experience: \"1 Year\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 64,\n avatar: \"\",\n full_name: \"Annetta Glozman\",\n post: \"Staff Accountant\",\n email: \"aglozman1r@storify.com\",\n city: \"Pendawanbaru\",\n start_date: \"08/25/2017\",\n salary: \"$10745.32\",\n age: \"27\",\n experience: \"3 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 65,\n avatar: \"\",\n full_name: \"Cletis Cervantes\",\n post: \"Health Coach\",\n email: \"ccervantes1s@de.vu\",\n city: \"Solnechnyy\",\n start_date: \"05/24/2018\",\n salary: \"$24769.08\",\n age: \"22\",\n experience: \"7 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 66,\n avatar: \"9.jpg\",\n full_name: \"Christos Kiley\",\n post: \"Geologist\",\n email: \"ckiley1t@buzzfeed.com\",\n city: \"El Bolsón\",\n start_date: \"02/27/2019\",\n salary: \"$16053.15\",\n age: \"46\",\n experience: \"2 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 67,\n avatar: \"7.jpg\",\n full_name: \"Silvain Siebert\",\n post: \"VP Sales\",\n email: \"ssiebert1u@domainmarket.com\",\n city: \"Cadiz\",\n start_date: \"09/23/2017\",\n salary: \"$23347.17\",\n age: \"47\",\n experience: \"8 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 68,\n avatar: \"\",\n full_name: \"Sharla Ibberson\",\n post: \"Payment Adjustment Coordinator\",\n email: \"sibberson1v@virginia.edu\",\n city: \"Lamam\",\n start_date: \"11/01/2016\",\n salary: \"$15658.40\",\n age: \"51\",\n experience: \"8 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 69,\n avatar: \"7.jpg\",\n full_name: \"Ripley Rentcome\",\n post: \"Physical Therapy Assistant\",\n email: \"rrentcome1w@youtu.be\",\n city: \"Dashkawka\",\n start_date: \"07/15/2018\",\n salary: \"$15396.66\",\n age: \"41\",\n experience: \"8 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 70,\n avatar: \"\",\n full_name: \"Chrisse Birrane\",\n post: \"Chemical Engineer\",\n email: \"cbirrane1x@google.com.br\",\n city: \"Las Toscas\",\n start_date: \"05/22/2016\",\n salary: \"$15823.40\",\n age: \"62\",\n experience: \"0 Year\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 71,\n avatar: \"\",\n full_name: \"Georges Tesyro\",\n post: \"Human Resources Manager\",\n email: \"gtesyro1y@last.fm\",\n city: \"Gabao\",\n start_date: \"01/27/2019\",\n salary: \"$19051.25\",\n age: \"37\",\n experience: \"7 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 72,\n avatar: \"\",\n full_name: \"Bondon Hazard\",\n post: \"Geological Engineer\",\n email: \"bhazard1z@over-blog.com\",\n city: \"Llano de Piedra\",\n start_date: \"01/17/2019\",\n salary: \"$11632.84\",\n age: \"65\",\n experience: \"3 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 73,\n avatar: \"5.jpg\",\n full_name: \"Aliza MacElholm\",\n post: \"VP Sales\",\n email: \"amacelholm20@printfriendly.com\",\n city: \"Sosnovyy Bor\",\n start_date: \"11/17/2017\",\n salary: \"$16741.31\",\n age: \"64\",\n experience: \"7 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 74,\n avatar: \"2.jpg\",\n full_name: \"Lucas Witherdon\",\n post: \"Senior Quality Engineer\",\n email: \"lwitherdon21@storify.com\",\n city: \"Staré Křečany\",\n start_date: \"09/26/2016\",\n salary: \"$19387.76\",\n age: \"38\",\n experience: \"2 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 75,\n avatar: \"\",\n full_name: \"Pegeen Peasegod\",\n post: \"Web Designer\",\n email: \"ppeasegod22@slideshare.net\",\n city: \"Keda\",\n start_date: \"05/21/2016\",\n salary: \"$24014.04\",\n age: \"59\",\n experience: \"6 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 76,\n avatar: \"\",\n full_name: \"Elyn Watkinson\",\n post: \"Structural Analysis Engineer\",\n email: \"ewatkinson23@blogspot.com\",\n city: \"Osan\",\n start_date: \"09/30/2016\",\n salary: \"$14493.51\",\n age: \"55\",\n experience: \"7 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 77,\n avatar: \"10.jpg\",\n full_name: \"Babb Skirving\",\n post: \"Analyst Programmer\",\n email: \"bskirving24@cbsnews.com\",\n city: \"Balky\",\n start_date: \"09/27/2016\",\n salary: \"$24733.28\",\n age: \"39\",\n experience: \"1 Year\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 78,\n avatar: \"\",\n full_name: \"Shelli Ondracek\",\n post: \"Financial Advisor\",\n email: \"sondracek25@plala.or.jp\",\n city: \"Aoluguya Ewenke Minzu\",\n start_date: \"03/28/2016\",\n salary: \"$21922.17\",\n age: \"23\",\n experience: \"1 Year\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 79,\n avatar: \"9.jpg\",\n full_name: \"Stanislaw Melloy\",\n post: \"Sales Associate\",\n email: \"smelloy26@fastcompany.com\",\n city: \"Funafuti\",\n start_date: \"04/13/2017\",\n salary: \"$16944.42\",\n age: \"30\",\n experience: \"2 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 80,\n avatar: \"\",\n full_name: \"Seamus Eisikovitsh\",\n post: \"Legal Assistant\",\n email: \"seisikovitsh27@usgs.gov\",\n city: \"Cangkringan\",\n start_date: \"05/28/2018\",\n salary: \"$21963.69\",\n age: \"22\",\n experience: \"7 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 81,\n avatar: \"2.jpg\",\n full_name: \"Tammie Wattins\",\n post: \"Web Designer\",\n email: \"twattins28@statcounter.com\",\n city: \"Xilin\",\n start_date: \"08/07/2018\",\n salary: \"$16049.93\",\n age: \"36\",\n experience: \"5 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 82,\n avatar: \"8.jpg\",\n full_name: \"Aila Quailadis\",\n post: \"Technical Writer\",\n email: \"aquail29@prlog.org\",\n city: \"Shuangchahe\",\n start_date: \"02/11/2018\",\n salary: \"$24137.29\",\n age: \"43\",\n experience: \"4 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 83,\n avatar: \"\",\n full_name: \"Myrvyn Gilogly\",\n post: \"Research Associate\",\n email: \"mgilogly2a@elpais.com\",\n city: \"Prince Rupert\",\n start_date: \"05/13/2018\",\n salary: \"$10089.96\",\n age: \"19\",\n experience: \"8 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 84,\n avatar: \"5.jpg\",\n full_name: \"Hanna Langthorne\",\n post: \"Analyst Programmer\",\n email: \"hlangthorne2b@stumbleupon.com\",\n city: \"Guaynabo\",\n start_date: \"11/11/2018\",\n salary: \"$14227.10\",\n age: \"21\",\n experience: \"7 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 85,\n avatar: \"\",\n full_name: \"Ruby Gimblet\",\n post: \"Registered Nurse\",\n email: \"rgimblet2c@1688.com\",\n city: \"Nanyulinxi\",\n start_date: \"03/28/2016\",\n salary: \"$19562.59\",\n age: \"30\",\n experience: \"1 Year\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 86,\n avatar: \"4.jpg\",\n full_name: \"Louis Paszak\",\n post: \"Programmer\",\n email: \"lpaszak2d@behance.net\",\n city: \"Chiscas\",\n start_date: \"04/25/2016\",\n salary: \"$17178.86\",\n age: \"51\",\n experience: \"7 Years\",\n status: 5,\n },\n {\n responsive_id: \"\",\n id: 87,\n avatar: \"\",\n full_name: \"Glennie Riolfi\",\n post: \"Computer Systems Analyst\",\n email: \"griolfi2e@drupal.org\",\n city: \"Taung\",\n start_date: \"06/18/2018\",\n salary: \"$15089.83\",\n age: \"29\",\n experience: \"4 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 88,\n avatar: \"\",\n full_name: \"Jemimah Morgan\",\n post: \"Staff Accountant\",\n email: \"jmorgan2f@nifty.com\",\n city: \"La Esperanza\",\n start_date: \"01/17/2016\",\n salary: \"$18330.72\",\n age: \"27\",\n experience: \"3 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 89,\n avatar: \"10.jpg\",\n full_name: \"Talya Brandon\",\n post: \"Food Chemist\",\n email: \"tbrandon2g@ucoz.com\",\n city: \"Zaječar\",\n start_date: \"10/08/2018\",\n salary: \"$16284.64\",\n age: \"28\",\n experience: \"6 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 90,\n avatar: \"6.jpg\",\n full_name: \"Renate Shay\",\n post: \"Recruiter\",\n email: \"rshay2h@tumblr.com\",\n city: \"Pueblo Viejo\",\n start_date: \"03/15/2017\",\n salary: \"$18523.75\",\n age: \"28\",\n experience: \"3 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 91,\n avatar: \"\",\n full_name: \"Julianne Bartosik\",\n post: \"Senior Cost Accountant\",\n email: \"jbartosik2i@state.gov\",\n city: \"Botlhapatlou\",\n start_date: \"02/06/2017\",\n salary: \"$17607.66\",\n age: \"48\",\n experience: \"6 Years\",\n status: 3,\n },\n {\n responsive_id: \"\",\n id: 92,\n avatar: \"3.jpg\",\n full_name: \"Yvonne Emberton\",\n post: \"Recruiter\",\n email: \"yemberton2j@blog.com\",\n city: \"Nagcarlan\",\n start_date: \"02/13/2017\",\n salary: \"$17550.18\",\n age: \"20\",\n experience: \"1 Year\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 93,\n avatar: \"8.jpg\",\n full_name: \"Danya Faichnie\",\n post: \"Social Worker\",\n email: \"dfaichnie2k@weather.com\",\n city: \"Taling\",\n start_date: \"07/29/2019\",\n salary: \"$18469.35\",\n age: \"37\",\n experience: \"3 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 94,\n avatar: \"\",\n full_name: \"Ronica Hasted\",\n post: \"Software Consultant\",\n email: \"rhasted2l@hexun.com\",\n city: \"Gangkou\",\n start_date: \"07/04/2019\",\n salary: \"$24866.66\",\n age: \"53\",\n experience: \"7 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 95,\n avatar: \"2.jpg\",\n full_name: \"Edwina Ebsworth\",\n post: \"Human Resources Assistant\",\n email: \"eebsworth2m@sbwire.com\",\n city: \"Puzi\",\n start_date: \"09/27/2018\",\n salary: \"$19586.23\",\n age: \"27\",\n experience: \"2 Years\",\n status: 1,\n },\n {\n responsive_id: \"\",\n id: 96,\n avatar: \"\",\n full_name: \"Alaric Beslier\",\n post: \"Tax Accountant\",\n email: \"abeslier2n@zimbio.com\",\n city: \"Ocucaje\",\n start_date: \"04/16/2017\",\n salary: \"$19366.53\",\n age: \"22\",\n experience: \"8 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 97,\n avatar: \"\",\n full_name: \"Reina Peckett\",\n post: \"Quality Control Specialist\",\n email: \"rpeckett2o@timesonline.co.uk\",\n city: \"Anyang\",\n start_date: \"05/20/2018\",\n salary: \"$16619.40\",\n age: \"46\",\n experience: \"8 Years\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 98,\n avatar: \"7.jpg\",\n full_name: \"Olivette Gudgin\",\n post: \"Paralegal\",\n email: \"ogudgin2p@gizmodo.com\",\n city: \"Fujinomiya\",\n start_date: \"04/09/2019\",\n salary: \"$15211.60\",\n age: \"47\",\n experience: \"8 Years\",\n status: 2,\n },\n {\n responsive_id: \"\",\n id: 99,\n avatar: \"10.jpg\",\n full_name: \"Evangelina Carnock\",\n post: \"Cost Accountant\",\n email: \"ecarnock2q@washington.edu\",\n city: \"Doushaguan\",\n start_date: \"01/26/2017\",\n salary: \"$23704.82\",\n age: \"51\",\n experience: \"0 Year\",\n status: 4,\n },\n {\n responsive_id: \"\",\n id: 100,\n avatar: \"\",\n full_name: \"Glyn Giacoppo\",\n post: \"Software Test Engineer\",\n email: \"ggiacoppo2r@apache.org\",\n city: \"Butha-Buthe\",\n start_date: \"04/15/2017\",\n salary: \"$24973.48\",\n age: \"41\",\n experience: \"7 Years\",\n status: 2,\n },\n];\n\nmock.onGet(\"/api/datatables/initial-data\").reply(() => {\n return [200, data];\n});\n\nmock.onGet(\"/api/datatables/data\").reply((config) => {\n // eslint-disable-next-line object-curly-newline\n const { q = \"\", perPage = 10, page = 1 } = config;\n /* eslint-enable */\n\n const queryLowered = q.toLowerCase();\n const filteredData = data.filter(\n (item) =>\n /* eslint-disable operator-linebreak, implicit-arrow-linebreak */\n item.full_name.toLowerCase().includes(queryLowered) ||\n item.post.toLowerCase().includes(queryLowered) ||\n item.email.toLowerCase().includes(queryLowered) ||\n item.age.toLowerCase().includes(queryLowered) ||\n item.salary.toLowerCase().includes(queryLowered) ||\n item.start_date.toLowerCase().includes(queryLowered)\n );\n /* eslint-enable */\n\n return [\n 200,\n {\n allData: data,\n invoices: paginateArray(filteredData, perPage, page),\n total: filteredData.length,\n },\n ];\n});\n","import mock from \"../mock\";\n\nconst data = {\n pricing: {\n basicPlan: {\n title: \"Basic\",\n img: require(\"@src/assets/images/illustration/Pot1.svg\").default,\n subtitle: \"A simple start for everyone\",\n monthlyPrice: 0,\n yearlyPlan: {\n perMonth: 0,\n totalAnnual: 0,\n },\n planBenefits: [\n \"100 responses a month\",\n \"Unlimited forms and surveys\",\n \"Unlimited fields\",\n \"Basic form creation tools\",\n \"Up to 2 subdomains\",\n ],\n popular: false,\n },\n standardPlan: {\n title: \"Standard\",\n img: require(\"@src/assets/images/illustration/Pot2.svg\").default,\n subtitle: \"For small to medium businesses\",\n monthlyPrice: 49,\n yearlyPlan: {\n perMonth: 40,\n totalAnnual: 480,\n },\n planBenefits: [\n \"Unlimited responses\",\n \"Unlimited forms and surveys\",\n \"Instagram profile page\",\n \"Google Docs integration\",\n \"Custom “Thank you” page\",\n ],\n popular: true,\n },\n enterprisePlan: {\n title: \"Enterprise\",\n img: require(\"@src/assets/images/illustration/Pot3.svg\").default,\n subtitle: \"Solution for big organizations\",\n monthlyPrice: 99,\n yearlyPlan: {\n perMonth: 80,\n totalAnnual: 960,\n },\n planBenefits: [\n \"PayPal payments\",\n \"Logic Jumps\",\n \"File upload with 5GB storage\",\n \"Custom domain support\",\n \"Stripe integration\",\n ],\n popular: false,\n },\n qandA: [\n {\n question: \"Does my subscription automatically renew?\",\n ans: \"Pastry pudding cookie toffee bonbon jujubes jujubes powder topping. Jelly beans gummi bears sweet roll bonbon muffin liquorice. Wafer lollipop sesame snaps. Brownie macaroon cookie muffin cupcake candy caramels tiramisu. Oat cake chocolate cake sweet jelly-o brownie biscuit marzipan. Jujubes donut marzipan chocolate bar. Jujubes sugar plum jelly beans tiramisu icing cheesecake.\",\n },\n {\n question: \"Can I store the item on an intranet so everyone has access?\",\n ans: \"Tiramisu marshmallow dessert halvah bonbon cake gingerbread. Jelly beans chocolate pie powder. Dessert pudding chocolate cake bonbon bear claw cotton candy cheesecake. Biscuit fruitcake macaroon carrot cake. Chocolate cake bear claw muffin chupa chups pudding.\",\n },\n {\n question: \"Am I allowed to modify the item that I purchased?\",\n ans: \"Tart gummies dragée lollipop fruitcake pastry oat cake. Cookie jelly jelly macaroon icing jelly beans soufflé cake sweet. Macaroon sesame snaps cheesecake tart cake sugar plum. Dessert jelly-o sweet muffin chocolate candy pie tootsie roll marzipan. Carrot cake marshmallow pastry. Bonbon biscuit pastry topping toffee dessert gummies. Topping apple pie pie croissant cotton candy dessert tiramisu.\",\n },\n ],\n },\n};\n\nmock.onGet(\"/pricing/data\").reply(() => [200, data.pricing]);\n","import mock from \"../mock\";\n\nexport const searchArr = [\n {\n groupTitle: \"Pages\",\n searchLimit: 4,\n data: [\n {\n id: 1,\n target: \"analyticsDash\",\n isBookmarked: false,\n title: \"Analytics Dashboard\",\n icon: \"Home\",\n link: \"/dashboard/analytics\",\n },\n {\n id: 2,\n target: \"eCommerceDash\",\n isBookmarked: false,\n title: \"eCommerce Dashboard\",\n icon: \"Home\",\n link: \"/\",\n },\n {\n id: 3,\n target: \"email\",\n isBookmarked: true,\n title: \"Email\",\n icon: \"Mail\",\n link: \"/apps/email\",\n },\n {\n id: 4,\n target: \"chat\",\n isBookmarked: true,\n title: \"Chat\",\n icon: \"MessageSquare\",\n link: \"/apps/chat\",\n },\n {\n id: 5,\n target: \"todo\",\n isBookmarked: true,\n title: \"Todo\",\n icon: \"CheckSquare\",\n link: \"/apps/todo\",\n },\n {\n id: 6,\n target: \"calendar\",\n isBookmarked: true,\n title: \"Calendar\",\n icon: \"Calendar\",\n link: \"/apps/calendar\",\n },\n {\n id: 7,\n target: \"invoiceList\",\n isBookmarked: false,\n title: \"Invoice List\",\n icon: \"List\",\n link: \"/apps/invoice/list\",\n },\n {\n id: 8,\n target: \"invoicePreview\",\n isBookmarked: false,\n title: \"Invoice Preview\",\n icon: \"FileText\",\n link: \"/apps/invoice/preview\",\n },\n {\n id: 9,\n target: \"invoiceEdit\",\n isBookmarked: false,\n title: \"Invoice Edit\",\n icon: \"Edit\",\n link: \"/apps/invoice/edit\",\n },\n {\n id: 10,\n target: \"invoiceAdd\",\n isBookmarked: false,\n title: \"Invoice Add\",\n icon: \"Plus\",\n link: \"/apps/invoice/add\",\n },\n {\n id: 11,\n target: \"shop\",\n isBookmarked: false,\n title: \"Shop Ecommerce\",\n icon: \"ShoppingCart\",\n link: \"/apps/ecommerce/shop\",\n },\n {\n id: 12,\n target: \"detail\",\n isBookmarked: false,\n title: \"Product Detail\",\n icon: \"Circle\",\n link: \"/apps/ecommerce/product-detail\",\n },\n {\n id: 13,\n target: \"wishList\",\n isBookmarked: false,\n title: \"Wish List\",\n icon: \"Heart\",\n link: \"/apps/ecommerce/wishlist\",\n },\n {\n id: 14,\n target: \"checkout\",\n isBookmarked: false,\n title: \"Checkout\",\n icon: \"CreditCard\",\n link: \"/apps/ecommerce/checkout\",\n },\n {\n id: 15,\n target: \"userList\",\n isBookmarked: false,\n title: \"User List\",\n icon: \"User\",\n link: \"/apps/user/list\",\n },\n {\n id: 16,\n target: \"userView\",\n isBookmarked: false,\n title: \"User View\",\n icon: \"User\",\n link: \"/apps/user/view\",\n },\n {\n id: 18,\n target: \"login-basic\",\n isBookmarked: false,\n title: \"Login Basic\",\n icon: \"LogIn\",\n link: \"/pages/login-basic\",\n },\n {\n id: 19,\n target: \"login-cover\",\n isBookmarked: false,\n title: \"Login Cover\",\n icon: \"LogIn\",\n link: \"/pages/login-cover\",\n },\n {\n id: 20,\n target: \"register-basic\",\n isBookmarked: false,\n title: \"Register Basic\",\n icon: \"UserPlus\",\n link: \"/pages/register-basic\",\n },\n {\n id: 21,\n target: \"register-cover\",\n isBookmarked: false,\n title: \"Register Cover\",\n icon: \"UserPlus\",\n link: \"/pages/register-cover\",\n },\n {\n id: 22,\n target: \"forgotPassword-basic\",\n isBookmarked: false,\n title: \"Forgot Password Basic\",\n icon: \"Crosshair\",\n link: \"/pages/forgot-password-basic\",\n },\n {\n id: 23,\n target: \"forgotPassword-cover\",\n isBookmarked: false,\n title: \"Forgot Password Cover\",\n icon: \"Crosshair\",\n link: \"/pages/forgot-password-cover\",\n },\n {\n id: 24,\n target: \"resetPassword-basic\",\n isBookmarked: false,\n title: \"Reset Password Basic\",\n icon: \"TrendingUp\",\n link: \"/pages/reset-password-basic\",\n },\n {\n id: 25,\n target: \"resetPassword-cover\",\n isBookmarked: false,\n title: \"Reset Password Cover\",\n icon: \"TrendingUp\",\n link: \"/pages/reset-password-cover\",\n },\n {\n id: 26,\n target: \"accountSettings\",\n isBookmarked: false,\n title: \"Account Settings\",\n icon: \"Settings\",\n link: \"/pages/account-settings\",\n },\n {\n id: 27,\n target: \"profile\",\n isBookmarked: false,\n title: \"Profile Page\",\n icon: \"Users\",\n link: \"/pages/profile\",\n collapsed: true,\n },\n {\n id: 28,\n target: \"faq\",\n isBookmarked: false,\n title: \"FAQ Page\",\n icon: \"Zap\",\n link: \"/pages/faq\",\n },\n {\n id: 29,\n target: \"knowledgeBase\",\n isBookmarked: false,\n title: \"Knowledge Base Page\",\n icon: \"AlignLeft\",\n link: \"/pages/knowledge-base\",\n },\n\n {\n id: 30,\n target: \"pricing\",\n isBookmarked: false,\n title: \"Pricing\",\n icon: \"DollarSign\",\n link: \"/pages/pricing\",\n },\n\n {\n id: 31,\n target: \"blogList\",\n isBookmarked: false,\n title: \"Blog List\",\n icon: \"List\",\n link: \"/pages/blog/list\",\n },\n {\n id: 32,\n target: \"blogDetail\",\n isBookmarked: false,\n title: \"Blog Details\",\n icon: \"FileText\",\n link: \"/pages/blog/detail\",\n },\n {\n id: 33,\n target: \"blogEdit\",\n isBookmarked: false,\n title: \"Blog Edit\",\n icon: \"Edit\",\n link: \"/pages/blog/edit\",\n },\n\n {\n id: 34,\n target: \"comingSoon\",\n isBookmarked: false,\n title: \"Coming Soon Page\",\n icon: \"Watch\",\n link: \"/misc/coming-soon\",\n },\n\n {\n id: 35,\n target: \"notAuthorized\",\n isBookmarked: false,\n title: \"Not Authorized Page\",\n icon: \"UserX\",\n link: \"/misc/not-authorized\",\n },\n {\n id: 36,\n target: \"maintenance\",\n isBookmarked: false,\n title: \"Maintenance Page\",\n icon: \"Aperture\",\n link: \"/misc/maintenance\",\n },\n {\n id: 37,\n target: \"error\",\n isBookmarked: false,\n title: \"Error\",\n icon: \"AlertTriangle\",\n link: \"/misc/error\",\n },\n {\n id: 38,\n target: \"typography\",\n isBookmarked: false,\n title: \"Typography\",\n icon: \"Type\",\n link: \"/ui-element/typography\",\n },\n {\n id: 39,\n target: \"colors\",\n isBookmarked: false,\n title: \"Colors\",\n icon: \"Feather\",\n link: \"/colors/colors\",\n },\n {\n id: 40,\n target: \"feather\",\n isBookmarked: false,\n title: \"Feather Icons\",\n icon: \"Feather\",\n link: \"/icons/reactfeather\",\n },\n {\n id: 41,\n target: \"basic\",\n isBookmarked: false,\n title: \"Card Basic\",\n icon: \"Square\",\n link: \"/cards/basic\",\n },\n {\n id: 42,\n target: \"cardAdvance\",\n isBookmarked: false,\n title: \"Card Advance\",\n icon: \"Tablet\",\n link: \"/cards/advance\",\n },\n {\n id: 43,\n target: \"cardStatistics\",\n isBookmarked: false,\n title: \"Card Statistics\",\n icon: \"Smartphone\",\n link: \"/cards/statistics\",\n },\n {\n id: 44,\n target: \"CardAnalytics\",\n isBookmarked: false,\n title: \"Card Analytics\",\n icon: \"BarChart2\",\n link: \"/cards/analytics\",\n },\n {\n id: 45,\n target: \"cardActions\",\n isBookmarked: false,\n title: \"Card Actions\",\n icon: \"Airplay\",\n link: \"/cards/action\",\n },\n {\n id: 46,\n target: \"alerts\",\n isBookmarked: false,\n title: \"Alerts\",\n icon: \"Info\",\n link: \"/components/alerts\",\n },\n {\n id: 47,\n target: \"autoComplete\",\n isBookmarked: false,\n title: \"Auto Complete\",\n icon: \"Search\",\n link: \"/components/auto-complete\",\n },\n {\n id: 48,\n target: \"avatar\",\n isBookmarked: false,\n title: \"Avatar\",\n icon: \"User\",\n link: \"/components/avatar\",\n },\n {\n id: 49,\n target: \"badges\",\n isBookmarked: false,\n title: \"Badges\",\n icon: \"Circle\",\n link: \"/components/badges\",\n },\n {\n id: 50,\n target: \"breadCrumbs\",\n isBookmarked: false,\n title: \"Breadcrumbs\",\n icon: \"MoreHorizontal\",\n link: \"/components/breadcrumbs\",\n },\n {\n id: 51,\n target: \"buttons\",\n isBookmarked: false,\n title: \"Buttons\",\n icon: \"Inbox\",\n link: \"/components/buttons\",\n },\n {\n id: 52,\n target: \"carousel\",\n isBookmarked: false,\n title: \"Carousel\",\n icon: \"Map\",\n link: \"/components/carousel\",\n },\n {\n id: 53,\n target: \"collapse\",\n isBookmarked: false,\n title: \"Collapse\",\n icon: \"Minimize\",\n link: \"/components/collapse\",\n },\n {\n id: 54,\n target: \"divider\",\n isBookmarked: false,\n title: \"Divider\",\n icon: \"Minus\",\n link: \"/components/divider\",\n },\n {\n id: 55,\n target: \"dropDowns\",\n isBookmarked: false,\n title: \"Dropdowns\",\n icon: \"Inbox\",\n link: \"/components/dropdowns\",\n },\n {\n id: 56,\n target: \"listGroup\",\n isBookmarked: false,\n title: \"List Group\",\n icon: \"Layers\",\n link: \"/components/list-group\",\n },\n {\n id: 58,\n target: \"modals\",\n isBookmarked: false,\n title: \"Modals\",\n icon: \"Maximize2\",\n link: \"/components/modals\",\n },\n {\n id: 59,\n target: \"navsComponent\",\n isBookmarked: false,\n title: \"Navs Component\",\n icon: \"MoreVertical\",\n link: \"/components/nav-component\",\n },\n {\n id: 60,\n target: \"pagination\",\n isBookmarked: false,\n title: \"Pagination\",\n icon: \"ChevronsRight\",\n link: \"/components/pagination\",\n },\n {\n id: 61,\n target: \"pillBadges\",\n isBookmarked: false,\n title: \"Pill Badges\",\n icon: \"Circle\",\n link: \"/components/pill-badges\",\n },\n {\n id: 62,\n target: \"pillsComponent\",\n isBookmarked: false,\n title: \"Pills Component\",\n icon: \"ToggleRight\",\n link: \"/components/pills-component\",\n },\n {\n id: 63,\n target: \"popovers\",\n isBookmarked: false,\n title: \"Popovers\",\n icon: \"MessageCircle\",\n link: \"/components/popovers\",\n },\n {\n id: 64,\n target: \"progress\",\n isBookmarked: false,\n title: \"Progress\",\n icon: \"Server\",\n link: \"/components/progress\",\n },\n {\n id: 65,\n target: \"spinners\",\n isBookmarked: false,\n title: \"Spinners\",\n icon: \"Sun\",\n link: \"/components/spinners\",\n },\n {\n id: 66,\n target: \"tabsComponent\",\n isBookmarked: false,\n title: \"Tabs Component\",\n icon: \"Server\",\n link: \"/components/tabs-component\",\n },\n {\n id: 67,\n target: \"timeline\",\n isBookmarked: false,\n title: \"Timeline\",\n icon: \"MoreVertical\",\n link: \"/components/timeline\",\n },\n {\n id: 68,\n target: \"toasts\",\n isBookmarked: false,\n title: \"Toasts\",\n icon: \"Triangle\",\n link: \"/components/toasts\",\n },\n {\n id: 69,\n target: \"tooltips\",\n isBookmarked: false,\n title: \"Tooltips\",\n icon: \"MessageCircle\",\n link: \"/components/tooltips\",\n },\n {\n id: 70,\n target: \"sweetAlert\",\n isBookmarked: false,\n title: \"Sweet Alerts\",\n icon: \"AlertTriangle\",\n link: \"/extensions/sweet-alert\",\n },\n {\n id: 71,\n target: \"blockui\",\n isBookmarked: false,\n title: \"BlockUI\",\n icon: \"Loader\",\n link: \"/components/blockui\",\n },\n {\n id: 72,\n target: \"toastr\",\n isBookmarked: false,\n title: \"Toastr\",\n icon: \"CreditCard\",\n link: \"/extensions/toastr\",\n },\n {\n id: 73,\n target: \"slider\",\n isBookmarked: false,\n title: \"Slider\",\n icon: \"Sliders\",\n link: \"/extensions/slider\",\n },\n {\n id: 74,\n target: \"drag_&_drop\",\n isBookmarked: false,\n title: \"Drag & Drop\",\n icon: \"Move\",\n link: \"/extensions/drag-and-drop\",\n },\n {\n id: 75,\n target: \"tour\",\n isBookmarked: false,\n title: \"Tour\",\n icon: \"Airplay\",\n link: \"/extensions/tour\",\n },\n {\n id: 76,\n target: \"clipBoard\",\n isBookmarked: false,\n title: \"Clipboard\",\n icon: \"Clipboard\",\n link: \"/extensions/clipboard\",\n },\n {\n id: 77,\n target: \"mediaPlayer\",\n isBookmarked: false,\n title: \"React Player\",\n icon: \"Film\",\n link: \"/extensions/react-player\",\n },\n {\n id: 78,\n target: \"contentMenu\",\n isBookmarked: false,\n title: \"Context Menu\",\n icon: \"Menu\",\n link: \"/extensions/context-menu\",\n },\n {\n id: 79,\n target: \"swiper\",\n isBookmarked: false,\n title: \"Swiper\",\n icon: \"Smartphone\",\n link: \"/extensions/swiper\",\n },\n {\n id: 81,\n target: \"ratings\",\n isBookmarked: false,\n title: \"Ratings\",\n icon: \"Star\",\n link: \"/extensions/ratings\",\n },\n {\n id: 82,\n target: \"i18n\",\n isBookmarked: false,\n title: \"I18n\",\n icon: \"Globe\",\n link: \"/extensions/i18n\",\n },\n {\n id: 83,\n target: \"access-control\",\n isBookmarked: false,\n title: \"Access Control\",\n icon: \"Lock\",\n link: \"/access-control\",\n },\n {\n id: 84,\n target: \"extPagination\",\n isBookmarked: false,\n title: \"React Paginate\",\n icon: \"MoreHorizontal\",\n link: \"/extensions/pagination\",\n },\n {\n id: 85,\n target: \"extImport\",\n isBookmarked: false,\n title: \"Import\",\n icon: \"DownloadCloud\",\n link: \"/extensions/import\",\n },\n {\n id: 86,\n target: \"extExport\",\n isBookmarked: false,\n title: \"Export\",\n icon: \"UploadCloud\",\n link: \"/extensions/export\",\n },\n {\n id: 87,\n target: \"extExportSelected\",\n isBookmarked: false,\n title: \"Export Selected\",\n icon: \"CheckSquare\",\n link: \"/extensions/export-selected\",\n },\n {\n id: 88,\n target: \"pageLayout-collapsedMenu\",\n isBookmarked: false,\n title: \"Collapsed Menu Page Layout\",\n icon: \"Layout\",\n link: \"/page-layout/collapse-menu\",\n },\n {\n id: 89,\n target: \"pageLayout-layoutBoxed\",\n isBookmarked: false,\n title: \"Boxed Page Layout\",\n icon: \"Layout\",\n link: \"/page-layout/layout-boxed\",\n },\n {\n id: 90,\n target: \"pageLayout-withoutMenu\",\n isBookmarked: false,\n title: \"Without Menu Page Layout\",\n icon: \"Layout\",\n link: \"/page-layout/without-menu\",\n },\n {\n id: 91,\n target: \"pageLayout-layoutEmpty\",\n isBookmarked: false,\n title: \"Empty Page Layout\",\n icon: \"Layout\",\n link: \"/page-layout/layout-empty\",\n },\n {\n id: 92,\n target: \"pageLayout-layoutBlank\",\n isBookmarked: false,\n title: \"Blank Page Layout\",\n icon: \"Layout\",\n link: \"/page-layout/layout-blank\",\n },\n {\n id: 93,\n target: \"input\",\n isBookmarked: false,\n title: \"Input\",\n icon: \"Server\",\n link: \"/forms/elements/input\",\n },\n {\n id: 94,\n target: \"inputGroup\",\n isBookmarked: false,\n title: \"Input Group\",\n icon: \"Package\",\n link: \"/forms/elements/input-group\",\n },\n {\n id: 95,\n target: \"inputMask\",\n isBookmarked: false,\n title: \"Input Mask\",\n icon: \"Copy\",\n link: \"/forms/elements/input-mask\",\n },\n {\n id: 96,\n target: \"textarea\",\n isBookmarked: false,\n title: \"Textarea\",\n icon: \"Edit2\",\n link: \"/forms/elements/textarea\",\n },\n {\n id: 97,\n target: \"checkbox\",\n isBookmarked: false,\n title: \"Checkbox\",\n icon: \"CheckSquare\",\n link: \"/forms/elements/checkbox\",\n },\n {\n id: 98,\n target: \"radio\",\n isBookmarked: false,\n title: \"Radio\",\n icon: \"StopCircle\",\n link: \"/forms/elements/radio\",\n },\n {\n id: 99,\n target: \"switch\",\n isBookmarked: false,\n title: \"Switch\",\n icon: \"ToggleLeft\",\n link: \"/forms/elements/switch\",\n },\n {\n id: 100,\n target: \"select\",\n isBookmarked: false,\n title: \"Select\",\n icon: \"Server\",\n link: \"/forms/elements/select\",\n },\n {\n id: 101,\n target: \"numberInput\",\n isBookmarked: false,\n title: \"Number Input\",\n icon: \"Plus\",\n link: \"/forms/elements/number-input\",\n },\n {\n id: 102,\n target: \"fileUploader\",\n isBookmarked: false,\n title: \"File Uploader\",\n icon: \"Upload\",\n link: \"/forms/elements/file-uploader\",\n },\n {\n id: 103,\n target: \"quillEditor\",\n isBookmarked: false,\n title: \"Editor\",\n icon: \"Edit3\",\n link: \"/forms/elements/editor\",\n },\n {\n id: 104,\n target: \"date_&_timePicker\",\n isBookmarked: false,\n title: \"Date & Time Picker\",\n icon: \"Calendar\",\n link: \"/forms/elements/pickers\",\n },\n {\n id: 105,\n target: \"formLayouts\",\n isBookmarked: false,\n title: \"Form Layouts\",\n icon: \"Layout\",\n link: \"/forms/layout/form-layout\",\n },\n {\n id: 106,\n target: \"wizard\",\n isBookmarked: false,\n title: \"Form Wizard\",\n icon: \"Sliders\",\n link: \"/forms/wizard\",\n },\n {\n id: 107,\n isBookmarked: false,\n icon: \"AlertTriangle\",\n target: \"formValidation\",\n title: \"Form Validation\",\n link: \"/forms/form-validation\",\n },\n {\n id: 109,\n target: \"formRepeater\",\n isBookmarked: false,\n title: \"Form Repeater\",\n icon: \"RotateCw\",\n link: \"/forms/form-repeater\",\n },\n {\n id: 110,\n target: \"tablesReactstrap\",\n isBookmarked: false,\n title: \"Reactstrap Tables\",\n icon: \"Grid\",\n link: \"/tables/reactstrap\",\n },\n {\n id: 111,\n target: \"dtBasic\",\n isBookmarked: false,\n title: \"Datatables Basic\",\n icon: \"Grid\",\n link: \"/datatables/basic\",\n },\n {\n id: 112,\n target: \"dtAdvance\",\n isBookmarked: false,\n title: \"Datatables Advance\",\n icon: \"Grid\",\n link: \"/datatables/advance\",\n },\n {\n id: 114,\n target: \"apex\",\n isBookmarked: false,\n title: \"Apex Charts\",\n icon: \"BarChart\",\n link: \"/charts/apex\",\n },\n {\n id: 115,\n target: \"chartJs\",\n isBookmarked: false,\n title: \"ChartJS\",\n icon: \"Activity\",\n link: \"/charts/chartjs\",\n },\n {\n id: 116,\n target: \"recharts\",\n isBookmarked: false,\n title: \"Recharts\",\n icon: \"BarChart2\",\n link: \"/charts/recharts\",\n },\n {\n id: 118,\n target: \"roles\",\n isBookmarked: false,\n title: \"Roles\",\n icon: \"Shield\",\n link: \"/apps/roles\",\n },\n {\n id: 119,\n target: \"permissions\",\n isBookmarked: false,\n title: \"Permissions\",\n icon: \"Shield\",\n link: \"/apps/permissions\",\n },\n {\n id: 120,\n target: \"license\",\n isBookmarked: false,\n title: \"License\",\n icon: \"CreditCard\",\n link: \"/pages/license\",\n },\n {\n id: 121,\n target: \"apiKey\",\n isBookmarked: false,\n title: \"API Key\",\n icon: \"Key\",\n link: \"/pages/api-key\",\n },\n {\n id: 122,\n target: \"accordion\",\n isBookmarked: false,\n title: \"Accordion\",\n icon: \"AlignJustify\",\n link: \"/components/accordion\",\n },\n {\n id: 123,\n target: \"offCanvas\",\n isBookmarked: false,\n title: \"OffCanvas\",\n icon: \"Layout\",\n link: \"/components/offcanvas\",\n },\n {\n id: 123,\n target: \"offCanvas\",\n isBookmarked: false,\n title: \"OffCanvas\",\n icon: \"Layout\",\n link: \"/components/offcanvas\",\n },\n {\n id: 124,\n target: \"modalExamples\",\n isBookmarked: false,\n title: \"Modal Examples\",\n icon: \"Square\",\n link: \"/pages/modal-examples\",\n },\n {\n id: 125,\n icon: \"AtSign\",\n isBookmarked: false,\n target: \"verifyEmailBasic\",\n title: \"Verify Email Basic\",\n link: \"/pages/verify-email-basic\",\n },\n {\n id: 126,\n icon: \"AtSign\",\n isBookmarked: false,\n target: \"verifyEmailCover\",\n title: \"Verify Email Cover\",\n link: \"/pages/verify-email-cover\",\n },\n {\n id: 127,\n icon: \"HelpCircle\",\n isBookmarked: false,\n target: \"TwoStepBasic\",\n link: \"/pages/two-steps-basic\",\n title: \"Two Step Verification Basic\",\n },\n {\n id: 128,\n icon: \"HelpCircle\",\n isBookmarked: false,\n target: \"TwoStepCover\",\n link: \"/pages/two-steps-cover\",\n title: \"Two Step Verification Cover\",\n },\n ],\n },\n {\n groupTitle: \"Files\",\n searchLimit: 4,\n data: [\n {\n title: \"Passport Image\",\n by: \"Oliver Queen\",\n size: \"52kb\",\n file: require(\"@src/assets/images/icons/jpg.png\").default,\n },\n {\n title: \"Parenting Guide\",\n by: \"Alfred Pennyworth\",\n size: \"2.3mb\",\n file: require(\"@src/assets/images/icons/doc.png\").default,\n },\n {\n title: \"Class Notes\",\n by: \"Barry Allen\",\n size: \"30kb\",\n file: require(\"@src/assets/images/icons/doc.png\").default,\n },\n {\n title: \"Class Attendance\",\n by: \"Walter White\",\n size: \"52mb\",\n file: require(\"@src/assets/images/icons/xls.png\").default,\n },\n ],\n },\n {\n groupTitle: \"Contacts\",\n searchLimit: 4,\n data: [\n {\n title: \"Mia Davis\",\n email: \"miadavis@teleworm.us\",\n img: require(\"@src/assets/images/portrait/small/avatar-s-8.jpg\")\n .default,\n date: \"01/03/2020\",\n },\n {\n title: \"Norris Carrière\",\n email: \"NorrisCarriere@rhyta.com\",\n img: require(\"@src/assets/images/portrait/small/avatar-s-3.jpg\")\n .default,\n date: \"07/03/2020\",\n },\n {\n title: \"Charlotte Gordon\",\n email: \"CharlotteGordon@jourrapide.com\",\n img: require(\"@src/assets/images/portrait/small/avatar-s-26.jpg\")\n .default,\n date: \"14/03/2020\",\n },\n {\n title: \"Robert Nash\",\n email: \"RobertNash@dayrep.com\",\n img: require(\"@src/assets/images/portrait/small/avatar-s-25.jpg\")\n .default,\n date: \"21/03/2020\",\n },\n ],\n },\n];\n\n// GET Search Data\nmock.onGet(\"/api/main-search/data\").reply(() => {\n return [200, { searchArr }];\n});\n\n// GET Search Data & Bookmarks\nmock.onGet(\"/api/bookmarks/data\").reply(() => {\n const bookmarks = searchArr[0].data.filter((item) => item.isBookmarked);\n const suggestions = searchArr[0].data;\n return [200, { suggestions, bookmarks }];\n});\n\n// POST Update isBookmarked\nmock.onPost(\"/api/bookmarks/update\").reply((config) => {\n const { id } = JSON.parse(config.data);\n\n const obj = searchArr[0].data.find((item) => item.id === id);\n\n Object.assign(obj, { isBookmarked: !obj.isBookmarked });\n\n return [200];\n});\n","import mock from \"../mock\";\n\nconst data = {\n // knowledge base\n knowledgeBase: [\n {\n id: 1,\n category: \"sales-automation\",\n img: require(\"@src/assets/images/illustration/sales.svg\").default,\n title: \"Sales Automation\",\n desc: \"There is perhaps no better demonstration of the folly of image of our tiny world.\",\n },\n {\n id: 2,\n category: \"marketing-automation\",\n img: require(\"@src/assets/images/illustration/marketing.svg\").default,\n title: \"Marketing Automation\",\n desc: \"Look again at that dot. That’s here. That’s home. That’s us. On it everyone you love.\",\n },\n {\n id: 3,\n category: \"api-questions\",\n img: require(\"@src/assets/images/illustration/api.svg\").default,\n title: \"API Questions\",\n desc: \"every hero and coward, every creator and destroyer of civilization.\",\n },\n {\n id: 4,\n category: \"personalization\",\n img: require(\"@src/assets/images/illustration/personalization.svg\")\n .default,\n title: \"Personalization\",\n desc: \"It has been said that astronomy is a humbling and character experience.\",\n },\n {\n id: 5,\n category: \"email-marketing\",\n img: require(\"@src/assets/images/illustration/email.svg\").default,\n title: \"Email Marketing\",\n desc: \"There is perhaps no better demonstration of the folly of human conceits.\",\n },\n {\n id: 6,\n category: \"demand-generation\",\n img: require(\"@src/assets/images/illustration/demand.svg\").default,\n title: \"Demand Generation\",\n desc: \"Competent means we will never take anything for granted.\",\n },\n ],\n categoryData: [\n {\n id: 0,\n title: \"Account Settings\",\n icon: \"Settings\",\n iconColor: \"text-primary\",\n questions: [\n {\n id: 0,\n question: \"How Secure Is My Password?\",\n slug: \"how-secure-is-my-password\",\n },\n {\n id: 1,\n question: \"Can I Change My Username?\",\n slug: \"can-i-change-my-username\",\n },\n {\n id: 2,\n question: \"Where Can I Upload My Avatar?\",\n slug: \"where-can-i-upload-my-avatar\",\n },\n {\n id: 3,\n question: \"How Do I Change My Timezone?\",\n slug: \"how-do-i-change-my-timezone\",\n },\n {\n id: 4,\n question: \"How Do I Change My Password?\",\n slug: \"how-do-i-change-my-password\",\n },\n ],\n },\n {\n id: 1,\n title: \"API Questions\",\n icon: \"Link\",\n iconColor: \"text-success\",\n questions: [\n {\n id: 0,\n question: \"What Technologies Are Used?\",\n slug: \"what-technologies-are-used\",\n },\n {\n id: 1,\n question: \"What Are The API Limits?\",\n slug: \"what-are-the-api-limits\",\n },\n {\n id: 2,\n question: \"Why Was My Application Rejected?\",\n slug: \"why-was-my-application-rejected?\",\n },\n {\n id: 3,\n question: \"Where can I find the documentation?\",\n slug: \"where-can-i-find-the-documentation\",\n },\n {\n id: 4,\n question: \"How Do I Get An API Key?\",\n slug: \"how-do-i-get-an-api-key?\",\n },\n ],\n },\n {\n id: 2,\n title: \"Billing\",\n icon: \"FileText\",\n iconColor: \"text-danger\",\n questions: [\n {\n id: 0,\n question: \"Can I Contact A Salés Rep?\",\n slug: \"can-i-contact-a-salés-rep\",\n },\n {\n id: 1,\n question: \"Do I Need To Pay VAT?\",\n slug: \"do-i-needto-pay-vat\",\n },\n {\n id: 2,\n question: \"Can I Get A Refund?\",\n slug: \"can-i-get-a-refund\",\n },\n {\n id: 3,\n question: \"Difference Annual & Monthly Billing\",\n slug: \"difference-annual-monthly-billing\",\n },\n {\n id: 4,\n question: \"What Happens If The Price Increases?\",\n slug: \"what-happens-if-the-price-increases?\",\n },\n ],\n },\n {\n id: 3,\n title: \"Copyright & Legal\",\n icon: \"Lock\",\n iconColor: \"text-warning\",\n questions: [\n {\n id: 0,\n question: \"How Do I Contact Legal?\",\n slug: \"how-do-i-contact-legal\",\n },\n {\n id: 1,\n question: \"Where Are Your Offices Located?\",\n slug: \"where-are-your-offices-located\",\n },\n {\n id: 2,\n question: \"Who Owns The Copyright On Text?\",\n slug: \"who-owns-the-copyright-on-text\",\n },\n {\n id: 3,\n question: \"Our Content Policy\",\n slug: \"our-content-policy\",\n },\n {\n id: 4,\n question: \"How Do I File A DMCA?\",\n slug: \"how-do-i-file-a-dmca\",\n },\n ],\n },\n {\n id: 4,\n title: \"Mobile Apps\",\n icon: \"Smartphone\",\n iconColor: \"text-info\",\n questions: [\n {\n id: 0,\n question: \"How Do I Download The Android App?\",\n slug: \"how-do-i-download-the-android-app\",\n },\n {\n id: 1,\n question: \"How To Download Our iPad App\",\n slug: \"how-to-download-our-ipad-app\",\n },\n {\n id: 2,\n question: \"Where Can I Upload My Avatar?\",\n slug: \"where-can-i-upload-my-avatar\",\n },\n {\n id: 3,\n question: \"Can I Use My Android Phone?\",\n slug: \"can-i-use-my-android-phone\",\n },\n {\n id: 4,\n question: \"Is There An iOS App?\",\n slug: \"is-there-an-ios-app\",\n },\n ],\n },\n {\n id: 5,\n title: \"Using KnowHow\",\n icon: \"HelpCircle\",\n iconColor: \"\",\n questions: [\n {\n id: 0,\n question: \"Customization\",\n slug: \"customization\",\n },\n {\n id: 1,\n question: \"Upgrading\",\n slug: \"upgrading\",\n },\n {\n id: 2,\n question: \"Customizing Your Theme\",\n slug: \"customizing-your-theme\",\n },\n {\n id: 3,\n question: \"Upgrading Your Theme\",\n slug: \"upgrading-your-theme\",\n },\n ],\n },\n ],\n questionData: {\n title: \"Why Was My Developer Application Rejected?\",\n lastUpdated: \"10 Dec 2018\",\n relatedQuestions: [\n {\n id: 0,\n question: \"How Secure Is My Password?\",\n },\n {\n id: 1,\n question: \"Can I Change My Username?\",\n },\n {\n id: 2,\n question: \"Where Can I Upload My Avatar?\",\n },\n {\n id: 3,\n question: \"How Do I Change My Timezone?\",\n },\n {\n id: 4,\n question: \"How Do I Change My Password?\",\n },\n ],\n // ! Here we have used require for image source but in API it shall be URL of live image, this is just for demo purpose\n content: `It has been said that astronomy is a humbling and character-building experience. There is perhaps no better demonstration of the folly of human conceits than this distant image of our tiny world. To me, it underscores our responsibility to deal more kindly with one another, and to preserve and cherish the pale blue dot, the only home we’ve ever known. The Earth is a very small stage in a vast cosmic arena. Think of the rivers of blood spilled by all those generals and emperors so that, in glory and triumph, they could become the momentary masters of a fraction of a dot. Think of the endless cruelties visited by the inhabitants of one corner of this pixel on the scarcely distinguishable inhabitants of some other corner, how frequent their misunderstandings, how eager they are to kill one another, how fervent their hatreds.
Houston that may have seemed like a very long final phase. The auto targeting was taking us right into a … crater, with a large number of big boulders and rocks … and it required …flying manually over the rock field to find a reasonably good area.
`,\n },\n};\n\nmock.onGet(\"/faq/data/knowledge_base\").reply(() => [200, data.knowledgeBase]);\nmock.onGet(\"/faq/data/category\").reply(() => [200, data.categoryData]);\nmock.onGet(\"/faq/data/question\").reply(() => [200, data.questionData]);\n","import mock from \"../mock\";\n\n// ** Utils\nimport { paginateArray } from \"../utils\";\n\nconst data = {\n permissions: [\n {\n id: 1,\n name: \"Management\",\n assignedTo: [\"administrator\"],\n createdDate: \"14 Apr 2021, 8:43 PM\",\n },\n {\n id: 2,\n assignedTo: [\"administrator\"],\n name: \"Manage Billing & Roles\",\n createdDate: \"16 Sep 2021, 5:20 PM\",\n },\n {\n id: 3,\n name: \"Add & Remove Users\",\n createdDate: \"14 Oct 2021, 10:20 AM\",\n assignedTo: [\"administrator\", \"manager\"],\n },\n {\n id: 4,\n name: \"Project Planning\",\n createdDate: \"14 Oct 2021, 10:20 AM\",\n assignedTo: [\"administrator\", \"user\", \"support\"],\n },\n {\n id: 5,\n name: \"Manage Email Sequences\",\n createdDate: \"23 Aug 2021, 2:00 PM\",\n assignedTo: [\"administrator\", \"user\", \"support\"],\n },\n {\n id: 6,\n name: \"Client Communication\",\n createdDate: \"15 Apr 2021, 11:30 AM\",\n assignedTo: [\"administrator\", \"manager\"],\n },\n {\n id: 7,\n name: \"Only View\",\n createdDate: \"04 Dec 2021, 8:15 PM\",\n assignedTo: [\"administrator\", \"restricted-user\"],\n },\n {\n id: 8,\n name: \"Financial Management\",\n createdDate: \"25 Feb 2021, 10:30 AM\",\n assignedTo: [\"administrator\", \"manager\"],\n },\n {\n id: 9,\n name: \"Manage Others’ Tasks\",\n createdDate: \"04 Nov 2021, 11:45 AM\",\n assignedTo: [\"administrator\", \"support\"],\n },\n ],\n};\n\n// ------------------------------------------------\n// GET: Return Permissions List\n// ------------------------------------------------\nmock.onGet(\"/apps/permissions/data\").reply((config) => {\n const { q = \"\", perPage = 10, page = 1, assignedTo = \"\" } = config.params;\n const queryLowered = q.toLowerCase();\n const filteredData = data.permissions.filter((permission) => {\n if (assignedTo !== \"\") {\n return (\n (permission.name.toLowerCase().includes(queryLowered) ||\n permission.createdDate.toLowerCase().includes(queryLowered)) &&\n permission.assignedTo.includes(assignedTo)\n );\n } else {\n return (\n permission.name.toLowerCase().includes(queryLowered) ||\n permission.createdDate.toLowerCase().includes(queryLowered)\n );\n }\n });\n\n return [\n 200,\n {\n params: config.params,\n allData: data.permissions,\n total: filteredData.length,\n permissions: paginateArray(filteredData, perPage, page),\n },\n ];\n});\n\n// POST: Add new permission\nmock.onPost(\"/apps/permissions/add-permission\").reply((config) => {\n // Get permission from post data\n const permission = JSON.parse(config.data).permission;\n\n const { length } = data.permissions;\n let lastIndex = 0;\n if (length) {\n lastIndex = data.permissions[length - 1].id;\n }\n permission.id = lastIndex + 1;\n\n permission.assignedTo = [\"administrator\"];\n\n const now = new Date();\n const months = now\n .toLocaleDateString(\"en-US\", {\n year: \"numeric\",\n month: \"short\",\n day: \"numeric\",\n })\n .replace(\",\", \"\");\n const time = now.toLocaleString(\"en-US\", {\n hour: \"numeric\",\n minute: \"numeric\",\n hour12: true,\n });\n\n const monthsArr = months.split(\" \");\n /*eslint-disable */\n const moveElement = (array, sourceIndex, destinationIndex) => {\n return array.map((a) =>\n a === sourceIndex\n ? array.find((a) => a === destinationIndex)\n : a === destinationIndex\n ? array.find((a) => a === sourceIndex)\n : a\n );\n };\n\n const finalDate = moveElement(monthsArr, monthsArr[0], monthsArr[1]).join(\n \" \"\n );\n\n permission.createdDate = `${finalDate}, ${time}`;\n\n data.permissions.unshift(permission);\n\n return [201, { permission }];\n});\n\nmock.onPost(\"/apps/permissions/update-permission\").reply((config) => {\n // Get permission from post data\n const { id, name } = JSON.parse(config.data);\n\n data.permissions.find((i) => {\n if (i.id === id) {\n i.name = name;\n }\n });\n\n return [201];\n});\n\n// DELETE: Deletes Permissions\nmock.onDelete(\"/apps/permissions/delete\").reply((config) => {\n // Get id from URL\n let permissionID = config.id;\n\n // Convert Id to number\n permissionID = Number(permissionID);\n\n const permissionIndex = data.permissions.findIndex(\n (t) => t.id === permissionID\n );\n data.permissions.splice(permissionIndex, 1);\n\n return [200];\n});\n","import mock from \"../mock\";\n\nconst data = {\n support_tracker: {\n title: \"Support Tracker\",\n last_days: [\"Last 28 Days\", \"Last Month\", \"Last Year\"],\n totalTicket: 163,\n newTicket: 29,\n openTicket: 63,\n responseTime: 1,\n },\n avg_sessions: {\n sessions: 2700,\n last_days: [\"Last 28 Days\", \"Last Month\", \"Last Year\"],\n growth: \"+5.2%\",\n goal: 100000,\n users: 100000,\n retention: 90,\n duration: 1,\n },\n revenue_report: {\n years: [\"2020\", \"2019\", \"2018\"],\n price: \"25,852\",\n budget: \"56,800\",\n },\n goal_overview: {\n completed: \"786,617\",\n inProgress: \"13,561\",\n },\n revenue: {\n thisMonth: \"86,589\",\n lastMonth: \"73,683\",\n },\n product_orders: {\n last_days: [\"Last 28 Days\", \"Last Month\", \"Last Year\"],\n chart_info: { finished: 23043, pending: 14658, rejected: 4758 },\n },\n sessions_device: {\n last_days: [\"Last 28 Days\", \"Last Month\", \"Last Year\"],\n chart_info: [\n {\n icon: \"Monitor\",\n name: \"Desktop\",\n iconColor: \"text-primary\",\n usage: 58.6,\n upDown: 2,\n },\n {\n icon: \"Tablet\",\n name: \"Mobile\",\n iconColor: \"text-warning\",\n usage: 34.9,\n upDown: 8,\n },\n {\n icon: \"Tablet\",\n name: \"Tablet\",\n iconColor: \"text-danger\",\n usage: 6.5,\n upDown: -5,\n },\n ],\n },\n customers: {\n last_days: [\"Last 28 Days\", \"Last Month\", \"Last Year\"],\n listData: [\n {\n icon: \"Circle\",\n iconColor: \"text-primary\",\n text: \"New\",\n result: 690,\n },\n {\n icon: \"Circle\",\n iconColor: \"text-warning\",\n text: \"Returning\",\n result: 258,\n },\n {\n icon: \"Circle\",\n iconColor: \"text-danger\",\n text: \"Referrals\",\n result: 149,\n },\n ],\n },\n};\n\nmock\n .onGet(\"/card/card-analytics/support-tracker\")\n .reply(() => [200, data.support_tracker]);\nmock\n .onGet(\"/card/card-analytics/avg-sessions\")\n .reply(() => [200, data.avg_sessions]);\nmock\n .onGet(\"/card/card-analytics/revenue-report\")\n .reply(() => [200, data.revenue_report]);\nmock\n .onGet(\"/card/card-analytics/goal-overview\")\n .reply(() => [200, data.goal_overview]);\nmock.onGet(\"/card/card-analytics/revenue\").reply(() => [200, data.revenue]);\nmock\n .onGet(\"/card/card-analytics/product-orders\")\n .reply(() => [200, data.product_orders]);\nmock\n .onGet(\"/card/card-analytics/sessions-device\")\n .reply(() => [200, data.sessions_device]);\nmock.onGet(\"/card/card-analytics/customers\").reply(() => [200, data.customers]);\n","import mock from \"../mock\";\n\nconst data = {\n orders_bar_chart: {\n title: \"Orders\",\n statistics: \"2,76k\",\n series: [\n {\n name: \"2020\",\n data: [45, 85, 65, 45, 65],\n },\n ],\n },\n profit_line_chart: {\n title: \"Profit\",\n statistics: \"6,24k\",\n series: [\n {\n data: [0, 20, 5, 30, 15, 45],\n },\n ],\n },\n subscribers_gained: {\n series: [\n {\n name: \"Subscribers\",\n data: [28, 40, 36, 52, 38, 60, 55],\n },\n ],\n analyticsData: {\n subscribers: 92600,\n },\n },\n revenueGenerated: {\n series: [\n {\n name: \"Revenue\",\n data: [350, 275, 400, 300, 350, 300, 450],\n },\n ],\n analyticsData: {\n revenue: 97500,\n },\n },\n quarterlySales: {\n series: [\n {\n name: \"Sales\",\n data: [10, 15, 7, 12, 3, 16],\n },\n ],\n analyticsData: {\n sales: \"36%\",\n },\n },\n ordersRecevied: {\n series: [\n {\n name: \"Orders\",\n data: [10, 15, 8, 15, 7, 12, 8],\n },\n ],\n analyticsData: {\n orders: 97500,\n },\n },\n siteTraffic: {\n series: [\n {\n name: \"Traffic Rate\",\n data: [150, 200, 125, 225, 200, 250],\n },\n ],\n },\n activeUsers: {\n series: [\n {\n name: \"Active Users\",\n data: [750, 1000, 900, 1250, 1000, 1200, 1100],\n },\n ],\n },\n newsletter: {\n series: [\n {\n name: \"Newsletter\",\n data: [365, 390, 365, 400, 375, 400],\n },\n ],\n },\n};\n\nmock\n .onGet(\"/card/card-statistics/orders-bar-chart\")\n .reply(() => [200, data.orders_bar_chart]);\n\nmock\n .onGet(\"/card/card-statistics/profit-line-chart\")\n .reply(() => [200, data.profit_line_chart]);\n\nmock\n .onGet(\"/card/card-statistics/subscribers\")\n .reply(() => [200, data.subscribers_gained]);\n\nmock\n .onGet(\"/card/card-statistics/revenue\")\n .reply(() => [200, data.revenueGenerated]);\n\nmock\n .onGet(\"/card/card-statistics/sales\")\n .reply(() => [200, data.quarterlySales]);\n\nmock\n .onGet(\"/card/card-statistics/orders\")\n .reply(() => [200, data.ordersRecevied]);\n\nmock\n .onGet(\"/card/card-statistics/site-traffic\")\n .reply(() => [200, data.siteTraffic]);\n\nmock\n .onGet(\"/card/card-statistics/active-users\")\n .reply(() => [200, data.activeUsers]);\n\nmock\n .onGet(\"/card/card-statistics/newsletter\")\n .reply(() => [200, data.newsletter]);\n","import mock from \"../mock\";\nconst data = {\n accountSetting: {\n general: {\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-11.jpg\")\n .default,\n username: \"johndoe\",\n fullName: \"John Doe\",\n email: \"granger007@hogward.com\",\n company: \"PIXINVENT\",\n },\n info: {\n bio: \"\",\n dob: null,\n country: \"USA\",\n website: \"\",\n phone: 6562542568,\n },\n social: {\n socialLinks: {\n twitter: \"https://www.twitter.com\",\n facebook: \"\",\n google: \"\",\n linkedIn: \"https://www.linkedin.com\",\n instagram: \"\",\n quora: \"\",\n },\n connections: {\n twitter: {\n profileImg: require(\"@src/assets/images/avatars/11-small.png\")\n .default,\n id: \"johndoe\",\n },\n google: {\n profileImg: require(\"@src/assets/images/avatars/3-small.png\").default,\n id: \"luraweber\",\n },\n facebook: {},\n github: {},\n },\n },\n notification: {\n commentOnArticle: true,\n answerOnForm: true,\n followMe: false,\n newAnnouncements: true,\n productUpdates: true,\n blogDigest: false,\n },\n },\n};\n\nmock.onGet(\"/account-setting/data\").reply(() => [200, data.accountSetting]);\n","import mock from \"../mock\";\n\nconst autoComplete = [\n {\n title: \"The Shawshank Redemption\",\n rank: \"1\",\n id: \"tt0111161\",\n },\n {\n title: \"The Godfather\",\n rank: \"2\",\n id: \"tt0068646\",\n },\n {\n title: \"The Godfather: Part II\",\n rank: \"3\",\n id: \"tt0071562\",\n },\n {\n title: \"Pulp Fiction\",\n rank: \"4\",\n id: \"tt0110912\",\n },\n {\n title: \"The Good, the Bad and the Ugly\",\n rank: \"5\",\n id: \"tt0060196\",\n },\n {\n title: \"The Dark Knight\",\n rank: \"6\",\n id: \"tt0468569\",\n },\n {\n title: \"12 Angry Men\",\n rank: \"7\",\n id: \"tt0050083\",\n },\n {\n title: \"Schindler's List\",\n rank: \"8\",\n id: \"tt0108052\",\n },\n {\n title: \"The Lord of the Rings: The Return of the King\",\n rank: \"9\",\n id: \"tt0167260\",\n },\n {\n title: \"Fight Club\",\n rank: \"10\",\n id: \"tt0137523\",\n },\n {\n title: \"Star Wars: Episode V - The Empire Strikes Back\",\n rank: \"11\",\n id: \"tt0080684\",\n },\n {\n title: \"The Lord of the Rings: The Fellowship of the Ring\",\n rank: \"12\",\n id: \"tt0120737\",\n },\n {\n title: \"One Flew Over the Cuckoo's Nest\",\n rank: \"13\",\n id: \"tt0073486\",\n },\n {\n title: \"Inception\",\n rank: \"14\",\n id: \"tt1375666\",\n },\n {\n title: \"Goodfellas\",\n rank: \"15\",\n id: \"tt0099685\",\n },\n {\n title: \"Star Wars\",\n rank: \"16\",\n id: \"tt0076759\",\n },\n {\n title: \"Seven Samurai\",\n rank: \"17\",\n id: \"tt0047478\",\n },\n {\n title: \"Forrest Gump\",\n rank: \"18\",\n id: \"tt0109830\",\n },\n {\n title: \"The Matrix\",\n rank: \"19\",\n id: \"tt0133093\",\n },\n {\n title: \"The Lord of the Rings: The Two Towers\",\n rank: \"20\",\n id: \"tt0167261\",\n },\n {\n title: \"City of God\",\n rank: \"21\",\n id: \"tt0317248\",\n },\n {\n title: \"Se7en\",\n rank: \"22\",\n id: \"tt0114369\",\n },\n {\n title: \"The Silence of the Lambs\",\n rank: \"23\",\n id: \"tt0102926\",\n },\n {\n title: \"Once Upon a Time in the West\",\n rank: \"24\",\n id: \"tt0064116\",\n },\n {\n title: \"Casablanca\",\n rank: \"25\",\n id: \"tt0034583\",\n },\n {\n title: \"The Usual Suspects\",\n rank: \"26\",\n id: \"tt0114814\",\n },\n {\n title: \"Raiders of the Lost Ark\",\n rank: \"27\",\n id: \"tt0082971\",\n },\n {\n title: \"Rear Window\",\n rank: \"28\",\n id: \"tt0047396\",\n },\n {\n title: \"It's a Wonderful Life\",\n rank: \"29\",\n id: \"tt0038650\",\n },\n {\n title: \"Psycho\",\n rank: \"30\",\n id: \"tt0054215\",\n },\n {\n title: \"Léon: The Professional\",\n rank: \"31\",\n id: \"tt0110413\",\n },\n {\n title: \"Sunset Blvd.\",\n rank: \"32\",\n id: \"tt0043014\",\n },\n {\n title: \"American History X\",\n rank: \"33\",\n id: \"tt0120586\",\n },\n {\n title: \"Apocalypse Now\",\n rank: \"34\",\n id: \"tt0078788\",\n },\n {\n title: \"Terminator 2: Judgment Day\",\n rank: \"35\",\n id: \"tt0103064\",\n },\n {\n title: \"Saving Private Ryan\",\n rank: \"36\",\n id: \"tt0120815\",\n },\n {\n title: \"Memento\",\n rank: \"37\",\n id: \"tt0209144\",\n },\n {\n title: \"City Lights\",\n rank: \"38\",\n id: \"tt0021749\",\n },\n {\n title:\n \"Dr. Strangelove or: How I Learned to Stop Worrying and Love the Bomb\",\n rank: \"39\",\n id: \"tt0057012\",\n },\n {\n title: \"Alien\",\n rank: \"40\",\n id: \"tt0078748\",\n },\n {\n title: \"Modern Times\",\n rank: \"41\",\n id: \"tt0027977\",\n },\n {\n title: \"Spirited Away\",\n rank: \"42\",\n id: \"tt0245429\",\n },\n {\n title: \"North by Northwest\",\n rank: \"43\",\n id: \"tt0053125\",\n },\n {\n title: \"Back to the Future\",\n rank: \"44\",\n id: \"tt0088763\",\n },\n {\n title: \"Life Is Beautiful\",\n rank: \"45\",\n id: \"tt0118799\",\n },\n {\n title: \"The Shining\",\n rank: \"46\",\n id: \"tt0081505\",\n },\n {\n title: \"The Pianist\",\n rank: \"47\",\n id: \"tt0253474\",\n },\n {\n title: \"Citizen Kane\",\n rank: \"48\",\n id: \"tt0033467\",\n },\n {\n title: \"The Departed\",\n rank: \"49\",\n id: \"tt0407887\",\n },\n {\n title: \"M\",\n rank: \"50\",\n id: \"tt0022100\",\n },\n {\n title: \"Paths of Glory\",\n rank: \"51\",\n id: \"tt0050825\",\n },\n {\n title: \"Vertigo\",\n rank: \"52\",\n id: \"tt0052357\",\n },\n {\n title: \"Django Unchained\",\n rank: \"53\",\n id: \"tt1853728\",\n },\n {\n title: \"Double Indemnity\",\n rank: \"54\",\n id: \"tt0036775\",\n },\n {\n title: \"The Dark Knight Rises\",\n rank: \"55\",\n id: \"tt1345836\",\n },\n {\n title: \"Aliens\",\n rank: \"56\",\n id: \"tt0090605\",\n },\n {\n title: \"Taxi Driver\",\n rank: \"57\",\n id: \"tt0075314\",\n },\n {\n title: \"American Beauty\",\n rank: \"58\",\n id: \"tt0169547\",\n },\n {\n title: \"The Green Mile\",\n rank: \"59\",\n id: \"tt0120689\",\n },\n {\n title: \"Gladiator\",\n rank: \"60\",\n id: \"tt0172495\",\n },\n {\n title: \"The Intouchables\",\n rank: \"61\",\n id: \"tt1675434\",\n },\n {\n title: \"WALL·E\",\n rank: \"62\",\n id: \"tt0910970\",\n },\n {\n title: \"The Lives of Others\",\n rank: \"63\",\n id: \"tt0405094\",\n },\n {\n title: \"Toy Story 3\",\n rank: \"64\",\n id: \"tt0435761\",\n },\n {\n title: \"The Great Dictator\",\n rank: \"65\",\n id: \"tt0032553\",\n },\n {\n title: \"The Prestige\",\n rank: \"66\",\n id: \"tt0482571\",\n },\n {\n title: \"A Clockwork Orange\",\n rank: \"67\",\n id: \"tt0066921\",\n },\n {\n title: \"Lawrence of Arabia\",\n rank: \"68\",\n id: \"tt0056172\",\n },\n {\n title: \"Amélie\",\n rank: \"69\",\n id: \"tt0211915\",\n },\n {\n title: \"To Kill a Mockingbird\",\n rank: \"70\",\n id: \"tt0056592\",\n },\n {\n title: \"Reservoir Dogs\",\n rank: \"71\",\n id: \"tt0105236\",\n },\n {\n title: \"Das Boot\",\n rank: \"72\",\n id: \"tt0082096\",\n },\n {\n title: \"The Lion King\",\n rank: \"73\",\n id: \"tt0110357\",\n },\n {\n title: \"Cinema Paradiso\",\n rank: \"74\",\n id: \"tt0095765\",\n },\n {\n title: \"Star Wars: Episode VI - Return of the Jedi\",\n rank: \"75\",\n id: \"tt0086190\",\n },\n {\n title: \"The Treasure of the Sierra Madre\",\n rank: \"76\",\n id: \"tt0040897\",\n },\n {\n title: \"The Third Man\",\n rank: \"77\",\n id: \"tt0041959\",\n },\n {\n title: \"Once Upon a Time in America\",\n rank: \"78\",\n id: \"tt0087843\",\n },\n {\n title: \"Requiem for a Dream\",\n rank: \"79\",\n id: \"tt0180093\",\n },\n {\n title: \"Eternal Sunshine of the Spotless Mind\",\n rank: \"80\",\n id: \"tt0338013\",\n },\n {\n title: \"Full Metal Jacket\",\n rank: \"81\",\n id: \"tt0093058\",\n },\n {\n title: \"Oldboy\",\n rank: \"82\",\n id: \"tt0364569\",\n },\n {\n title: \"Braveheart\",\n rank: \"83\",\n id: \"tt0112573\",\n },\n {\n title: \"L.A. Confidential\",\n rank: \"84\",\n id: \"tt0119488\",\n },\n {\n title: \"Bicycle Thieves\",\n rank: \"85\",\n id: \"tt0040522\",\n },\n {\n title: \"Chinatown\",\n rank: \"86\",\n id: \"tt0071315\",\n },\n {\n title: \"Singin' in the Rain\",\n rank: \"87\",\n id: \"tt0045152\",\n },\n {\n title: \"Princess Mononoke\",\n rank: \"88\",\n id: \"tt0119698\",\n },\n {\n title: \"Monty Python and the Holy Grail\",\n rank: \"89\",\n id: \"tt0071853\",\n },\n {\n title: \"Metropolis\",\n rank: \"90\",\n id: \"tt0017136\",\n },\n {\n title: \"Rashomon\",\n rank: \"91\",\n id: \"tt0042876\",\n },\n {\n title: \"Some Like It Hot\",\n rank: \"92\",\n id: \"tt0053291\",\n },\n {\n title: \"Amadeus\",\n rank: \"93\",\n id: \"tt0086879\",\n },\n {\n title: \"2001: A Space Odyssey\",\n rank: \"94\",\n id: \"tt0062622\",\n },\n {\n title: \"All About Eve\",\n rank: \"95\",\n id: \"tt0042192\",\n },\n {\n title: \"Witness for the Prosecution\",\n rank: \"96\",\n id: \"tt0051201\",\n },\n {\n title: \"The Sting\",\n rank: \"97\",\n id: \"tt0070735\",\n },\n {\n title: \"The Apartment\",\n rank: \"98\",\n id: \"tt0053604\",\n },\n {\n title: \"Grave of the Fireflies\",\n rank: \"99\",\n id: \"tt0095327\",\n },\n {\n title: \"Indiana Jones and the Last Crusade\",\n rank: \"100\",\n id: \"tt0097576\",\n },\n];\n\nmock.onGet(\"/api/autocomplete/data\").reply(200, {\n autoComplete,\n});\n","import mock from \"./mock\";\n\nimport \"./jwt\";\nimport \"./pages/faq\";\nimport \"./apps/chat\";\nimport \"./apps/todo\";\nimport \"./apps/email\";\nimport \"./apps/invoice\";\nimport \"./apps/calendar\";\nimport \"./apps/userList\";\nimport \"./pages/profile\";\nimport \"./apps/eCommerce\";\nimport \"./pages/blog-data\";\nimport \"./tables/datatables\";\nimport \"./pages/pricing-data\";\nimport \"./navbar/navbarSearch\";\nimport \"./pages/knowledge-base\";\nimport \"./apps/permissionsList\";\nimport \"./cards/card-analytics\";\nimport \"./cards/card-statistics\";\nimport \"./pages/account-settings\";\nimport \"./autoComplete/autoComplete\";\n\nmock.onAny().passThrough();\n","/*eslint-disable */\n// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n window.location.hostname === \"localhost\" ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === \"[::1]\" ||\n // 127.0.0.1/8 is considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\nexport function register(config) {\n if (process.env.NODE_ENV === \"production\" && \"serviceWorker\" in navigator) {\n // The URL constructor is available in all browsers that support SW.\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n if (publicUrl.origin !== window.location.origin) {\n // Our service worker won't work if PUBLIC_URL is on a different origin\n // from what our page is served on. This might happen if a CDN is used to\n // serve assets see https://github.com/facebook/create-react-app/issues/2374\n return;\n }\n\n window.addEventListener(\"load\", () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Let's check if a service worker still exists or not.\n checkValidServiceWorker(swUrl, config);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n \"This web app is being served cache-first by a service \" +\n \"worker. To learn more, visit https://bit.ly/CRA-PWA\"\n );\n });\n } else {\n // Is not localhost. Just register service worker\n registerValidSW(swUrl, config);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl, config) {\n navigator.serviceWorker\n .register(swUrl)\n .then((registration) => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n if (installingWorker === null) {\n return;\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === \"installed\") {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n console.log(\n \"New content is available and will be used when all \" +\n \"tabs for this page are closed. See https://bit.ly/CRA-PWA.\"\n );\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration);\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log(\"Content is cached for offline use.\");\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration);\n }\n }\n }\n };\n };\n })\n .catch((error) => {\n console.error(\"Error during service worker registration:\", error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl, config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl)\n .then((response) => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get(\"content-type\");\n if (\n response.status === 404 ||\n (contentType !== null && contentType.indexOf(\"javascript\") === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then((registration) => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config);\n }\n })\n .catch(() => {\n console.log(\n \"No internet connection found. App is running in offline mode.\"\n );\n });\n}\n\nexport function unregister() {\n if (\"serviceWorker\" in navigator) {\n navigator.serviceWorker.ready.then((registration) => {\n registration.unregister();\n });\n }\n}\n","import React from \"react\";\nimport { X } from \"react-feather\";\nimport { connect } from \"react-redux\";\nimport { dismissServerMessage } from \"./ServerMessageActions\";\n\nclass ServerMessages extends React.Component {\n componentDidUpdate({ messages, errors, dispatch }) {\n if (messages.length || errors.length) {\n const firstMessage = [...messages, ...errors][0];\n setTimeout(() => dispatch(dismissServerMessage(firstMessage)), 6000);\n }\n }\n\n dismiss = (key) => () => {\n this.props.dispatch(dismissServerMessage(key));\n };\n\n render() {\n const { messages, errors } = this.props;\n if (!messages.length && !errors.length) return null;\n return (\n \n {errors &&\n errors.length > 0 &&\n errors\n .filter(\n (value) => value !== undefined && value !== null && value !== \"\"\n )\n .map((error) => (\n
\n {error}\n {/* */}\n \n
\n ))}\n {messages &&\n messages.length > 0 &&\n messages\n .filter(\n (value) => value !== undefined && value !== null && value !== \"\"\n )\n .map((message) => (\n
\n {message}\n {/* */}\n \n
\n ))}\n
\n );\n }\n}\n\nconst mapStateToProps = ({ serverMessages, errors }) => ({\n messages: serverMessages,\n errors: errors.serverErrors,\n});\n\nexport default connect(mapStateToProps)(ServerMessages);\n","import { useDispatch, useSelector } from \"react-redux\";\nimport { Modal, ModalBody, ModalHeader } from \"reactstrap\";\nimport {\n updateParams,\n updateVideoPageState,\n} from \"../../../Pages/Video/VideoActions\";\nimport \"./FlaggedModal.scss\";\nimport { useNavigate } from \"react-router-dom\";\n\nexport default () => {\n const videoReportedAsFlagged = useSelector(\n (state) => state.videoPageStates.videoReportedAsFlagged\n );\n\n const isVideoDetailPage = useSelector(\n (state) => state.videoPageStates.isVideoDetailPage\n );\n const dispatch = useDispatch();\n const navigate = useNavigate();\n return (\n \n \n {\n dispatch(updateVideoPageState({ videoReportedAsFlagged: false }));\n if (isVideoDetailPage) {\n navigate(\"/videos\");\n dispatch(updateParams({ reFetch: true }));\n }\n }}\n />\n \n
\n
\n This video has been flagged\n
\n {/*
*/}\n
\n \n \n );\n};\n","import { useEffect, useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\nimport {\n updateParams,\n updateVideoPageState,\n} from \"../../../Pages/Video/VideoActions\";\nimport { submitUnFlaggedVideo } from \"../../SharedActions\";\nimport \"./FlaggedModal.scss\";\nimport { useNavigate } from \"react-router-dom\";\nimport { usePrevious } from \"../../CustomHooks\";\n\nexport default () => {\n const [loading, setLoading] = useState(false);\n const confirmUnflag = useSelector(\n (state) => state.videoPageStates.confirmUnflag\n );\n\n const videoTab = useSelector((state) => state.videoParams.tab);\n const successfullyUnFlagged = useSelector(\n (state) => state.videoPageStates.successfullyUnFlagged\n );\n\n const flaggedVideosCheckList = useSelector(\n (state) => state.videoPageStates.flaggedVideosCheckList\n );\n\n const isVideoDetailPage = useSelector(\n (state) => state.videoPageStates.isVideoDetailPage\n );\n\n const dispatch = useDispatch();\n const navigate = useNavigate();\n const prevSuccessfullyUnFlagged = usePrevious(successfullyUnFlagged);\n\n const sumbitUnflagg = () => {\n submitUnFlaggedVideo(flaggedVideosCheckList)\n .then((response) => {\n if (response) {\n setLoading(false);\n dispatch(\n updateVideoPageState({\n successfullyUnFlagged: true,\n })\n );\n }\n })\n .catch((err) => {});\n };\n\n useEffect(() => {\n if (isVideoDetailPage) {\n if (\n prevSuccessfullyUnFlagged &&\n prevSuccessfullyUnFlagged !== successfullyUnFlagged\n ) {\n navigate(\"/videos\");\n dispatch(updateParams({ reFetch: true }));\n }\n }\n }, [isVideoDetailPage, confirmUnflag, successfullyUnFlagged]);\n\n return (\n \n \n {\n successfullyUnFlagged\n ? dispatch(\n updateVideoPageState({\n successfullyUnFlagged: false,\n confirmUnflag: false,\n flaggedVideosCheckList: [],\n flaggedChecks: false,\n flagSelectAll: false,\n })\n )\n : dispatch(\n updateVideoPageState({\n confirmUnflag: false,\n flaggedVideosCheckList: [],\n })\n );\n }}\n />\n \n \n {!successfullyUnFlagged ? (\n <>\n \n
\n
\n Unflagged videos will show in “{videoTab}” {\" \"}\n Are you sure you want to unflag{\" \"}\n {flaggedVideosCheckList.length == 1\n ? \"this\"\n : flaggedVideosCheckList.length}{\" \"}\n video{flaggedVideosCheckList.length > 1 ? \"s\" : null}?\n \n \n
\n \n {\n dispatch(\n updateVideoPageState({\n confirmUnflag: false,\n flaggedVideosCheckList: [],\n })\n );\n }}\n >\n No\n \n \n Yes\n \n
\n >\n ) : (\n <>\n \n
\n
\n
\n
\n {videoTab === \"Competition\" ? \"Competitors\" : videoTab}\n
\n
\n
\n
\n {flaggedVideosCheckList.length == 1\n ? \"This video has\"\n : `${flaggedVideosCheckList.length} videos have`}{\" \"}\n been moved to “\n {videoTab === \"Competition\" ? \"Competitors\" : videoTab}”\n \n \n
\n
\n >\n )}\n \n \n );\n};\n","import { useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\nimport { updateProductPageState } from \"../../../Pages/Product/productActions\";\nimport { updateVideoPageState } from \"../../../Pages/Video/VideoActions\";\nimport { submitUnFlaggedVideo, trashItem } from \"../../SharedActions\";\nimport \"./FlaggedModal.scss\";\n\nexport default () => {\n const [loading, setLoading] = useState(false);\n\n const trshItemId = useSelector((state) => state.productPageStates.itemId);\n const moveToTrashModal = useSelector(\n (state) => state.productPageStates.moveToTrashModal\n );\n const movedToTrash = useSelector(\n (state) => state.productPageStates.movedToTrash\n );\n\n const dispatch = useDispatch();\n\n const sumbit = () => {\n setLoading(true);\n trashItem(`products/${trshItemId}/trash_product`)\n .then((response) => {\n if (response) {\n setLoading(false);\n dispatch(\n updateProductPageState({\n movedToTrash: true,\n })\n );\n }\n })\n .catch((err) => {\n console.log(err);\n });\n };\n\n return (\n \n \n {\n dispatch(\n updateProductPageState({\n moveToTrashModal: false,\n movedToTrash: false,\n itemId: \"\",\n })\n );\n }}\n />\n \n \n {!movedToTrash ? (\n <>\n \n
\n
\n
\n Are you sure you want to delete this product?\n \n \n
\n
\n \n {\n dispatch(\n updateProductPageState({\n moveToTrashModal: false,\n movedToTrash: false,\n itemId: \"\",\n })\n );\n }}\n >\n No\n \n \n Yes\n \n
\n >\n ) : (\n <>\n \n
\n
\n
\n
\n
\n
\n Your product has been moved to trash\n \n \n
\n
\n >\n )}\n \n \n );\n};\n","import { useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\nimport { updateVideoPageState } from \"../../../Pages/Video/VideoActions\";\nimport {\n submitPermanentDelete,\n submitUnFlaggedVideo,\n} from \"../../SharedActions\";\nimport \"./FlaggedModal.scss\";\nimport { updateProductPageState } from \"../../../Pages/Product/productActions\";\n\nexport default () => {\n const [loading, setLoading] = useState(false);\n const [message, setMessage] = useState(\"\");\n const permanentDeleteModal = useSelector(\n (state) => state.productPageStates.permanentDeleteModal\n );\n\n const removedFromTrash = useSelector(\n (state) => state.productPageStates.removedFromTrash\n );\n\n const itemsCheckList = useSelector(\n (state) => state.productPageStates.itemsCheckList\n );\n\n const dispatch = useDispatch();\n const sumbitUnflagg = () => {\n setLoading(true);\n submitPermanentDelete(\"/products/removed_on_dashboard\", itemsCheckList)\n .then((response) => {\n if (response) {\n setLoading(false);\n setMessage(response[0]);\n dispatch(\n updateProductPageState({\n removedFromTrash: true,\n })\n );\n }\n })\n .catch((err) => {\n // @TODO REMOVE WHEN API AVAILABLE\n // dispatch(\n // updateProductPageState({\n // removedFromTrash: true,\n // })\n // );\n setLoading(false);\n });\n };\n\n return (\n \n \n {\n removedFromTrash\n ? dispatch(\n updateProductPageState({\n removedFromTrash: false,\n permanentDeleteModal: false,\n itemsCheckList: [],\n showchecks: false,\n selectAllChecks: false,\n })\n )\n : dispatch(\n updateProductPageState({ permanentDeleteModal: false })\n );\n }}\n />\n \n \n {!removedFromTrash ? (\n <>\n \n
\n
\n
\n Are you sure you want to delete{\" \"}\n {itemsCheckList.length > 1 ? \"these products \" : \"this product \"} \n permanently?\n \n \n
\n
\n \n {\n dispatch(\n updateProductPageState({\n permanentDeleteModal: false,\n // itemsCheckList: [],\n })\n );\n }}\n >\n No\n \n \n Yes\n \n
\n >\n ) : (\n <>\n \n
\n
\n
\n
\n
\n
\n {/* The product has been deleted permanently */}\n {message}\n {/* {itemsCheckList.length == 1\n ? \"The product has\"\n : `${itemsCheckList.length} products have`}{\" \"}\n been deleted permanently */}\n \n \n
\n
\n >\n )}\n \n \n );\n};\n","import { useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useNavigate } from \"react-router-dom\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\n\nimport {\n updateParams,\n updateVideoPageState,\n} from \"../../../Pages/Video/VideoActions\";\nimport { submitUnFavoriteVideo } from \"../../../Shared/SharedActions\";\nimport \"../FlaggedModal/FlaggedModal.scss\";\n\nconst ConfirmUnFavoriteModal = () => {\n const [loading, setLoading] = useState(false);\n\n const confirmUnfav = useSelector(\n (state) => state.videoPageStates.confirmUnfav\n );\n\n const isVideoDetailPage = useSelector(\n (state) => state.videoPageStates.isVideoDetailPage\n );\n\n const videoTab = useSelector((state) => state.videoParams.tab);\n\n const favVideosCheckList = useSelector(\n (state) => state.videoPageStates.favVideosCheckList\n );\n\n const successfullyUnFavorite = useSelector(\n (state) => state.videoPageStates.successfullyUnFavorite\n );\n\n const dispatch = useDispatch();\n const navigate = useNavigate();\n\n const sumbitUnfav = () => {\n submitUnFavoriteVideo(favVideosCheckList)\n .then((response) => {\n if (response) {\n setLoading(false);\n dispatch(\n updateVideoPageState({\n successfullyUnFavorite: true,\n favoriteChecks: false,\n flagSelectAll: false,\n isVideoDetailPage: false,\n isCategoryPage: false,\n })\n );\n if (isVideoDetailPage) {\n navigate(\"/videos\");\n dispatch(updateParams({ reFetch: true, isFavoriteTab: true }));\n } else {\n dispatch(updateParams({ reFetch: true }));\n }\n }\n })\n .catch((err) => {\n console.log(err);\n });\n };\n\n return (\n \n \n {\n dispatch(\n updateVideoPageState({\n confirmUnfav: false,\n successfullyUnFavorite: false,\n favVideosCheckList: successfullyUnFavorite\n ? []\n : favVideosCheckList,\n })\n );\n }}\n />\n \n \n {!successfullyUnFavorite ? (\n <>\n \n
\n
\n Unfavorite videos will show in{\" \"}\n \n “{videoTab === \"Competition\" ? \"Competitors\" : videoTab}”\n {\" \"}\n Are you sure you want to unfavorite{\" \"}\n {favVideosCheckList.length === 1\n ? \"this\"\n : favVideosCheckList.length}{\" \"}\n video{favVideosCheckList.length > 1 ? \"s\" : null}?\n \n \n
\n \n {\n dispatch(\n updateVideoPageState({\n confirmUnfav: false,\n favVideosCheckList: [],\n })\n );\n }}\n >\n No\n \n \n Yes\n \n
\n >\n ) : (\n <>\n \n
\n
\n
\n
\n {videoTab === \"Competition\" ? \"Competitors\" : videoTab}\n
\n
\n
\n
\n {favVideosCheckList.length === 1\n ? \"This video has\"\n : `${favVideosCheckList.length} videos have`}{\" \"}\n been removed from “Favorites”. It will only show in “\n {videoTab === \"Competition\" ? \"Competitors\" : videoTab}” now\n \n \n
\n
\n >\n )}\n \n \n );\n};\n\nexport default ConfirmUnFavoriteModal;\n","import { useEffect, useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\n\nimport { submitUnFavoriteProducts } from \"../../SharedActions\";\nimport \"../FlaggedModal/FlaggedModal.scss\";\nimport {\n updateParams as updateProductParams,\n updateProductPageState,\n fetchProducts,\n} from \"../../../Pages/Product/productActions\";\nimport { usePrevious } from \"../../CustomHooks\";\nimport { useNavigate } from \"react-router-dom\";\n\nexport default () => {\n const [loading, setLoading] = useState(false);\n const [isProcessSuccessfull, setIsProcessSuccessfull] = useState(false);\n\n const modalFor = useSelector((state) => state.productPageStates.modalFor);\n const unFavoriteModal = useSelector(\n (state) => state.productPageStates.unFavoriteModal\n );\n\n const productTab = useSelector((state) => state.productParams.tab);\n const productParams = useSelector((state) => state.productParams);\n const isDetailPage = useSelector(\n (state) => state.productPageStates.isDetailPage\n );\n const itemsCheckList = useSelector(\n (state) => state.productPageStates.itemsCheckList\n );\n\n const dispatch = useDispatch();\n const navigate = useNavigate();\n\n const sumbitUnfav = () => {\n submitUnFavoriteProducts(itemsCheckList)\n .then((response) => {\n if (response) {\n setIsProcessSuccessfull(true);\n setLoading(false);\n // dispatch(\n // updateProductPageState({\n // // isProcessSuccessfull: true,\n // // unFavoriteModal: false,\n // // showchecks: false,\n // // selectAllChecks: false,\n // // itemsCheckList: [],\n // }),\n // );\n if (isDetailPage) {\n navigate(\"/products\");\n } else {\n dispatch(fetchProducts(productParams));\n }\n }\n })\n .catch((err) => {});\n };\n\n const favTabDetailPage = `This product has been removed from “Favorites”. It will only show in “${\n productTab === \"Competition\" ? \"Competitors\" : productTab\n }“ now`;\n const favTabIndexPage = `${\n itemsCheckList.length == 1\n ? \"This product has\"\n : `${itemsCheckList.length} products have`\n }\n been removed from “Favorites”. It will only show in “${\n productTab === \"Competition\" ? \"Competitors\" : productTab\n }”\n now`;\n\n return (\n \n \n {\n dispatch(\n updateProductPageState({\n unFavoriteModal: false,\n showchecks: false,\n selectAllChecks: false,\n itemsCheckList: [],\n })\n );\n setIsProcessSuccessfull(false);\n }}\n />\n \n \n {!isProcessSuccessfull ? (\n <>\n \n
\n
\n Unfavorite products will show in{\" \"}\n \n “{productTab === \"Competition\" ? \"Competitors\" : productTab}\n ”\n {\" \"}\n Are you sure you want to unfavorite{\" \"}\n {itemsCheckList.length == 1 ? \"this\" : itemsCheckList.length}{\" \"}\n product{itemsCheckList.length > 1 ? \"s\" : null}?\n \n \n
\n \n {\n dispatch(\n updateProductPageState({\n unFavoriteModal: false,\n showchecks: false,\n selectAllChecks: false,\n itemsCheckList: [],\n })\n );\n setIsProcessSuccessfull(false);\n }}\n >\n No\n \n \n Yes\n \n
\n >\n ) : (\n <>\n \n
\n
\n
\n
\n {productTab === \"Competition\" ? \"Competitors\" : productTab}\n
\n
\n
\n
\n {isDetailPage ? favTabDetailPage : favTabIndexPage}\n \n \n
\n
\n >\n )}\n \n \n );\n};\n","import { useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useLocation, useNavigate } from \"react-router-dom\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\n\nimport {\n updateParams,\n updateVideoPageState,\n} from \"../../../Pages/Video/VideoActions\";\nimport { markAsTrashItem, trashItem } from \"../../SharedActions\";\nimport \"../FlaggedModal/FlaggedModal.scss\";\nimport { fetchNavbarStats } from \"../../../vyrill-ui-config/layout/sidebar/navbarStatsActions\";\n\nconst VideoMoveToTrash = () => {\n const [loading, setLoading] = useState(false);\n\n const dispatch = useDispatch();\n const navigate = useNavigate();\n const { pathname } = useLocation();\n\n const trashItemId = useSelector((state) => state.videoPageStates.itemId);\n const tab = useSelector((state) => state.videoParams.tab);\n const videos = useSelector((state) => state.videos);\n const trashConfirmationModal = useSelector(\n (state) => state.videoPageStates.trashConfirmationModal\n );\n const movedToTrash = useSelector(\n (state) => state.videoPageStates.movedToTrash\n );\n\n const manufacturer_ids =\n videos.find((i) => i?.video?._id === trashItemId)?.video\n ?.manufacturer_ids || [];\n\n const sumbit = () => {\n setLoading(true);\n markAsTrashItem(`${trashItemId}`, tab === \"Competition\", manufacturer_ids)\n .then((response) => {\n if (response) {\n setLoading(false);\n dispatch(updateVideoPageState({ movedToTrash: true }));\n dispatch(updateParams({ reFetch: true }));\n dispatch(fetchNavbarStats());\n if (pathname !== \"/videos\") navigate(\"/videos\");\n }\n })\n .catch((err) => {\n console.log(err);\n });\n };\n\n return (\n \n \n {\n dispatch(\n updateVideoPageState({\n trashConfirmationModal: false,\n movedToTrash: false,\n itemId: \"\",\n })\n );\n }}\n />\n \n \n {!movedToTrash ? (\n <>\n \n
\n
\n
\n Are you sure you want to delete this video?\n \n \n
\n
\n \n {\n dispatch(\n updateVideoPageState({\n trashConfirmationModal: false,\n movedToTrash: false,\n itemId: \"\",\n })\n );\n }}\n >\n No\n \n \n Yes\n \n
\n >\n ) : (\n <>\n \n
\n
\n
\n
\n
\n
\n Your Video has been moved to trash\n \n \n
\n
\n >\n )}\n \n \n );\n};\n\nexport default VideoMoveToTrash;\n","import { useEffect, useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\n\nimport {\n updateParams,\n updateVideoPageState,\n} from \"../../../Pages/Video/VideoActions\";\nimport { submitRestoreVideo } from \"../../SharedActions\";\nimport \"../FlaggedModal/FlaggedModal.scss\";\nimport { fetchNavbarStats } from \"../../../vyrill-ui-config/layout/sidebar/navbarStatsActions\";\n\nconst VideoConfirmRestore = () => {\n const [loading, setLoading] = useState(false);\n const [videoPayload, setVideoPayload] = useState([]);\n const dispatch = useDispatch();\n\n const confirmRestore = useSelector(\n (state) => state.videoPageStates.confirmRestore\n );\n const successfullyRestored = useSelector(\n (state) => state.videoPageStates.successfullyRestored\n );\n const restoreVideosCheckList = useSelector(\n (state) => state.videoPageStates.restoreVideosCheckList\n );\n const tab = useSelector((state) => state.videoParams.tab);\n const videos = useSelector((state) => state.videos);\n\n const tabNames = { \"My Videos\": \"My Videos\", Competition: \"Competitors\" };\n const restoreIcon =\n require(`@src/assets/images/vyrill/videos/restore.png`).default;\n\n useEffect(() => {\n setVideoPayload(\n restoreVideosCheckList.map((i) => ({\n video_id: i,\n manufacturer_ids:\n videos.find((j) => j?.video?._id === i)?.video?.manufacturer_ids ||\n [],\n }))\n );\n }, [restoreVideosCheckList]);\n\n const submitRestore = () => {\n submitRestoreVideo(videoPayload, tab === \"Competition\")\n .then((response) => {\n if (response) {\n setLoading(false);\n dispatch(updateVideoPageState({ successfullyRestored: true }));\n dispatch(updateParams({ reFetch: true }));\n dispatch(fetchNavbarStats());\n }\n })\n .catch((err) => {\n console.log(err);\n });\n };\n\n const cancelHandler = () => {\n if (successfullyRestored) {\n dispatch(\n updateVideoPageState({\n successfullyRestored: false,\n confirmRestore: false,\n restoreVideosCheckList: [],\n restoreChecks: false,\n })\n );\n } else {\n dispatch(updateVideoPageState({ confirmRestore: false }));\n }\n };\n\n return (\n \n \n \n \n \n {!successfullyRestored ? (\n <>\n \n
\n Are you sure you want to restore{\" \"}\n {restoreVideosCheckList.length === 1 ? \"this\" : \"these\"} video\n {restoreVideosCheckList.length > 1 && \"s\"} to “\n {`${tabNames[tab]}`}”?\n \n \n \n {\n dispatch(updateVideoPageState({ confirmRestore: false }));\n }}\n >\n No\n \n \n Yes\n \n
\n >\n ) : (\n \n
\n
\n
\n
\n
\n {restoreVideosCheckList.length === 1\n ? \" Your video has\"\n : `${restoreVideosCheckList.length} videos have`}{\" \"}\n been restored to “{`${tabNames[tab]}`}”\n \n \n
\n )}\n \n \n );\n};\n\nexport default VideoConfirmRestore;\n","import { useEffect, useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { useLocation, useNavigate } from \"react-router-dom\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\n\nimport {\n updateParams,\n updateVideoPageState,\n} from \"../../../Pages/Video/VideoActions\";\nimport { submitDeleteVideo } from \"../../SharedActions\";\nimport \"../FlaggedModal/FlaggedModal.scss\";\n\nconst VideoConfirmDelete = () => {\n const [loading, setLoading] = useState(false);\n const [videoPayload, setVideoPayload] = useState([]);\n\n const dispatch = useDispatch();\n const { pathname } = useLocation();\n const navigate = useNavigate();\n\n const confirmDelete = useSelector(\n (state) => state.videoPageStates.confirmDelete\n );\n const successfullyDeleted = useSelector(\n (state) => state.videoPageStates.successfullyDeleted\n );\n const deleteVideosCheckList = useSelector(\n (state) => state.videoPageStates.deleteVideosCheckList\n );\n const tab = useSelector((state) => state.videoParams.tab);\n const videos = useSelector((state) => state.videos);\n\n useEffect(() => {\n setVideoPayload(\n deleteVideosCheckList.map((i) => ({\n video_id: i,\n manufacturer_ids:\n videos.find((j) => j?.video?._id === i)?.video?.manufacturer_ids ||\n [],\n }))\n );\n }, [deleteVideosCheckList]);\n\n const sumbitDelete = () => {\n submitDeleteVideo(deleteVideosCheckList, tab === \"Competition\")\n // submitDeleteVideo(deleteVideosCheckList)\n .then((response) => {\n if (response) {\n setLoading(false);\n dispatch(updateVideoPageState({ successfullyDeleted: true }));\n dispatch(updateParams({ reFetch: true }));\n if (pathname !== \"/videos\") navigate(\"/videos\");\n }\n })\n .catch((err) => {\n console.log(err);\n });\n };\n\n return (\n \n \n {\n successfullyDeleted\n ? dispatch(\n updateVideoPageState({\n successfullyDeleted: false,\n confirmDelete: false,\n deleteVideosCheckList: [],\n deleteChecks: false,\n deleteSelectAll: false,\n })\n )\n : dispatch(updateVideoPageState({ confirmDelete: false }));\n }}\n />\n \n \n {!successfullyDeleted ? (\n <>\n \n
\n
\n Are you sure you want to delete{\" \"}\n {deleteVideosCheckList.length === 1 ? \"this\" : \"these\"} video\n {deleteVideosCheckList.length > 1 ? \"s\" : null} permanently?\n \n \n
\n \n {\n dispatch(updateVideoPageState({ confirmDelete: false }));\n }}\n >\n No\n \n \n Yes\n \n
\n >\n ) : (\n <>\n \n
\n
\n
\n
\n
\n
\n {deleteVideosCheckList.length === 1\n ? \"This video has\"\n : `${deleteVideosCheckList.length} videos have`}{\" \"}\n been deleted permanently\n \n \n
\n
\n >\n )}\n \n \n );\n};\n\nexport default VideoConfirmDelete;\n","import { useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\nimport { updateVideoPageState } from \"../../../Pages/Video/VideoActions\";\nimport { submitPermanentDelete } from \"../../SharedActions\";\nimport \"./FlaggedModal.scss\";\nimport { updateProductPageState } from \"../../../Pages/Product/productActions\";\n\nconst RestoreFromTrash = () => {\n const [loading, setLoading] = useState(false);\n const [message, setMessage] = useState(\"\");\n const restoreFromTrashModal = useSelector(\n (state) => state.productPageStates.restoreFromTrashModal\n );\n\n const currentProductTab = useSelector((state) => state.productParams.tab);\n\n const removedFromTrash = useSelector(\n (state) => state.productPageStates.removedFromTrash\n );\n\n const itemsCheckList = useSelector(\n (state) => state.productPageStates.itemsCheckList\n );\n\n const dispatch = useDispatch();\n const sumbitUnflagg = () => {\n setLoading(true);\n submitPermanentDelete(\"/products/restore_products\", itemsCheckList)\n .then((response) => {\n if (response) {\n setLoading(false);\n setMessage(response[0]);\n dispatch(\n updateProductPageState({\n removedFromTrash: true,\n })\n );\n }\n })\n .catch((err) => {\n setLoading(false);\n });\n };\n\n return (\n \n \n {\n removedFromTrash\n ? dispatch(\n updateProductPageState({\n removedFromTrash: false,\n restoreFromTrashModal: false,\n itemsCheckList: [],\n showchecks: false,\n selectAllChecks: false,\n })\n )\n : dispatch(\n updateProductPageState({ restoreFromTrashModal: false })\n );\n }}\n />\n \n \n {!removedFromTrash ? (\n <>\n \n
\n
\n
\n Are you sure you want to restore{\" \"}\n {itemsCheckList.length > 1 ? \"these products\" : \"this product\"} to \"\n {currentProductTab === \"Competition\"\n ? \"Competitors\"\n : currentProductTab}\n \"?\n \n \n
\n
\n \n {\n dispatch(\n updateProductPageState({\n restoreFromTrashModal: false,\n itemsCheckList: [],\n })\n );\n }}\n >\n No\n \n \n Yes\n \n
\n >\n ) : (\n <>\n \n
\n
\n
\n
\n
\n
\n {message &&\n `Your product has been restored to “${\n currentProductTab === \"Competition\"\n ? \"Competitors\"\n : currentProductTab\n }”`}\n \n \n
\n
\n >\n )}\n \n \n );\n};\nexport default RestoreFromTrash;\n","import React from \"react\";\nimport { Button } from \"reactstrap\";\n\nimport { Header } from \"../Components\";\nimport useTutorialState from \"../TutorialHooks\";\n\nimport \"../TutorialModalstyles.scss\";\nimport \"./FirstVideoStyles.scss\";\n\nconst FirstVideoStep1 = ({}) => {\n const { activeStep, handleNext, showStep } = useTutorialState(\"first-video\");\n\n if (showStep && activeStep === 1) {\n return (\n \n
\n
\n
\n\n
\n Welcome to the My Videos folder under the Videos\n Tab. Here, you'll find all the videos you've added to your dashboard. \n
\n\n
\n handleNext()}\n >\n Next\n \n
\n
\n
\n
\n );\n } else {\n return null;\n }\n};\n\nexport default FirstVideoStep1;\n","import React from \"react\";\nimport { Button } from \"reactstrap\";\nimport { useDispatch } from \"react-redux\";\nimport { useNavigate } from \"react-router-dom\";\n\nimport useTutorialState from \"../TutorialHooks\";\nimport { updateTutorialState } from \"../TutorialActions\";\nimport { Header } from \"../Components\";\nimport { updateVideoDetailBreadcrumb } from \"../../../Pages/Video/VideoActions\";\n\nimport \"./FirstVideoStyles.scss\";\nimport \"../TutorialModalstyles.scss\";\n\nconst FirstVideoStep2 = ({}) => {\n const { activeStep, showStep } = useTutorialState(\"first-video\");\n const dispatch = useDispatch();\n const navigate = useNavigate();\n\n const skipTour = () => {\n dispatch(\n updateTutorialState({\n isTutorial: false,\n activeTutorial: \"\",\n activeStep: 1,\n totalSteps: 0,\n })\n );\n localStorage.removeItem(\"toturialScreen\");\n };\n\n // const startTour = () => {\n // localStorage.removeItem(\"toturialScreen\");\n // navigate(\"/videos/639b80fb7e0802b89600002e\"); //@TODO\n // const videosPageBreadcrumb = [\n // {\n // name: \"Videos\",\n // type: \"link\",\n // link: \"/videos\",\n // page: \"videos\",\n // },\n // {\n // name: \"Videos\",\n // tab: \"My Videos\",\n // type: \"tab\",\n // link: \"/videos\",\n // page: \"videos\",\n // },\n // ];\n // dispatch(updateVideoDetailBreadcrumb(videosPageBreadcrumb));\n // dispatch(\n // updateTutorialState({\n // isTutorial: true,\n // activeTutorial: \"video-detail\",\n // activeStep: 1,\n // totalSteps: 5,\n // })\n // );\n // };\n\n if (showStep && activeStep === 2) {\n return (\n \n
\n
\n
\n\n
\n Video analysis takes about 10 minutes. In the meantime,{\" \"}\n upload more videos to{\" \"}\n create your first video carousel to boost sales and\n conversion. A minimum of{\" \"}\n 5 videos is required .\n
\n\n
\n
{\n dispatch(updateTutorialState({ openVideoModal: true }));\n skipTour();\n }}\n >\n Upload More Videos\n \n {/*
\n skipTour()}>Skip \n
*/}\n
\n
\n
\n
\n );\n } else {\n return null;\n }\n};\n\nexport default FirstVideoStep2;\n","import { useDispatch } from \"react-redux\";\n\nimport useTutorialState from \"../TutorialHooks\";\nimport { Header } from \"../Components\";\n\nimport \"./FirstVideoAnalyzedStyle.scss\";\nimport \"../TutorialModalstyles.scss\";\n\nconst FirstVideoAnalyzedStep1 = () => {\n const { activeStep, showStep } = useTutorialState(\"first-video-analyzed\");\n const dispatch = useDispatch();\n\n if (showStep && activeStep === 1) {\n return (\n \n
\n
\n
\n
\n
\n\n
\n Go to My Videos under the Videos tab to see the detailed video\n analysis. Here is an overview of the analysis.\n
\n
\n
\n
\n
\n );\n } else {\n return null;\n }\n};\n\nexport default FirstVideoAnalyzedStep1;","import { useDispatch, useSelector } from \"react-redux\";\nimport PerfectScrollbar from \"react-perfect-scrollbar\";\nimport { X } from \"react-feather\";\n\nimport { updateTranscriptModalState } from \"../../Actions\";\nimport { timeInSeconds } from \"../../../../utilities\";\nimport { useState } from \"react\";\n\nconst TranscriptBox = ({\n setShouldTranscriptRender,\n shouldTranscriptRender,\n}) => {\n const transcripts = useSelector((state) => state?.transcript.transcripts);\n const videoId = useSelector(\n (state) => state?.modalsState.videoTranscript.videoId\n );\n const dispatch = useDispatch();\n const transcript = transcripts.filter((k) => k.video_id === videoId);\n const pinSentence = useSelector(\n (state) => state?.modalsState?.videoTranscript?.pinSentence\n );\n const pinTime = useSelector(\n (state) => state?.modalsState?.videoTranscript?.pinTime\n );\n\n const [searchVal, setSearchVal] = useState(\"\");\n const searchValLowercase = searchVal.toLowerCase();\n\n const handlePlayVideoSentence = (timeStamp) => () => {\n dispatch(\n updateTranscriptModalState({ videoStartAt: timeInSeconds(timeStamp) })\n );\n };\n\n const handleInput = (e) => {\n setSearchVal(e.target.value);\n };\n\n const handleClear = () => {\n setSearchVal(\"\");\n };\n\n const filteredContent = transcript?.[0]?.transcription?.filter((k) => {\n const contentLowercase = k.content.toLowerCase();\n return contentLowercase.includes(searchValLowercase);\n });\n\n if (shouldTranscriptRender)\n return (\n \n
\n
\n {searchVal && (\n
\n )}\n
\n
setShouldTranscriptRender(!shouldTranscriptRender)}\n src={\n require(\"@src/assets/images/vyrill/collapse-open-icon.png\")\n .default\n }\n alt=\"\"\n />\n
\n
\n
Sentiment Highlights
\n\n
\n {/* Pinned Sentence */}\n \n
\n
\n
\n
\n
\n {pinTime} \n \n {\" \"}\n {/* pinSentence */}\n {pinSentence}\n \n
\n
\n
\n
\n {filteredContent?.length > 0 ? (\n filteredContent.map((k, index) => (\n \n
\n
\n
\n
\n
\n {k?.start_time}: \n {k?.content} \n
\n
\n
\n ))\n ) : (\n
\n )}\n \n\n {/*
*/}\n \n );\n else {\n return (\n \n
setShouldTranscriptRender(!shouldTranscriptRender)}\n >\n
\n
\n
\n );\n }\n};\nexport default TranscriptBox;\n","export const DownloadIcon = () => {\n return (\n \n \n \n );\n};\n\nexport const DownloadDisableIcon = () => {\n return (\n \n \n \n );\n};\n","import { useState } from \"react\";\nimport { X } from \"react-feather\";\nimport { useQuery } from \"@apollo/client\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { Button, Modal, ModalBody, ModalHeader } from \"reactstrap\";\nimport YouTubePlayer from \"react-youtube\";\n\nimport TranscriptBox from \"./Components/TranscriptBox\";\nimport { updateTranscriptModalState } from \"../Actions\";\nimport { GET_VIDEO_DETAILS } from \"../../../Queries/ask-vyrill\";\nimport \"./VideoPopup.scss\";\nimport { Link } from \"react-router-dom\";\nimport TikTokPlayer from \"../../TikTokPlayer\";\nimport {\n handleDownloadVideo,\n updateVideoDetailBreadcrumb,\n} from \"../../../Pages/Video/VideoActions\";\nimport Loader from \"../../Loader\";\nimport { DownloadDisableIcon, DownloadIcon } from \"../../SVGs/Download\";\nimport { mimeTypes } from \"../../../constants\";\nimport { InstagramEmbed } from \"react-social-media-embed\";\n\nconst VideoTranscriptModal = () => {\n const [shouldTranscriptRender, setShouldTranscriptRender] = useState(true);\n const [openDownloadInfo, setOpenDownloadInfo] = useState(false);\n const [videoDownloading, setVideoDownloading] = useState(false);\n\n const shouldOpen = useSelector(\n (state) => state.modalsState?.videoTranscript?.shouldOpen\n );\n const videoId = useSelector(\n (state) => state.modalsState?.videoTranscript?.videoId\n );\n\n const videoStartAt = useSelector(\n (state) => state.modalsState?.videoTranscript?.videoStartAt\n );\n\n const video = useSelector(\n (state) => state.videoAssociations.body.video || {}\n );\n\n const dispatch = useDispatch();\n const {\n loading,\n error,\n data: videoData,\n } = useQuery(GET_VIDEO_DETAILS, {\n variables: { _id: videoId },\n skip: !videoId,\n });\n\n const style = {\n width: \"40px\",\n position: \"absolute\",\n top: \"6%\",\n left: \"3.3%\",\n transform: \"translate(-50%, -50%)\",\n zIndex: 2,\n };\n const GoogleDriveImg = (\n \n );\n const GenerateIcon = ({ path }) => {\n return (\n \n );\n };\n const downloadVideo = () => {\n if (videoDownloading) {\n return null;\n }\n setVideoDownloading(true);\n handleDownloadVideo(videoData?.getVideo?._id)\n .then(({ data }) => {\n if (data?.signedUrl) {\n fetch(data?.signedUrl)\n .then((response) => response.blob())\n .then((blob) => URL.createObjectURL(blob))\n .then((url) => {\n const link = document.createElement(\"a\");\n link.href = url;\n link.download = `${videoData?.getVideo?.title || \"download\"}`;\n link.setAttribute(\"type\", \"hidden\");\n document.body.appendChild(link);\n link.click();\n document.body.removeChild(link);\n // For Firefox it is necessary to delay revoking the ObjectURL\n setTimeout(() => {\n URL.revokeObjectURL(data?.signedUrl);\n }, 100);\n setVideoDownloading(false);\n });\n }\n })\n .catch((err) => {\n console.log(err);\n setVideoDownloading(false);\n });\n };\n\n const videosPageBreadcrumb = [\n {\n name: \"Home\",\n type: \"link\",\n link: \"/home\",\n page: \"videos\",\n },\n ];\n\n return (\n dispatch(updateTranscriptModalState({ shouldOpen: false }))}\n role=\"\"\n style={{ maxWidth: \"1058px\" }}\n >\n \n \n dispatch(updateTranscriptModalState({ shouldOpen: false }))\n }\n />\n \n \n \n
{videoData?.getVideo?.title}
\n\n {openDownloadInfo && (\n
\n {videoData?.getVideo?.platform === \"Vyrill_AWS_S3\" ||\n videoData?.getVideo?.platform === \"GoogleDrive\"\n ? `${videoDownloading ? \"Downloading\" : \"Download\"} Video`\n : \"Downloading YouTube and TikTok video is not supported\"}\n
\n )}\n\n
setOpenDownloadInfo(true)}\n onMouseOut={() => setOpenDownloadInfo(false)}\n >\n {(videoData?.getVideo?.platform === \"Vyrill_AWS_S3\" ||\n videoData?.getVideo?.platform === \"GoogleDrive\") && (\n \n {videoDownloading ? : }\n
\n )}\n\n {(videoData?.getVideo?.platform === \"Youtube\" ||\n videoData?.getVideo?.platform === \"Tiktok\") && (\n { }
\n )}\n \n\n
\n \n {\n dispatch(updateTranscriptModalState({ shouldOpen: false }));\n dispatch(updateVideoDetailBreadcrumb(videosPageBreadcrumb));\n }}\n >\n See Video Analysis\n \n \n
\n
\n \n {/* Handling platforms players */}\n {videoData?.getVideo?.platform === \"GoogleDrive\" &&\n videoData?.getVideo?.video_url && (\n <>\n {videoData.getVideo.video_url.includes(\"denali\") ? (\n
\n {GoogleDriveImg}\n
\n \n \n Sorry, your browser doesn't support embedded\n videos.\n
\n \n
\n ) : (\n
\n {GoogleDriveImg}\n \n
\n )}\n >\n )}\n {videoData?.getVideo?.video_embedded_url &&\n videoData?.getVideo?.platform === \"Youtube\" && (\n
\n {GenerateIcon({ path: \"youtubeIcon.png\" })}\n \n
\n )}\n {videoData?.getVideo?.video_url &&\n videoData?.getVideo?.platform === \"Tiktok\" && (\n <>\n
\n {GenerateIcon({ path: \"tikTokIcon.png\" })}\n
\n
\n >\n )}\n {videoData?.getVideo?.video_url &&\n videoData?.getVideo?.platform === \"Instagram\" && (\n <>\n
\n
\n \n
\n >\n )}\n {(videoData?.getVideo?.platform === \"Vyrill_AWS_S3\" ||\n videoData?.getVideo?.platform === \"AWS_S3_Swirl\") &&\n videoData?.getVideo?.video_url && (\n
\n {\n e.target.currentTime = videoStartAt;\n }}\n >\n \n \n
\n )}\n\n {videoData?.getVideo?.video_url &&\n videoData?.getVideo?.platform === \"Dropbox\" && (\n
\n {GenerateIcon({ path: \"dropboxIcon.png\" })}\n
\n
\n \n Sorry, your browser doesn't support embedded videos.
\n \n
\n
\n )}\n
\n \n \n \n );\n};\n\nexport default VideoTranscriptModal;\n","import { useDispatch, useSelector } from \"react-redux\";\nimport { Modal, Button, ModalBody, ModalHeader, Spinner } from \"reactstrap\";\n\nimport { updateConfirmationModalState } from \"../Actions\";\nimport CrossSVG from \"../../SVGs/Cross\";\nimport \"./styles.scss\";\n\nconst ProcessConfirmation = () => {\n const shouldOpen = useSelector(\n (state) => state.modalsState?.confirmationProcess?.shouldOpen\n );\n\n const loading = useSelector(\n (state) => state.modalsState?.confirmationProcess?.loading\n );\n\n const message = useSelector(\n (state) => state.modalsState?.confirmationProcess?.message\n );\n\n const func = useSelector(\n (state) => state.modalsState?.confirmationProcess?.func\n );\n\n const dispatch = useDispatch();\n\n const handleConfirm = () => {\n func();\n dispatch(updateConfirmationModalState({ loading: true }));\n };\n\n return (\n \n \n \n dispatch(\n updateConfirmationModalState({ shouldOpen: false, message: \"\" })\n )\n }\n >\n \n \n \n \n <>\n \n\n \n
\n dispatch(\n updateConfirmationModalState({\n shouldOpen: false,\n message: \"\",\n })\n )\n }\n >\n No\n \n
\n \n \n
\n >\n \n \n );\n};\n\nexport default ProcessConfirmation;\n","import { useEffect, useState } from \"react\";\nimport { useDispatch, useSelector } from \"react-redux\";\n\nimport FlaggedModal from \"./FlaggedModal\";\nimport ConfirmUnflag from \"./FlaggedModal/ConfirmUnflag\";\nimport MoveToTrash from \"./TrashModals/MoveToTrash\";\nimport PermanentDelete from \"./TrashModals/PermanentDelete\";\nimport UnFavoriteConfirmModal from \"./FavoritesModals/UnFavoriteConfirmModal\";\nimport UnFavoriteModal from \"./FavoritesModals/unFavoriteModal\";\nimport VideoMoveToTrash from \"./VideoTrashModals/VideoMoveToTrash\";\nimport VideoConfirmRestore from \"./VideoTrashModals/VideoConfirmRestore\";\nimport VideoConfirmDelete from \"./VideoTrashModals/VideoConfirmDelete\";\nimport RestoreFromTrash from \"./TrashModals/RestoreFromTrash\";\nimport FirstVideoStep1 from \"../Tutorials/FirstVideo/FirstVideoStep1\";\nimport FirstVideoStep2 from \"../Tutorials/FirstVideo/FirstVideoStep2\";\nimport FirstVideoAnalyzedStep1 from \"../Tutorials/FirstVideo/FirstVideoAnalyzedStep1\";\nimport { updateTutorialState } from \"../Tutorials/TutorialActions\";\nimport { getSingleVideoDetails } from \"../../Pages/Home/home_actions\";\nimport VideoTranscriptModal from \"./VideoTranscriptModal/VideoTranscriptModal\";\nimport ProcessConfirmation from \"./ProcessConfirmation/ProcessConfirmation\";\nimport { updateAskVyrillIntroModal } from \"./Actions\";\n\nconst ModalsIndex = () => {\n const dispatch = useDispatch();\n const videoCount = useSelector(\n (state) => state.navbarStatsReducer.counts.videos\n );\n\n useEffect(() => {\n let timerId;\n\n if (\n videoCount == 1 &&\n localStorage.getItem(\"firstVideoAnalysisId\")?.split(\",\")[1] == \"pending\"\n ) {\n timerId = setInterval(() => {\n callAPI();\n }, 5 * 60 * 1000);\n }\n\n return () => {\n if (timerId) {\n clearTimeout(timerId);\n }\n };\n }, [videoCount]);\n\n const callAPI = () => {\n getSingleVideoDetails(\n localStorage.getItem(\"firstVideoAnalysisId\").split(\",\")[0]\n )\n .then((videoResponse) => {\n if (videoResponse?.video?.analysis_stage === \"completed\") {\n const updateValue = localStorage\n .getItem(\"firstVideoAnalysisId\")\n .replace(\"pending\", \"completed\");\n\n localStorage.setItem(\"firstVideoAnalysisId\", updateValue);\n\n dispatch(\n updateTutorialState({\n isTutorial: true,\n activeTutorial: \"first-video-analyzed\",\n activeStep: 1,\n totalSteps: 2,\n })\n );\n } else {\n }\n })\n .catch((err) => {\n console.log(err);\n // Handle the error case here\n });\n };\n\n return (\n <>\n {/* Video Trash Feature Modal @TODO Products*/}\n \n \n \n \n \n\n {/* Video Flag feature modal */}\n \n \n\n {/* Video Favorite feature modal */}\n \n\n {/* @TODO Reuse for videos */}\n \n\n {/* Video Tutorials */}\n \n \n \n \n \n \n >\n );\n};\n\nexport default ModalsIndex;\n","// ** React Imports\nimport ReactDOM from \"react-dom\";\nimport { Suspense, lazy } from \"react\";\nimport { HashRouter } from \"react-router-dom\";\n// ** Redux Imports\nimport { store } from \"./redux/store\";\nimport { Provider } from \"react-redux\";\n\n// ** GraphQL\n// import { ApolloLink, HttpLink } from \"apollo-boost\";\nimport { ApolloProvider, ApolloClient, InMemoryCache, ApolloLink, HttpLink } from \"@apollo/client\";\nimport Cookies from \"js-cookie\";\n\n// ** Intl, CASL & ThemeColors Context\nimport ability from \"./configs/acl/ability\";\nimport { AbilityContext } from \"./utility/context/Can\";\nimport { ThemeContext } from \"./utility/context/ThemeColors\";\n\n// ** ThemeConfig\nimport themeConfig from \"./configs/themeConfig\";\n\n// ** Toast\nimport { Toaster } from \"react-hot-toast\";\n\n// ** i18n\nimport \"./configs/i18n\";\n\n// ** Spinner (Splash Screen)\nimport Spinner from \"./@core/components/spinner/Fallback-spinner\";\n\n// ** Ripple Button\nimport \"./@core/components/ripple-button\";\n\n// ** Fake Database\nimport \"./@fake-db\";\n\n// ** PrismJS\nimport \"prismjs\";\nimport \"prismjs/themes/prism-tomorrow.css\";\nimport \"prismjs/components/prism-jsx.min\";\n\n// ** React Perfect Scrollbar\nimport \"react-perfect-scrollbar/dist/css/styles.css\";\n\n// ** React Hot Toast Styles\nimport \"@styles/react/libs/react-hot-toasts/react-hot-toasts.scss\";\n\n// ** Core styles\nimport \"./@core/assets/fonts/feather/iconfont.css\";\nimport \"./@core/scss/core.scss\";\nimport \"./assets/scss/style.scss\";\nimport \"./vyrillTheme.scss\";\n\n// ** Service Worker\nimport * as serviceWorker from \"./serviceWorker\";\nimport ServerMessages from \"./Shared/ServerMessages/ServerMessages\";\n\n// ** Google ClientID\nimport { GoogleOAuthProvider } from \"@react-oauth/google\";\n\n// ** Mixpanel\nimport mixpanel from \"mixpanel-browser\";\nimport PopUpModals from \"./Shared/PopUpModals\";\nmixpanel.init(`${process.env.REACT_APP_MIXPANEL_TOKEN}`, {\n debug: process.env.NODE_ENV === \"development\" || \"staging\",\n ignore_dnt: process.env.NODE_ENV === \"development\" || \"staging\",\n});\n\nconst httpLink = new HttpLink({\n uri: `${process.env.REACT_APP_GRAPHQL_URL}`,\n});\n\nconst authLink = new ApolloLink((operation, forward) => {\n // Retrieve the authorization token from Cookies.\n const token = Cookies.get(\"jwt\");\n\n // Use the setContext method to set the HTTP headers.\n operation.setContext({ headers: { authorization: `Bearer ${token}` } });\n\n // Call the next link in the middleware chain.\n return forward(operation);\n});\n\nconst client = new ApolloClient({\n link: authLink.concat(httpLink), // Chain it with the HttpLink\n cache: new InMemoryCache(),\n});\n\n// ** Lazy load app\nconst LazyApp = lazy(() => import(\"./App\"));\n\n// Set header in API calls\n$.ajaxSetup({ headers: { Authorization: `Bearer ${Cookies.get(\"jwt\")}` } });\n\nReactDOM.render(\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n ,\n document.getElementById(\"root\")\n);\n\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: https://bit.ly/CRA-PWA\nserviceWorker.unregister();\n"],"sourceRoot":""}