{"version":3,"sources":["redux/layout.js","redux/authentication.js","utility/context/Can.js","assets/images/portrait/small/avatar-s-9.jpg","Environment.js","assets/images/slider/006.jpg","assets/images/slider/003.jpg","assets/images/slider/004.jpg","assets/images/slider/optimize-your-website-content-for-maximum-conversion.png","assets/images/slider/increase-ctr.png","assets/images/portrait/small/avatar-s-13.jpg","assets/images/banner/conversion-rate-optimazation.jpg","assets/images/banner/7.jpg","configs/themeConfig.js","assets/images/banner/4.jpg","assets/images/banner/5.jpg","@core/auth/jwt/jwtDefaultConfig.js","@core/auth/jwt/jwtService.js","auth/jwt/useJwt.js","@core/auth/jwt/useJwt.js","assets/images/portrait/small/avatar-s-3.jpg","assets/images/portrait/small/avatar-s-5.jpg","assets/images/logo/logo.svg","assets/images/portrait/small/avatar-s-7.jpg","assets/images/avatars/1-small.png","assets/images/slider/001.jpg","assets/images/slider/009.jpg","assets/images/slider/011.jpg","assets/images/slider/use-gamification-to-improve-ux.png","assets/images/slider/strategy-tip-for-your-business.png","assets/images/slider/conversion-rate-optimazation.png","assets/images/slider/increase-user-engagement-in-your-website.png","assets/images/slider/mobile-commerce-effect-sales.png","assets/images/portrait/small/avatar-s-14.jpg","assets/images/slider/010.jpg","assets/images/slider/002.jpg","assets/images/banner/increase-user-engagement-in-your-website.jpg","assets/images/banner/mobile-commerce-effect-sales.jpg","assets/images/banner/3.jpg","assets/images/banner/strategy-tip-for-your-business.jpg","assets/images/banner/2.jpg","assets/images/slider/03.jpg","assets/images/avatars/11-small.png","assets/images/avatars/3-small.png","redux/navbar.js","redux/rootReducer.js","redux/store.js","configs/acl/ability.js","configs/acl/initialAbility.js","utility/context/ThemeColors.js","services/oauth.js","utils/authProvider.js","configs/i18n/index.js","@core/components/spinner/Fallback-spinner.js","assets/images/logo/logo.png","@core/components/ripple-button/index.js","@fake-db/mock.js","@fake-db/jwt/index.js","@fake-db/pages/blog-data.js","@fake-db/pages/account-settings.js","@fake-db/autoComplete/autoComplete.js","@fake-db/index.js","serviceWorker.js","index.js","assets/images/portrait/small/avatar-s-11.jpg"],"names":["layoutSlice","createSlice","name","initialState","skin","themeConfig","layout","isRTL","type","lastLayout","footerType","footer","navbarType","navbar","menuHidden","menu","isHidden","contentWidth","menuCollapsed","isCollapsed","routerTransition","navbarColor","backgroundColor","reducers","handleRTL","state","action","payload","window","localStorage","setItem","JSON","stringify","handleSkin","handleLayout","handleFooterType","handleNavbarType","handleMenuHidden","handleLastLayout","handleNavbarColor","handleContentWidth","handleMenuCollapsed","handleRouterTransition","_layoutSlice$actions","actions","config","useJwt","jwtConfig","authSlice","userData","item","getItem","parse","initialUser","handleLogin","storageTokenKeyName","storageRefreshTokenKeyName","accessToken","refreshToken","handleLogout","removeItem","_authSlice$actions","AbilityContext","createContext","createContextualCan","Consumer","ENV","apiUrl","oAuthConfig","issuer","clientId","clientSecret","scope","localization","defaultResourceName","getEnvVars","app","appName","appLogoImage","require","default","customizer","scrollTop","loginEndpoint","registerEndpoint","refreshEndpoint","logoutEndpoint","tokenType","JwtService","jwtOverrideConfig","_this","_classCallCheck","_objectSpread","jwtDefaultConfig","isAlreadyFetchingAccessToken","subscribers","this","axios","interceptors","request","use","getToken","headers","Authorization","concat","error","Promise","reject","response","originalRequest","status","then","r","setToken","data","setRefreshToken","onAccessTokenFetched","resolve","addSubscriber","_createClass","key","value","filter","callback","push","_len","arguments","length","args","Array","_key","post","apply","_len2","_key2","getRefreshToken","jwt","getBookmarks","createAsyncThunk","_asyncToGenerator","_regeneratorRuntime","mark","_callee","wrap","_context","prev","next","get","sent","abrupt","suggestions","bookmarks","stop","updateBookmarked","_ref2","_callee2","id","_context2","_x","query","handleSearchQuery","extraReducers","builder","addCase","fulfilled","objectToUpdate","find","isBookmarked","bookmarkIndex","findIndex","x","splice","rootReducer","auth","store","configureStore","reducer","middleware","getDefaultMiddleware","serializableCheck","existingAbility","ability","Ability","subject","ThemeColors","ThemeContext","_ref","children","_useState","useState","_useState2","_slicedToArray","colors","setColors","useEffect","getHex","color","getComputedStyle","document","body","getPropertyValue","trim","obj","primary","light","main","secondary","success","danger","warning","info","dark","_jsx","Provider","accessTokenUri","userInfoUri","endsessionUri","process","REACT_APP_AUTH_SERVER_URL","introspectURL","scopes","oauth","ClientOAuth2","AuthProvider","manager","userManager","useRef","current","React","Children","only","i18n","Backend","LanguageDetector","initReactI18next","init","lng","backend","loadPath","fallbackLng","debug","keySeparator","react","useSuspense","interpolation","escapeValue","formatSeparator","SpinnerComponent","_jsxs","className","src","alt","Button","Ripple","onClick","rest","_objectWithoutProperties","_excluded","mounted","setMounted","_useState3","_useState4","isRippling","setIsRippling","_useState5","y","_useState6","coords","setCoords","setTimeout","classnames","_defineProperty","e","rect","target","getBoundingClientRect","clientX","left","clientY","top","style","mock","MockAdapter","users","fullName","username","password","avatar","email","role","extras","eCommerceCartItemsCount","secret","refreshTokenSecret","expireTime","refreshTokenExpireTime","onPost","reply","_JSON$parse","user","u","sign","expiresIn","_JSON$parse2","isEmailAlreadyInUse","isUsernameAlreadyInUse","lastIndex","Object","assign","verify","newAccessToken","newRefreshToken","blogList","img","title","userFullName","blogPosted","tags","excerpt","comment","blogSidebar","recentPosts","createdTime","categories","category","icon","blogDetailIncreasingUserEngagement","blog","metaDescription","metaTitle","content","comments","bookmarked","commentedAt","commentText","blogDetailMobileCommerce","blogDetailBenefitsOfGamifying","blogDetailOptimizeWebsiteContent","blogDetailCTR","blogDetailConversionRateOptimization","blogDetailIncreaseClickThroughRate","blogDetailConversionRateOptimizationPracticalSteps","blogDetailGamificationStrategyTips","blogDetailGamificationToImproveUX","blogDetailGuideUsingWiply","blogDetailImproveConversionRate","blogDetailFutureOfAdvertising","blogDetailGamificationTactics","blogDetailWebsiteBudget","blogEdit","blogTitle","blogCategories","label","slug","featuredImage","onGet","accountSetting","general","company","bio","dob","country","website","phone","social","socialLinks","twitter","facebook","google","linkedIn","instagram","quora","connections","profileImg","github","notification","commentOnArticle","answerOnForm","followMe","newAnnouncements","productUpdates","blogDigest","autoComplete","rank","onAny","passThrough","Boolean","location","hostname","match","tagManagerArgs","gtmId","console","log","TagManager","initialize","LazyApp","lazy","ReactDOM","render","Suspense","fallback","Spinner","ToastContainer","newestOnTop","getElementById","navigator","serviceWorker","ready","registration","unregister"],"mappings":"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","file":"static/js/main.21c58333.chunk.js","sourcesContent":["// ** 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}\nexport const layoutSlice = createSlice({\n name: 'layout',\n initialState: {\n skin: themeConfig.layout.skin,\n isRTL: themeConfig.layout.isRTL,\n layout: themeConfig.layout.type,\n lastLayout: themeConfig.layout.type,\n footerType: themeConfig.layout.footer.type,\n navbarType: themeConfig.layout.navbar.type,\n menuHidden: themeConfig.layout.menu.isHidden,\n contentWidth: themeConfig.layout.contentWidth,\n menuCollapsed: themeConfig.layout.menu.isCollapsed,\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('menuCollapsed', JSON.stringify(action.payload))\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","// ** Redux Imports\nimport { createSlice } from '@reduxjs/toolkit'\n\n// ** UseJWT import to get config\nimport useJwt from '@src/auth/jwt/useJwt'\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] = action.payload[config.storageTokenKeyName]\n state[config.storageRefreshTokenKeyName] = action.payload[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 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(config.storageTokenKeyName)\n localStorage.removeItem(config.storageRefreshTokenKeyName)\n }\n }\n})\n\nexport const { handleLogin, handleLogout } = authSlice.actions\n\nexport default authSlice.reducer\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/avatar-s-9.e2785e7a.jpg\";","const ENV = {\n dev: {\n // apiUrl: 'http://localhost:44381',\n apiUrl: 'https://admin.wiply.com',\n oAuthConfig: {\n issuer: 'https://admin.wiply.com',\n clientId: 'Wiplify_React',\n clientSecret: 'ehbn8765',\n scope: 'offline_access Wiplify',\n },\n localization: {\n defaultResourceName: 'Wiplify',\n },\n },\n prod: {\n apiUrl: 'https://admin.wiply.com',\n oAuthConfig: {\n issuer: 'https://admin.wiply.com',\n clientId: 'Wiplify_React',\n clientSecret: 'ehbn8765',\n scope: 'offline_access Wiplify',\n },\n localization: {\n defaultResourceName: 'Wiplify',\n },\n },\n};\n\nexport const getEnvVars = () => {\n // eslint-disable-next-line no-undef\n return ENV.prod\n // return __DEV__ ? ENV.dev : ENV.prod;\n};\n","export default __webpack_public_path__ + \"static/media/006.e4c1ac2c.jpg\";","export default __webpack_public_path__ + \"static/media/003.3b0b4ff8.jpg\";","export default __webpack_public_path__ + \"static/media/004.227bcac2.jpg\";","export default __webpack_public_path__ + \"static/media/optimize-your-website-content-for-maximum-conversion.851e68c1.png\";","export default __webpack_public_path__ + \"static/media/increase-ctr.d7a48201.png\";","export default __webpack_public_path__ + \"static/media/avatar-s-13.41f43dab.jpg\";","export default __webpack_public_path__ + \"static/media/conversion-rate-optimazation.6275ba87.jpg\";","export default __webpack_public_path__ + \"static/media/7.c21958e2.jpg\";","// You can customize the template with the help of this file\n\n//Template config options\nconst themeConfig = {\n app: {\n appName: 'Wiply',\n appLogoImage: require('@src/assets/images/logo/logo.svg').default\n },\n layout: {\n isRTL: false,\n skin: 'light', // light, dark, bordered, semi-dark\n routerTransition: 'fadeIn', // fadeIn, fadeInLeft, zoomIn, none or check this for more transition https://animate.style/\n type: 'vertical', // vertical, horizontal\n contentWidth: 'boxed', // full, boxed\n menu: {\n isHidden: true,\n isCollapsed: false\n },\n navbar: {\n // ? For horizontal menu, navbar type will work for navMenu type\n type: 'floating', // static , sticky , floating, hidden\n backgroundColor: 'white' // BS color options [primary, success, etc]\n },\n footer: {\n type: 'static' // static, sticky, hidden\n },\n customizer: false,\n scrollTop: true // Enable scroll to top button\n }\n}\n\nexport default themeConfig\n","export default __webpack_public_path__ + \"static/media/4.5d91c0c1.jpg\";","export default __webpack_public_path__ + \"static/media/5.b6c06011.jpg\";","// ** Auth Endpoints\nexport default {\n // loginEndpoint: '/jwt/login',\n loginEndpoint: 'https://admin.wiply.com/connect/token',\n registerEndpoint: 'https://admin.wiply.com/api/account/register',\n refreshEndpoint: '/jwt/refresh-token',\n // ** This will be prefixed in authorization header with token\n logoutEndpoint: 'https://admin.wiply.com/api/account/logout',\n\n // ** This will be prefixed in authorization header with token\n // ? e.g. Authorization: Bearer \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'\nimport { getEnvVars } from '../../../Environment';\n\nconst { oAuthConfig } = getEnvVars();\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 => callback(accessToken))\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 login(...args) {\n return axios.post(this.jwtConfig.loginEndpoint, ...args, {headers:{'Content-Type':'application/x-www-form-urlencoded'}})\n // .catch(error => {\n // this.setState({ errorMessage: error.message })\n // console.error('There was an error!', error)\n // })\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","export default __webpack_public_path__ + \"static/media/avatar-s-3.c1d416e5.jpg\";","export default __webpack_public_path__ + \"static/media/avatar-s-5.301316d5.jpg\";","export default __webpack_public_path__ + \"static/media/logo.84ce80c4.svg\";","export default __webpack_public_path__ + \"static/media/avatar-s-7.ba3f6823.jpg\";","export default __webpack_public_path__ + \"static/media/1-small.58bbb9cc.png\";","export default __webpack_public_path__ + \"static/media/001.66398689.jpg\";","export default __webpack_public_path__ + \"static/media/009.a6885123.jpg\";","export default __webpack_public_path__ + \"static/media/011.f722aca5.jpg\";","export default __webpack_public_path__ + \"static/media/use-gamification-to-improve-ux.f736d9ee.png\";","export default __webpack_public_path__ + \"static/media/strategy-tip-for-your-business.4ff51195.png\";","export default __webpack_public_path__ + \"static/media/conversion-rate-optimazation.6f59d4d4.png\";","export default __webpack_public_path__ + \"static/media/increase-user-engagement-in-your-website.daab2890.png\";","export default __webpack_public_path__ + \"static/media/mobile-commerce-effect-sales.94383cd3.png\";","export default __webpack_public_path__ + \"static/media/avatar-s-14.ea440a6a.jpg\";","export default __webpack_public_path__ + \"static/media/010.118c7a42.jpg\";","export default __webpack_public_path__ + \"static/media/002.4ce5f00d.jpg\";","export default __webpack_public_path__ + \"static/media/increase-user-engagement-in-your-website.349152c5.jpg\";","export default __webpack_public_path__ + \"static/media/mobile-commerce-effect-sales.b87b3389.jpg\";","export default __webpack_public_path__ + \"static/media/3.0add6d6d.jpg\";","export default __webpack_public_path__ + \"static/media/strategy-tip-for-your-business.19848825.jpg\";","export default __webpack_public_path__ + \"static/media/2.d6b3c63a.jpg\";","export default __webpack_public_path__ + \"static/media/03.1c67b250.jpg\";","export default __webpack_public_path__ + \"static/media/11-small.5c61c575.png\";","export default __webpack_public_path__ + \"static/media/3-small.8d6585e8.png\";","// ** Redux Imports\nimport { createSlice, createAsyncThunk } from '@reduxjs/toolkit'\n\n// ** Axios Imports\nimport axios from 'axios'\n\nexport const getBookmarks = createAsyncThunk('layout/getBookmarks', 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\nexport const updateBookmarked = createAsyncThunk('layout/updateBookmarked', async id => {\n await axios.post('/api/bookmarks/update', { id })\n return id\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(x => x.id === action.payload)\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","// ** Reducers Imports\nimport navbar from './navbar'\nimport layout from './layout'\nimport auth from './authentication'\n\nconst rootReducer = {\n auth,\n navbar,\n layout\n}\n\nexport default rootReducer\n","// ** Redux Imports\nimport rootReducer from './rootReducer'\nimport { configureStore } from '@reduxjs/toolkit'\n\nconst store = configureStore({\n reducer: rootReducer,\n middleware: getDefaultMiddleware => {\n return getDefaultMiddleware({\n serializableCheck: false\n })\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\nconst userData = JSON.parse(localStorage.getItem('userData'))\nconst existingAbility = userData ? userData.ability : null\n\nexport default new Ability(existingAbility || initialAbility)\n","// ** Initial user ability\nexport const initialAbility = [\n {\n action: 'read',\n subject: 'Auth'\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 => 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 {children}\n}\n\nexport { ThemeColors, ThemeContext }\n","import ClientOAuth2 from \"client-oauth2\";\nimport axios from \"axios\";\nimport { setAuthHeader } from \"../utils/axiosHeaders\";\n//import {\n// storeUserError,\n// storeUser,\n// userSignedOut,\n// } from \"../../../actions/authActions\";\n// import store from \"store\";\nimport { store } from '../redux/store'\n\nconst config = {\n clientId: \"Wiplify_React\",\n clientSecret: \"ehbn8765\",\n accessTokenUri: `https://admin.wiply.com/connect/token`,\n userInfoUri: `https://admin.wiply.com/api/identity/my-profile`,\n endsessionUri: `${process.env.REACT_APP_AUTH_SERVER_URL}/connect/endsession`,\n introspectURL: `${process.env.REACT_APP_AUTH_SERVER_URL}/connect/introspect`,\n scopes: [\"openid\", \"profile\", \"email\", \"role\"],\n};\n\nconst oauth = new ClientOAuth2(config);\n\nexport const userProfile = () => {\n const token = localStorage.getItem(\"access_token\");\n if (token) {\n axios.defaults.headers.common[\"Authorization\"] = token ? `Bearer ${ token}` : \"\";\n axios.defaults.headers.common[\"Access-Control-Allow-Origin\"] = \"*\";\n return axios.get(config.userInfoUri);\n } else {\n return null;\n }\n};\nexport async function loadUserFromStorage(store) {\n try {\n const user = await userProfile();\n if (!user) {\n // return store.dispatch(storeUserError());\n }\n // localStorage.setItem(\"access_token\", result.accessToken);\n // store.dispatch(storeUser(user.data));\n } catch (e) {\n console.error(`User not found: ${e}`);\n // store.dispatch(storeUserError());\n }\n}\n\n\nexport const login = (params) => {\n return oauth.owner\n .getToken(params.username, params.password)\n .then((result) => {\n localStorage.setItem(\"access_token\", result.accessToken);\n setAuthHeader(result.accessToken);\n // const user = await userProfile();\n //get and store user details\n loadUserFromStorage(store);\n // try {\n // const user = await userProfile();\n // if (!user) {\n // return store.dispatch(storeUserError());\n // }\n // store.dispatch(storeUser(user.data));\n // } catch (e) {\n // console.error(`User not found: ${e}`);\n // store.dispatch(storeUserError());\n // }\n return result;\n })\n .catch((error) => {\n localStorage.removeItem(\"access_token\");\n console.log(error);\n });\n};\n\n// export const logoff = () => {\n// userSignedOut();\n// };\n\n\nexport const validateToken = (token) => {\n return axios\n .post(config.introspectURL, { token })\n .then((result) => {\n console.log(result);\n })\n .catch((error) => {\n console.error(error);\n });\n};\n\nexport default oauth;\n","import React, { useEffect, useRef } from 'react';\n\nexport default function AuthProvider({ userManager: manager, store, children }) {\n\n const userManager = useRef();\n\n useEffect(() => {\n userManager.current = manager\n }, [manager, store]);\n\n return (\n React.Children.only(children)\n )\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: '/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","// ** Logo\nimport logo from '@src/assets/images/logo/logo.png'\n\nconst SpinnerComponent = () => {\n return (\n
\n logo\n
\n
\n
\n
\n
\n
\n )\n}\n\nexport default SpinnerComponent\n","export default \"data:image/png;base64,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\"","// ** 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: 'max',\n password: 'admin',\n avatar: require('@src/assets/images/portrait/small/avatar-s-11.jpg').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(u => u.email === email && u.password === password)\n\n if (user) {\n try {\n const accessToken = jwt.sign({ id: user.id }, jwtConfig.secret, { expiresIn: jwtConfig.expireTime })\n const refreshToken = jwt.sign({ id: user.id }, jwtConfig.refreshTokenSecret, {\n expiresIn: jwtConfig.refreshTokenExpireTime\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(user => user.username === username)\n const error = {\n email: isEmailAlreadyInUse ? 'This email is already in use.' : null,\n username: isUsernameAlreadyInUse ? 'This username is already in use.' : 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, { expiresIn: jwtConfig.expireTime })\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, { expiresIn: jwtConfig.expiresIn })\n const newRefreshToken = jwt.sign({ id: userData.id }, jwtConfig.refreshTokenSecret, {\n expiresIn: jwtConfig.refreshTokenExpireTime\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\";\n\nconst data = {\n // blog list\n blogList: [\n {\n img: require(\"@src/assets/images/slider/006.jpg\").default,\n title: \"5 Ways to Create Conversion Rates of 5%-8%: Gamification Tactics\",\n id: 15,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n blogPosted: \"Aug 28, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n excerpt: \"Learn three gamification tactics that have been proven to work in increasing conversion rates for all types of businesses.\",\n comment: 15,\n },\n {\n img: require(\"@src/assets/images/slider/001.jpg\").default,\n title: \"How to Gamify Your E-commerce Website on a Budget \",\n id: 14,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n blogPosted: \"Aug 15, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n excerpt:\n \" Wiply.com is a great solution for businesses looking to add gamification to their website on a budget. \",\n comment: 15,\n },\n {\n img: require(\"@src/assets/images/slider/003.jpg\").default,\n title: \"How Gamification Can Improve the Conversion Rate on Your Website\",\n id: 12,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n blogPosted: \"Jul 07, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n excerpt: \"Want to know how to get leads for your business? \",\n comment: 15,\n },\n {\n img: require(\"@src/assets/images/slider/009.jpg\").default,\n title:\n \"Why wiply.com is the Future of Advertising: Add Innovation for Maximum Results\",\n id: 13,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n blogPosted: \"Jul 03, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n excerpt: \"Want to know how to get leads for your business? \",\n comment: 15,\n },\n {\n img: require(\"@src/assets/images/slider/011.jpg\").default,\n title: \"How to Get Leads for Your Business: A Guide Using Wiply.com\",\n id: 11,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n blogPosted: \"Jun 27, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n excerpt: \"Want to know how to get leads for your business? \",\n comment: 15,\n },\n {\n img: require(\"@src/assets/images/slider/use-gamification-to-improve-ux.png\")\n .default,\n title: \"How to use gamification to improve UX\",\n id: 10,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n blogPosted: \"Jun 15, 2022\",\n tags: [\"Gaming\", \"Sales\"],\n excerpt:\n \"Gamification can be a great way to improve UX, by adding games and making the experience more fun and engaging.\",\n comment: 5,\n },\n {\n img: require(\"@src/assets/images/slider/strategy-tip-for-your-business.png\")\n .default,\n title: \"Gamification Strategy Tips for Your Business\",\n id: 9,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n userFullName: \"Max Hunt\",\n blogPosted: \"Jun 12, 2022\",\n tags: [\"E-commerce\", \"Gaming\"],\n excerpt:\n \"Companies are increasingly looking to gamification as a way to engage and motivate employees, customers, and partners.\",\n comment: 24,\n },\n {\n img: require(\"@src/assets/images/slider/conversion-rate-optimazation.png\")\n .default,\n title: \"Conversion rate optimization in 7 practical steps\",\n id: 8,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-11.jpg\")\n .default,\n userFullName: \"Helena Hunt\",\n blogPosted: \"Apr 14, 2022\",\n tags: [\"Conversion\", \"SEO\"],\n excerpt:\n \"In this article, we will discuss 7 (and another bonus tip at the end!) steps that will help increase conversion rate.\",\n comment: 15,\n },\n {\n img: require(\"@src/assets/images/slider/increase-user-engagement-in-your-website.png\")\n .default,\n title: \"Increasing user engagement in you website\",\n id: 1,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n blogPosted: \"Mar 07 2022\",\n tags: [\"Gaming\", \"SEO\"],\n excerpt:\n \"User engagement is one of the most important aspects of a website. Without users engaging with your content, your website will not be successful. \",\n comment: 76,\n },\n {\n img: require(\"@src/assets/images/slider/mobile-commerce-effect-sales.png\")\n .default,\n title: \"How does mobile commerce affect sales and desktop website\",\n id: 2,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-9.jpg\")\n .default,\n userFullName: \"Jorge Griffin\",\n blogPosted: \"Mar 02 2022\",\n tags: [\"Gaming\", \"Sales\"],\n excerpt:\n \"As mobile commerce continues to grow in popularity, it's having a larger and larger impact on sales for desktop ecommerce websites. \",\n comment: 2100,\n },\n {\n img: require(\"@src/assets/images/slider/004.jpg\").default,\n title: \"Benefits of gamifying your online shop\",\n id: 3,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-3.jpg\")\n .default,\n userFullName: \"Claudia Neal\",\n blogPosted: \"Feb 22 2022\",\n tags: [\"Gaming\", \"Sales\"],\n excerpt:\n 'The phrase \"gamification\" may be a bit of a buzzword in online marketing and e-commerce but its still an important tool in any website owners arsenal.',\n comment: 243,\n },\n {\n img: require(\"@src/assets/images/slider/optimize-your-website-content-for-maximum-conversion.png\")\n .default,\n title: \"How to Optimize Your Website Content for Maximum Conversions\",\n id: 4,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-14.jpg\")\n .default,\n userFullName: \"Fred Boone\",\n blogPosted: \"Feb 17 2022\",\n tags: [\"Conversion\", \"Sales\"],\n excerpt:\n \"When it comes to creating website content, many business owners feel overwhelmed. How can I make sure my website is optimized for conversions? \",\n comment: 10,\n },\n {\n img: require(\"@src/assets/images/slider/increase-ctr.png\").default,\n title: \"CTR as a standard for evaluating success in e-commerce \",\n id: 5,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-13.jpg\")\n .default,\n userFullName: \"Billy French\",\n blogPosted: \"Feb 06 2022\",\n tags: [\"E-commerce\", \"SEO\"],\n excerpt:\n \"CTR has become a standard for evaluating the success of online marketing campaigns. What exactly is it? How does it work? \",\n comment: 319,\n },\n {\n img: require(\"@src/assets/images/slider/010.jpg\").default,\n title: \"How to Increase Click-Through Rate: A Comprehensive Guide\",\n id: 6,\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-13.jpg\")\n .default,\n userFullName: \"Helena Hunt\",\n blogPosted: \"Feb 03 2022\",\n tags: [\"Conversion\", \"SEO\"],\n excerpt:\n \"CTR, click-through rate, is a metric that tells you how often people click on your links as opposed to just seeing them. \",\n comment: 1500,\n },\n // {\n // img: require('@src/assets/images/slider/001.jpg').default,\n // title: 'Conversion rate optimization in 9 practical steps.',\n // id: 7,\n // avatar: require('@src/assets/images/portrait/small/avatar-s-11.jpg').default,\n // userFullName: 'Helena Hunt',\n // blogPosted: 'Jan 01, 2022',\n // tags: ['Fashion', 'Video'],\n // excerpt: 'Many businesses spend time trying to increase traffic to their website, and fail to improve the conversion rate once they get there. This is a huge mistake. In this article, we will discuss 9 steps that will help increase and optimize your conversion rates and generate more revenue in your eCommerce!',\n // comment: 1500\n // }\n ],\n\n // sidebar\n blogSidebar: {\n recentPosts: [\n {\n img: require(\"@src/assets/images/slider/002.jpg\").default,\n title: \"Increasing user engagement in you website\",\n id: 1,\n createdTime: \"Mar 07 2022\",\n },\n {\n img: require(\"@src/assets/images/slider/006.jpg\").default,\n title: \"How does mobile commerce affect sales and desktop website\",\n id: 2,\n createdTime: \"Mar 02 2022\",\n },\n {\n img: require(\"@src/assets/images/slider/004.jpg\").default,\n title: \"Benefits of gamifying your online shop\",\n id: 3,\n createdTime: \"Feb 22 2022\",\n },\n {\n img: require(\"@src/assets/images/slider/003.jpg\").default,\n title: \"How to Optimize Your Website Content for Maximum Conversions\",\n id: 4,\n createdTime: \"Feb 17 2022\",\n },\n ],\n categories: [\n { category: \"SEO\", icon: \"Watch\" },\n { category: \"Conversion\", icon: \"ShoppingCart\" },\n { category: \"Gaming\", icon: \"Command\" },\n { category: \"E-commerce\", icon: \"Quote\" },\n { category: \"Sales\", icon: \"Video\" },\n ],\n },\n\n // detail\n blogDetailIncreasingUserEngagement: {\n blog: {\n img: require(\"@src/assets/images/banner/increase-user-engagement-in-your-website.jpg\")\n .default,\n title: \"Increasing user engagement in you website\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n createdTime: \"Mar 07, 2022\",\n tags: [\"Gaming\", \"SEO\"],\n metaDescription:\n \"User engagement is one of the most important aspects of a website. learn how to increse it in a few easy steps >>\",\n metaTitle: \"Increasing user engagement in you website\",\n content: `\n

\nUser engagement is one of the most important aspects of a website. Without users engaging with your content, your website will not be successful. There are many techniques you can use to increase user engagement on your website. In this article, we will discuss some of the most effective ways to engage your users.\n\nAs more websites go live on the web it's getting harder to build a strong & engaging website that will put you above your competitors and will make your user want to come back to you. With that been said, more and more website owners are looking for ways to make their websites better.\n\nIf you're not quite sure how to get it done - we are here for you! Together we will learn about the best ways of making a better engaging website so you can get more of your goals achieved.\n

\n

Keeping your content updated and relevant

\n

\nThis means regularly adding new content to your website, whether it be articles, blog posts, images, or videos. stale content can quickly bore users, so keep them engaged by providing new and interesting material. That means you need to put on a list a couple of hours on a weekly basis to create content relevant for your users - a good way to get it done is to plan ahead of time and create a list of article headings and pictures so every week you're gonna have a subject to write about.\n\n

\n

Interactive website is the new game changer

\n

\nAllow users to interact with your content by providing quizzes, polls, or surveys. This will allow users to engage with your content on a deeper level and help them learn more about your website.\nAnd if you want to take it to the next level - gamify your website! Research shows that websites with gamification and rewards have a better engagement by users as long as more transactions. The best thing about it is that here in Wiply that's what we do and for free! absolutely free - you can modify and customize any game from our platform and easily upload it to any website platform you want.\n

\n\n

UI can make the difference

\n

\nYou can also engage users by making your website visually appealing. This means using attractive visuals and graphics to capture the user’s attention. You can do this by using bright colors, interesting shapes, and attractive images.\nIf you are low on budget and don’t have money or the resources to hire a graphic designer but you still want to get stunning graphics done - we have a solution for you. By now Canva has taken control of the graphic design world for beginners, the platform allows you to create stunning graphics with just basic knowledge!\n

\n\n

Personalized the user experience

\n

\nYou can engage users by providing a personalized experience. This means tailoring your content to fit the user’s interests and needs. You can do this by using cookies to track the user’s activity on your website or by asking the user to provide their preferences. Basically the set of mind is to make the user feel like he is a part of the website and not just a visitor, that will make him want to stay more and build his confidence in the website.\n\nThat's it, now you know how to increase user engagement in your website in just a few easy steps! If you want to keep up to date with our newsletter make sure you sign up, it will help you navigate the hard world of being a website owner with the best tips and tricks.\n

\n\n `,\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: \"Mar 08, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailMobileCommerce: {\n blog: {\n img: require(\"@src/assets/images/banner/mobile-commerce-effect-sales.jpg\")\n .default,\n title: \"How does mobile commerce affect sales and desktop website\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n createdTime: \"Mar 02, 2022\",\n metaDescription: `As mobile commerce continues to grow in popularity, it's having a larger and larger impact on sales for desktop ecommerce websites.`,\n metaTitle: \"How does mobile commerce affect sales and desktop website\",\n tags: [\"Gaming\", \"Sales\"],\n content: `\n

\n As mobile commerce continues to grow in popularity, it's having a larger and larger impact on sales for desktop ecommerce websites. Here are just a few of the ways that mobile commerce is changing the ecommerce landscape:\n

\n

Shoppers are increasingly using their phones to make purchases

\n

\n Whether they're buying items online or in-store. In fact, a recent study found that mobile commerce accounted for 30% of all online retail sales in 2017. That number is only going to increase as more and more people become comfortable making purchases with their phones.\n

\n

Mobile shopping apps are becoming increasingly sophisticated

\n

\n Offering a range of features that make it easy for shoppers to find what they're looking for and complete transactions quickly and easily. For instance, many shopping apps allow you to save your payment information so that you can buy items faster and without having to enter your information each time.\n

\n\n

Mobile commerce is particularly well-suited to impulse buys

\n

\n Because we're typically using our phones when we're out and about, it's easy to spot a deal or a product that we're interested in and make a purchase without having to wait. In fact, a study by Criteo found that mobile shoppers are 3x more likely to make an impulse purchase than desktop shoppers.\n

\n

Optimize desktop websites for mobile

\n\n

\n Desktop ecommerce websites need to make sure that their sites are optimized for mobile shoppers. If your site isn't mobile-friendly, you're likely to lose out on sales to competitors who are. In fact, a study by Google found that 61% of mobile users are unlikely to return to a website that's difficult to use on their phone.\n As you can see, mobile commerce is having a major impact on the ecommerce landscape. If you're not already optimized for mobile shoppers, it's time to start making changes. By doing so, you'll be better positioned to take advantage of the growth in mobile commerce and increase your sales.\n

\n\n

Here are some tips for increasing income on your mobile commerce

\n

\n In today's digital world, it's more important than ever to have a successful mobile ecommerce website. Not only is this the future of retail, but it's also where most consumers are doing their shopping. So how can you make sure your mobile ecommerce website is generating the income you want? Here are all the tips:\n

\n\n

Use effective imagery

\n

\n One of the best ways to engage and entice customers is with great imagery. Make sure your images are high quality, and that they showcase your products in the best light possible.\n

\n\n

Optimize your website for search engines

\n

\n This is another important factor that can help you grow your income. Make sure you're using the right keywords and phrases, and that your website is properly optimized for search engines.\n

\n\n

Offer great customer service

\n

\n\n Nothing is more frustrating than dealing with a company that doesn't offer great customer service. Make sure your team is knowledgeable and friendly, and that they're always available to help customers with any questions or concerns they may have.\n

\n\n

Use social media to promote your website

\n

\n Social media is a great way to reach out to more customers and promote your website. Make sure you're using all the social media platforms available to you, and that your content is engaging and relevant.\n

\n\n

Offer promotions and discounts

\n

\n One of the best ways to entice customers is to offer them promotions and discounts. Make sure your website has a section where customers can view all of your current offers, and be sure to promote them on social media and in your marketing materials.\n

\n\n

Keep your website up-to-date

\n

\n It's important to keep your website up-to-date with the latest trends and technologies. This will help keep your customers engaged, and it will show them that you're a cutting-edge company.\n

\n\n

Track your website's analytics

\n

\n Finally, be sure to track your website's analytics so you can see how well it's performing. This will help you make adjustments and improvements as needed.\n By following these tips, you can help make sure your mobile ecommerce website is generating the income you want. So get started today and see the results for yourself!\n

\n `,\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: \"Mar 21, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailBenefitsOfGamifying: {\n blog: {\n img: require(\"@src/assets/images/banner/3.jpg\").default,\n title: \"Benefits of gamifying your online shop\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n createdTime: \"Feb 22, 2022\",\n tags: [\"Gaming\", \"Sales\"],\n metaDescription:\n \"Learn all the pros & cons of gamification for e-commerce websites in our article >>\",\n metaTitle: \"Benefits of gamifying your online shop\",\n content: `\n

\n The phrase \"gamification\" may be a bit of a buzzword in online marketing and e-commerce but it's still an important tool in any website owner's arsenal.\n People interact with games in fundamentally different ways than they interact with websites, traditional advertising or even social media. This kind of user behavior can be incredibly valuable for retail companies that want to increase their sales or target specific demographics.\n The most important thing about gamifying an online shop is that it will usually pay for itself in sheer volume of product sold. Users are often more willing to buy something when they have invested time in getting to know a game world, regardless of whether the game-world has any direct connection with the products being sold.\n The first step in gamifying your online shop is to choose the game that will be least off-putting to people shopping for products or services. The old \"farmville\" style of casual games are good for this purpose but so are highly stylized one-on-one fighter games, action RPGs and even shoot-'em-ups.\n In all cases, the idea is to have a world that encourages your customers to explore and spend more time on your site. Choose a game that will appeal as much as possible to the demographic you want to target with your products or services.\n\n

\n

The main problems with gamification of online stores are:

\n

\n\n Lack of suitable games - not all games can be adapted to suit your needs. Lack of gamification experience - some web developers have never done gamification before so they cannot provide a quality service or product. Inadequate Results - some people overestimate the impact of gamification on consumer behavior and expect too much from it, thus their results are not as good as they could have been.\n\n

\n

One known example of a website that did it right

\n

\n In order to address these problems, Olymptrade came up with a solution that takes the headache out of gamifying an online shop and provides outstanding results as well.\n Olymptrade is a Binary Options Trading platform which has used gamification to make its platform look like a game. The first thing you are presented with on Olymptrade's site is a game world. The game rewards you for opening an account, logging in and trading (and not just once - every time you trade, the game checks if you've gained any new levels).\n This gamification turns mere e-commerce into entertainment that is actually fun to engage with. The result is that Olymptrade has more registered users than any other Binary Option Platform in the world.\n\n\n

\n\n

The main benefits of gamifying your online shop are:

\n

\n Improved conversion rates - people are often more open to buying something when they have invested time in getting to know another game world, regardless of whether the game-world has any direct connection with the products being sold. Increased time on site and return visits - every time you trade, the game checks if you've gained any new levels which means that users will naturally want to come back and see what they can achieve next. Higher quality leads (and therefore sales) as gamification increases user engagement.\n This is beneficial for both shop and customer, as it means a better user experience for the customer and increased sales for the shop.\n The most important thing to remember is that quality matters just as much as quantity when it comes to implementing gamification in an online store. That is where we come through - Wiply as a well known gamification platform for e-Commerce websites. With our easy and intuitive platform you'll be able to modify a custom game for your own website including adding your logo, special discounts and lots of more options!\n The best part is that it's all for FREE and it can be added to any website no matter on which platform it is built on. So have a go at our games and put yourself ahead of your competitors.\n

\n `,\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: \"Mar 01, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailOptimizeWebsiteContent: {\n blog: {\n img: require(\"@src/assets/images/slider/optimize-your-website-content-for-maximum-conversion.png\")\n .default,\n title: \"How to Optimize Your Website Content for Maximum Conversions\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n createdTime: \"Feb 17, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n metaDescription:\n \"When it comes to creating website content, many business owners feel overwhelmed. Learn how to creat content easily >>\",\n metaTitle: \"How to Optimize Your Website Content for Maximum Conversions\",\n content: `\n

\nWhen it comes to creating website content, many business owners feel overwhelmed. What should I write about? How can I make sure my website is optimized for conversions? In this blog post, we will provide you with tips and advice on how to create content that will help you achieve your desired results. By following our simple guidelines, you can optimize your website content for maximum conversions and see a significant improvement in your bottom line!\n\nThe most fundamental criteria for creating a converting content is to know your audience, what they are looking for, where you might be able to meet them and how you might be able to help them. But many business and site owners are not sure where to start, so here are some ideas to help grow your website conversions through content optimization:\n\nFirst, you need to know what kind of product or service they will need. If you are not sure about this yet or you are still in the planning stages of your business venture, that's okay. For now, just realize that it's better to do a little research and plan it out.\n\nOnce you have your product or service and business goals all planned and ready to go, you can start thinking about creating some engaging content on your website. One of the best ways to connect with customers is through informative content that they will actually enjoy reading and want to share with others as well. You can also keep it simple by offering a way for people to contact you or find out more about what you do.\n\nAfter that, it's just a matter of getting the word out there about your new website and company! Getting traffic is key but without content and good conversion numbers, not many visitors will stick around. Try adding engaging images and videos as well as keeping your content fresh.\n\nYou might be surprised at how much traffic you get, if you're prepared and know what to expect. Create quality content that your audience will enjoy reading and share it with others, creating a cycle of traffic building up over time.\n

\n

How to create quality content

\n

\nThe internet has made the distribution of news and information so widespread, there is often little reward for good quality content. These are our 10 goldem tips to help you improve your writing skills and get your content noticed.\n

\n

Have a central focus

\n

\nIn the same way that a journey needs a destination, good writing requires focus. It is important to define what you are trying to achieve and concentrate on that. If it doesn't relate to the overall theme of your writing then take it out, unless it is so good it deserves a piece to itself. This focus will help your writing to remain coherent and allow you to mention related aspects that strengthen your main point.\n\n\n\nThis is something I have been told so often it has become a cliché, but it's because it's true. Even if you consider yourself a good writer, proofreading before publishing can help you to stand out from the crowd. It is also sometimes necessary for legal reasons, that's why lawyers do it.\n

\n\n

Have an opinion

\n

\nOne of the biggest problems with writing online today is the sheer number of articles available. If something doesn't make your article unique in some way then there is little reason for people to read it. By having a clear opinion you create a hook that people can latch onto. Although it has become a cliche, \"there's no such thing as bad publicity\" still applies. As long as your target audience agrees with your point of view then they will be willing to engage with your writing and share it.\n

\n\n

Write for real people

\n

\nThis is an extension of the last tip, write for your audience. By imagining you are writing to someone in particular it will keep your content relevant and engaging. You can even create profiles for people who fit into certain categories so that they feel like individuals when you talk to them. This personal touch helps to give people a greater connection with your writing and makes it more interesting.\n

\n\n

Optimize your writing for search engines

\n

\nSearch engine optimization has become much less important than it used to be, because of social media sharing. That doesn't mean that you can forget about it entirely though. If you follow the tips in this post then your content will already be soundly optimized by default. If you can make the occasional subtle reference to common search terms then that will also help to boost your SEO and get your writing in front of more people.\n

\n\n

Use images sparingly

\n

\nAlthough sharing articles with images is a good idea, adding too many can reduce your website's speed and cause technical issues for some users. While it may seem like a good idea to include an image with every paragraph, it can make your content difficult to read and navigate. If you do feel like you need to add images then use them sparingly and keep them relevant to the text they accompany.\n

\n\n

Keep your content concise

\n

\nAs we mentioned in tip 3, there is a lot of competition for people's attention these days. If you want your content to stand out then it needs to be concise and relevant. Make sure that everything you write is necessary and cut out the fluff. As a rule of thumb aim for less than 300 words per paragraph and no more than 2500 in total.\n

\n\n

Get involved with social media

\n

\n\nBy sharing your content with people on Facebook, Twitter, Pinterest and other social networks you increase the exposure of your work. Social media is also a good place to meet potential clients who are likely to be interested in hiring you or buying products from your business. If someone likes what they read then there is a good chance that they will want more so you can direct them to your website or a sign up page.\n

\n\n

Promote yourself online

\n

\nBuild a good online presence and promote it wherever you can. Make sure that all of your social media profiles are updated regularly with fresh, interesting content. If you want people to read what you write then they need to know where to find it so get your name out there.\n

\n\n

Keep writing

\n

\nWhen you are new to the world of online writing it can seem difficult but don't give up. Even if you write one or two articles a week, over time that will add up to thousands which is good for both your bank balance and your reputation. The more you write the better at it you will become so keep going and you will reap the rewards.\n\nHopefully this article will help you get a better conversion rate through your content and help you optimize your content creation. for more info, guids and articles visit our blog!\n

\n`,\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailCTR: {\n blog: {\n img: require(\"@src/assets/images/slider/increase-ctr.png\").default,\n title: \"CTR as a standard for evaluating success in e-commerce\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n createdTime: \"Feb 06, 2022\",\n tags: [\"E-commerce\", \"SEO\"],\n metaDescription:\n \"CTR has become a standard for evaluating the success of online marketing campaigns. What exactly is CTR? Learn more >>\",\n metaTitle: \"CTR as a standard for evaluating success in e-commerce\",\n content: `\n\n

\n CTR has become a standard for evaluating the success of online marketing campaigns. What exactly is it? How does it work? And what are some other metrics that you might want to track in your campaign alongside CTR? Find out everything you need to know about this useful metric!\n\n

\n

In this article we will cover the following topics:

\n\n
    \n
  • CTR - definition
  • \n
  • The history of clickthrough rate metric
  • \n
  • clickthrough rate and Adwords relationship
  • \n
  • \tHow clickthrough rate is measure
  • \n
  • Using CTR as a benchmark
  • \n
\n

CTR - definition

\n

\n CTR is a key metric that you can use to gauge how much traffic your website gets. clickthrough rate could also be written as clickthrough rate, which is defined as the percentage of users who view one web page and then click on a specific link. CTR is usually applied in the context of online marketing campaigns – if you have an ad campaign running on Google or Facebook, CTR is a good indicator of how much exposure your campaign has gotten. clickthrough rate can be used in combination with other metrics to determine the success of an online marketing campaign.\n\n

\n\n

The history of clickthrough rate metric

\n

\n How did we come up with this stat? The CTR was first mentioned in a 1999 report where the author used clickthrough rate as a measure for assessing his results from an Adwords campaign. Back also coined the term \"click-through marketing\" to describe this type of online advertising, and he was really into it: In 1999 Back stated that 'half of all internet users' were clicking on ads.\n Although CTR was not mentioned in the 2000s, it didn't stop marketers from using it; on the contrary, clickthrough rate became more and more popular the next decade. Especially companies owning their platform (like Facebook) started to make use of this metric. Also important: the Google Display Network (GDN).\n\n\n

\n\n

Clickthrough rate and Adwords relationship

\n

\n Network is driven by PPC ads, so CTR was a very important factor when placing your ads. The CTR history in Google Adwords started with different types of Ads. In the beginning it was text only, but in 2006 Google introduced Image ads in their PPC campaigns. And this is when they also introduced the clickthrough rate metric for these campaigns.\n Image ads have a higher CTR than text ads, so it is logical to place them above your competitor's text ads for better results. In 2007 Google introduced Enhanced CPC (targeting + scheduling), this allows marketers to bid on CPM instead of CPC. Nowadays CPM has been replaced by the Smart bidding in Adwords.\n This bidding method is also affected by CTR, but only when the searcher uses mobile devices. Google has added many new features to Adwords over time; in late 2012 Google announced app extensions and callouts. The clickthrough rate of these ads can be really high (up to 30%) which makes them very interesting for marketers wanting more conversions.\n Recently Google has announced that the content network will be removed in Adwords, this network was very important for small businesses, since it allowed them to reach a larger audience.\n Nowadays CTRs vary between 1% and 7%, with an average of 3%. This means your ads should have at least 3 keywords above your competition in order to get good results. And that's the history of the clickthrough rate metric in Adwords.\n

\n\n

How clickthrough rate is measure

\n

\n One of the best things about CTR is that it's not particularly hard to calculate. CTR is calculated by taking the number of people who click on your ad and dividing it by the amount of people who actually saw your ad (in other words, CTR = CTR ads / impressions). CTR is usually expressed as a percentage or decimal number and can be determined over specific periods of time – you could have CTR measured per hour, day, week or month. CTR is also different depending on the specific campaign you're advertising for.\n CTR campaigns are usually done by direct marketers (such as e-commerce companies), but CTR can be used in any scenario where there's a marketer trying to get more traffic into their website through online ads. There isn't just one CTR number, there are actually many CTRs. You can get measurements based on different ad groups within the same campaign.\n

\n\n

Using CTR as a benchmark

\n

\n CTR can be used as a benchmark for tracking the progress of future campaigns. Having CTR numbers available from the start will allow marketers to make more informed decisions on where they need to improve on their campaigns. CTR is crucial because it helps determine the overall effectiveness of an online ad campaign. also helpful in determining how advertisements are performing compared with other ads for similar keywords within the same campaign.\n CTR numbers are important because CTR is highly correlated with conversion rates. and a good marketer can determine which keywords are good investments for your business, since CTR isn't consistent across all types of search results. CTR can also be used as an easy way to compare different keywords within the same campaign.\n Overall, CTR gives marketers a benchmark for tracking the progress of future campaigns. CTR helps marketers determine which keywords are good investments, where they need to improve , and is highly correlated with conversion rates.\n

\n `,\n\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailConversionRateOptimization: {\n blog: {\n img: require(\"@src/assets/images/banner/conversion-rate-optimazation.jpg\")\n .default,\n title: \"Conversion rate optimization in 9 practical steps.\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n createdTime: \"Feb 03, 2022\",\n tags: [\"Conversion\", \"SEO\"],\n metaDescription:\n \"Learn how to optimize the convertion rate on your website with in minutes and a 9 easy staeps anyone can do >>\",\n metaTitle: \"Conversion rate optimization in 9 practical steps.\",\n content: `\n\n `,\n\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, 2022\",\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 blogDetailIncreaseClickThroughRate: {\n blog: {\n img: require(\"@src/assets/images/banner/7.jpg\").default,\n title: \"How to Increase Click-Through Rate: A Comprehensive Guide\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-7.jpg\")\n .default,\n userFullName: \"Ghani Pradita\",\n createdTime: \"Jan 17, 2022\",\n tags: [\"Conversion\", \"SEO\"],\n metaDescription:\n \"CTR, click-through rate, is a metric that tells you how often people click on your links. Learn how to increase click-through rate >>\",\n metaTitle: \"How to Increase Click-Through Rate\",\n content: `\n\n

CTR, click-through rate, is a metric that tells you how often people click on your links as opposed to just seeing them. CTR is determined by dividing the total number of clicks by the total number of impressions. CTR is one of the most important metrics for online marketers because it can be used to measure the effectiveness of a campaign or an ad. In this comprehensive guide, we will discuss all aspects of CTR and provide tips on how to increase it!

\n

What on this article

\n
    \n
  • The 3 T’s - the main factors that have the biggest impact on CTR
  • \n
  • How the position of the ad or link impacts CTR
  • \n
  • How the headline or title of the ad or link impacts CTR
  • \n
  • How the relevance of the ad or link to the viewer's interests impacts CTR
  • \n
  • \n How to improve conversion rate\n\n\n
  • \n
\n

The main factors that have the biggest impact on CTR

\n

Now that you understand what CTR is and what affects it, you can start to focus on improving your click through rate. The main thing you need to do is make sure your ad or link is in a position where people are most likely to see it, and make sure the headline or title of the ad or link catches their attention. You can do this by testing different headlines or titles to see which one gets the most clicks. You should also make sure that your ad or link is relevant to what people are looking for, since they will be more likely to click on it if it's something they actually want.\n\n\n

\n

\n Or if we need the remember is, those factors also known as “The 3 t’s”:\n

\n
    \n
  • The position of the ad or link
  • \n
  • The headline or title of the ad or link
  • \n
  • The relevance of the ad or link to the viewer's interests
  • \n\n
\n

How the position of the ad or link impacts CTR

\n

\n Positioning is key when it comes to CTR. Ads that are in the top positions (position one through four) have a significantly higher CTR than those that are in lower positions. The reason for this is because people generally only look at the first few results on a page, so ads that are further down the page get less exposure.\n\n

\n\n

How the headline or title of the ad or link impacts CTR

\n

\n The title of an ad or link also has an impact on CTR. For example, if you have a blog post about how to increase CTR and your title is \"How To Increase CTR,\" then more people will click through than if your headline were something like \"What Is CTR?\"\n\n\n

\n

How the relevance of the ad or link to the viewer's interests impacts CTR

\n

\n Finally, the relevance of an ad or link to the viewer's needs and interests can have a big impact on CTR. If someone is searching for information about how to increase CTR, then they are likely to click on links that are relevant to that topic.\n\n\n

\n

How to improve conversion rate

\n

\n Keeping the above information in mind, here are a few tips to increase your CTR :\n\n

\n

Pay attention to ad positioning

\n

\n\n Placing ads on the top of the page or sidebar will give them more exposure than if they were placed below the fold. This is because most people do not scroll down beyond the first screen of search results, but rather just glance at the first page and then click an ad if they're interested.\n\n

\n

Use bold headings

\n

\n Placing keywords in text ads as a heading or subheading can attract attention to those particular terms and encourage CTR. For example, instead of simply placing \"Yoga Studio\" as an ad title, place \"Yoga | Studio | Yoga Studio\" to emphasize the particular words.\n\n\n

\n

Draw attention with color

\n

\n There are a lot of shades, tints and colors that your text ads can be displayed in, but certain key shades tend to get more clicks than others. Research has shown that reds and oranges have a high CTR , while yellows and blues have a lower CTR.\n\n\n

\n

Use stunning graphics

\n

\n Graphics are one of the best ways to increase your click-through rate, especially when you can incorporate them into your ads. For example, most people tend to notice images before they notice text, so use an image or symbol in your ad that will draw attention to it.\n\n\n

\n

Strong call to action

\n

\n\n One of the best ways to improve CTR is by using strong calls to action. A call to action is a statement that instructs the reader what they should do next, such as \"Click here\" or \"Buy now.\" You can use these types of statements at the end of an article or in your email signature line to encourage people who read it and are interested in learning more about CTR.\n You can also include calls to action in the beginning of an email or blog post by using a header like \"Read more\" or \"Learn how.\"\n\n

\n

Use images and videos

\n

\n\n Another great way to increase CTR is by using images and videos. People are more likely to click on links that include visuals, so if you can find ways to incorporate them into your content, then you will see a boost in CTR.\n\n

\n

The golden rule - Type a content

\n

\n\n Last but not least, make sure that your content is high-quality and relevant to your target audience. If you produce valuable content that is interesting and engaging, then people will be more likely to click through on your links, google will give you a better rank and over all your metrix will improve. its not a secret that content is the king!\n By following these tips, you should see an increase in CTR over time!\n Oh, one last thing - we have talked about what CTR is and how we can improve it. but none of these matters if we don't know to to measure is so you can learn how to measure CTR in our article “how the measure metrics - CTR”\n\n

\n

\n Thanks for reading!\n\n\n

\n `,\n\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailConversionRateOptimizationPracticalSteps: {\n blog: {\n img: require(\"@src/assets/images/banner/conversion-rate-optimazation.jpg\")\n .default,\n title: \"Conversion rate optimization in 7 practical steps\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-11.jpg\")\n .default,\n userFullName: \"Helena Hunt\",\n createdTime: \"Apr 14, 2022\",\n tags: [\"Conversion\", \"SEO\"],\n metaDescription:\n \"In this article, we will discuss 7 (and another bonus tip at the end!) steps that will help increase conversion rate. >>\",\n metaTitle: \"Conversion rate optimization in 7 practical steps\",\n content: `\n\n

Many businesses spend time trying to increase traffic to their website, and fail to improve the conversion rate once they get there. This is a huge mistake. In this article, we will discuss 7 (and another bonus tip at the end!) steps that will help increase and optimize your conversion rates and generate more revenue in your eCommerce!

\n

\n When talking about conversion rate we are referring to the number of transactions from the total users in the website. the bigger the number of transactions, the better the conversion rate - so we aspire to increase the amount of transactions. how to do it? Let's find out.\n

\n

\n Oh and by the way, we have a special tip waiting for you at the end of the article.\n

\n\n

Optimize the conversion rate by attract users using a “hook”

\n\n

\n Have a strong offer. You need to have an offer that is irresistible to your customers. In digital marketing, we call it a “HOOK” offer. Try to think about what can be your Hook to get your customer's attention and get high engagement. For e.g; this could be a discount, free shipping, or something else that is valuable to them. More engagement probably will lead to more conversions.\n

\n

\n Here we can see a “hook” been used in a meta title on google search result:\n

\n\n

\n The meta title contains two “hooks” in it:\n

\n\n\n

price and a special symbol

\n

\n Using a price as a “hook” is one of the most efficient ways to increase CTR and have people's attention. Either you use it on meta titles or inside your website - a clear indication of price is one of the most effective “hooks” you can use.\n

\n

Special description

\n

\nBy using a special description on the service\\website in the mate title will make users more likely to engage and click. Here we can see that a statement of “Quick online order” is used to make users prefer this result on top of others.\n

\n\n\n

Optimize the conversion rate by better UX

\n

\n Make sure your website is user-friendly. Your customers should be able to easily find what they are looking for on your website. If they can’t find it, they will leave and not come back. Another point to consider is that giving users a good experience will lead to them trusting your website and more likely to buy from you.\nHere are 4 basic steps you can use to make a better ux and optimize your conversion rate:\n\n

\n\n
    \n
  • Navigation should remain consistent throughout a page, and within the site.
  • \n
  • Keep fonts large enough for everyone to read and consistent in type throughout the entire website.
  • \n
  • Include social media buttons so customers can easily follow your brand online, read reviews and see the activity taken by the brand on social platforms.
  • \n
  • Use logos and images on the same page together with text, instead of in separate boxes with links below. Being able to see it all without scrolling is more user-friendly.
  • \n
\n

\nAll in all, UX can be hard for a non professional but due to the fact that UX design is becoming a major player in the field of the digital age, you can find a lot of guids and tips. Here are some of our Favorite sites for UX\\UI design:\n

\n\n

\n www.uxplanet.org\n\n\n

\n

www.toptal.com/designers/blog - The blog of Toptal is full with different guides and articles written by professionals.

\n\n\n\n\n

Optimize the conversion rate by better UI

\n

\nWe know what you guys think, basic UI should cut it right? no! Studies and researches have shown a direct link between great visual content and conversion rate. So in your eCommerce you should include images of your products as well as graphics that explain what you are selling and stunning graphics to give you users a good feeling. Having great visuals will help engage your customers and keep them on your website longer - and there for optimizing your conversion rate.\n

\n

\n\n But some of you might ask “what if i can't afford a graphic designer?”. The good news is we have a solution for you! if you haven't tried elements.envato.com and canve.com its time to give it a go! with these two together you'll get access to a huge source of graphic templates, photos, videos and much more! combined with the power of canva's easy and intuitive design platform you'll be able to create stunning designs without using a professional.\n

\n\n\n

Optimize the conversion rate with CTA

\n

\n CTA (or call to action) is one of the most important aspects in optimizing conversion rate, the CTA unconsciously guides users into doing what you want - making them buy. This is the part of your website where you ask your customers to take action, such as buying a product or signing up for your email list. You need to make sure your call to action is clear and easy to understand, another common mistake is to place the CTA under the folder instead of above the folder so keep that in mind.\n\n

\n

\n CTAs can be used for 5 different types of goals you like to achieve from the users:\n

\n\n
    \n
  • \n CTA for discovery - Subscribe / Sign up now\n

  • \n
  • \nCTA for consideration - Add to cart / Add to wishlist\n

  • \n
  • \nCTA for revenue - Buy now / Checkout\n

  • \n
  • \nCTA for retention - Coupon code / VIP Perks\n

  • \n
  • \n CTA for advocacy - Review / Ambassdor\n

  • \n
\n\n

A great resource for CTA understanding is this article.

\n\n\n

\n Optimize the conversion rate with social media\n

\n

\n\n More than 50% of Facebook's revenue comes from mobile ads, Twitter posts generate over 200 million clicks per day , and LinkedIn gets more traffic than Google+. With all this data, it doesn't take a genius to see that social media can be an important part of your business strategy.\nDo you know what I typically see with many businesses' Facebook pages? They always post links to their products on their pages, which is fine if you are using Facebook primarily to market your products. However, most businesses I have worked with are not really looking to sell their products on social media pages. So the main problem is that most people dont really use the power of social media and if they do, it's just not efficient as it should be. The problem is that they focus on pushing sales instead of promoting engagement and sharing relevant content.\nWe can go on and on about social media but for now, just keep in mind that you want people to trust your website and buy from you, keep that in mind while you are building your social media presence.\n\n

\n\n\n

\n Optimize the conversion rate with targeting the right traffic\n

\n

\n Make sure you are getting quality traffic to your website. This means that a lot of the people who visit your site will end up buying something or taking action on another page, such as signing up for an email list. If not, it’s just wasting money and time!\nIn case you're not sure who to target, just think about your product and who are the main users of it. let say you have a Boat company, there is no need to target people who are not living near water sources cause its most likely they will never buy a boat.\n\n

\n

\n This step is important to get right so your time and money won't be wasted, if you're not sure how to do a market and user research on your product you should consider getting help from a professional.\n\n

\n\n

\n Optimize the conversion rate with good customer service\n

\n

\n Have great customer service and make sure your customers are happy. If they aren’t, then you will lose them as a customer forever! You need to take actions that show they care about their happiness such as responding quickly or sending free product samples. This will increase the likelihood of repeat business and word-of-mouth marketing.\n

\n

\n And it's about making sure your emails are highly targeted and relevant for the interests of your customers. This will increase open rates, click through rate, as well as conversions! And please make sure to have a strong call-to-action in your email messages. You need to have an offer that you want your customers to take action on, such as buying a product or signing up for your email list.\n

\n\n\n

The Golden Tip

\n

\n After all of that being said we have a surprise for you - the 8th tip that will not only optimize your conversion rate but also will make you unique and make your eCommerce store pop-out.\n

\n\n

\n Optimize the conversion rate with good customer service\n

\n

\n As you may have understood by now, we are trying to get users to love our site, build a trust between us and make them have a good experience while scrolling through the store. to get all of this done we have made an easy platform for building a unique (and free for 21 days!) game for your store.\n

\n\n

So how Wiply can help you

\n

\n Here in wiply we improve your eCommerce conversion rate with fun games that you can easily embed in your website no matter which platform you are using.\n

\n

How does gamification with Wiply work?

\n

\n\n With the Wiply platform you'll be able to create a unique game, with your own brand in it for free! The games are easily embedded to any platform and with basic knowledge. With the games you'll be creating a more engaging environment for your users and have them win a prize.\nBy making users play and win a prize such as discount, free shipping, special offers and so on, we are making them feel like they have won something special and more likely they will buy from you.\n\n\n

\n

\n We also know that measuring data is important for growth, so all of our games can be tracked and monitored including how many transactions are made with the special prize won in the game.\n\n\n

\n

\n Our pricing plans are monthly so you can decide as you go and grow if you want more or less games, users playing or design support. But hold on, don't pay yet! you can enjoy a special offer for 21 days for free! yes, free. just have a look at our gemifying pricing plans.\n\n\n

\n

\n Hopefully you'll find this article helpful, stay tuned for other guides, articles and surprises from us :)\n\n\n

\n\n `,\n\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailGamificationStrategyTips: {\n blog: {\n img: require(\"@src/assets/images/banner/strategy-tip-for-your-business.jpg\")\n .default,\n title: \"Gamification Strategy Tips for Your Business\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"Max Hunt\",\n createdTime: \"Jun 12, 2022\",\n tags: [\"E-commerce\", \"Gaming\"],\n metaDescription:\n \" Companies are increasingly looking to gamification as a way to engage and motivate employees, customers, and partners. learn how to build a gamification strategy like a pro >>\",\n metaTitle: \"Gamification Strategy Tips for Your Business \",\n content: `\n\n

Companies are increasingly looking to gamification as a way to engage and motivate employees, customers, and partners. By definition, gamification is the use of game mechanics and game-thinking in non-game contexts to engage users and solve problems.

\n

\n Gamification can be used in a variety of business applications, from sales and marketing to employee training and development. When used correctly, gamification can drive positive business outcomes, such as increased sales, higher customer engagement, and improved employee performance.\n

\n

\n For businesses, it is important to have a clear understanding of what they want to achieve with gamification before implementing any strategies. Without a goal in mind, businesses may find themselves wasting time and resources on gamification initiatives that don't produce the desired results.\n

\n

\n When done right, gamification can be a powerful tool for businesses to engage and motivate employees, customers, and partners. By taking the time to develop a clear gamification strategy, businesses can ensure that they are using gamification in a way that will drive positive business outcomes.\n

\n

\n Here are the main Strategy Tips when building a gamification business strategy:\n

\n\n

1. Define your goals and objectives

\n\n

\n Before you can start implementing a gamification strategy, you need to know what you want to achieve. Do you want to increase employee productivity? Drive more sales? Improve customer satisfaction?\n

\n\n

2. Identify your target audience

\n

\n Who do you want to reach with your gamification strategy? Employees? Customers? Both? Once you know your target audience, you can start to think about what sorts of games and rewards will appeal to them.\n

\n

3. Choose the right platform

\n

\nThere are a variety of gamification platforms available, each with its own strengths and weaknesses. Do some research to find the one that best meets your needs.\n

\n\n\n\n

4. Implement the strategy

\n

\n Once you have your goals, target audience, and platform is chosen, it's time to start implementing your gamification strategy. This will involve creating games and rewards, as well as setting up tracking and reporting mechanisms to measure success.\n\n

\n

5. Evaluate and adjust

\n

\n Periodically check in on your gamification strategy to see how it's performing. Are your goals being met? If not, make some adjustments to your games and rewards to try and improve results.\n\n

\n\n\n `,\n\n comments: 24,\n bookmarked: 9,\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailGamificationToImproveUX: {\n blog: {\n img: require(\"@src/assets/images/banner/4.jpg\").default,\n title: \"How to use gamification to improve UX\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n createdTime: \"Jun 15, 2022\",\n tags: [\"Gaming\", \"Sales\"],\n metaDescription:\n \"Gamification can be a great way to improve UX, by adding games and making the experience more fun and engaging. learn how >>\",\n metaTitle: \"How to use gamification to improve UX \",\n content: `\n

\n User experience is important for any website or application - it is what makes the difference between a user coming back or leaving. Gamification can be a great way to improve UX, by adding games and making the experience more fun and engaging. There are many benefits to doing this, including increased user interaction, loyalty, and retention.\n

\n

\n One of the main reasons why good UX is so important is because it can make or break a website or application. If a user has a bad experience, they are likely to leave and never come back. On the other hand, if they have a good experience, they are more likely to return and recommend the site or app to others. This is why it is so important to focus on UX when creating a website or app.\n\n

\n

\n There are many benefits to using gamification to improve UX. Gamification can make the experience more fun and engaging, which will lead to increased user interaction. Additionally, it can also increase loyalty and retention. By adding games to a website or app, users are more likely to come back and continue using it.\n\n

\n

\n Wiply is a great platform that allows you to easily add games and gamify your website or application. With full customization control, you can create games that fit perfectly into your existing UX. So why not give it a try and see how it can improve your user experience?\n

\n `,\n\n comments: 10,\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailGuideUsingWiply: {\n blog: {\n img: require(\"@src/assets/images/banner/5.jpg\").default,\n title: \"How to Get Leads for Your Business: A Guide Using Wiply.com\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n createdTime: \"Aug 28, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n metaDescription:\n \"From offering rewards to creating a sense of urgency, learn three gamification tactics that have been proven to work in increasing conversion rates for all types of businesses. Read more >>\",\n metaTitle:\n \" Gamification Tactics That Work to Create Conversion Rates of at Least Five Percent\",\n content: `\n

\n Conversion rates can be a tricky thing to figure out. What works for one business might not work for another, and what works today might not work tomorrow. However, there are some general tactics that tend to help most businesses achieve a conversion rate of 5%-8%. In this article, we will discuss three of those tactics - Gamification is the use of game mechanics in non-gaming contexts, and it can be a very effective way to encourage people to take action.\n\n

\n

\n Wiply.com is a powerful lead generation tool that can help you get more leads for your business. With Wiply.com, you can target your ideal customer and reach out to them directly. You can also create custom forms to capture leads from your website or blog. Plus, our platform integrates with many popular CRM and marketing automation tools, so you can easily follow up with your leads.\n\n

\n

\n To get started, simply create a free account and sign up for our 14-day trial. Then, you can start creating your forms and customizing your lead capture process. Once you're ready to start reaching out to leads, you can purchase credits that will allow you to contact your leads directly.\n\n

\n

\n So what are you waiting for? Sign up for Wiply.com today and start generating more leads for your business! You won't be disappointed.\n\n

\n `,\n\n comments: 15,\n bookmarked: 13,\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailImproveConversionRate: {\n blog: {\n img: require(\"@src/assets/images/banner/4.jpg\").default,\n title: \"How Gamification Can Improve the Conversion Rate on Your Website\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n createdTime: \"Jul 03, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n metaDescription:\n \"How Gamification Can Improve the Conversion Rate on Your Website\",\n metaTitle:\n \"How Gamification Can Improve the Conversion Rate on Your Website \",\n content: `\n

\n There are many ways to improve the conversion rate on a website. Some business owners focus on improving the design of their website, while others focus on generating more traffic. However, one of the most effective ways to improve conversions is through gamification. In this article, we will discuss how gamification can help improve your conversion rate.\nGamification is the process of applying game-thinking and mechanics to non-gaming activities in order to engage users and motivate them to achieve their goals. When it comes to conversion rate optimization, gamification can be a powerful tool for increasing engagement and boosting conversions. In this blog post, we will discuss how gamification can help improve your website's conversion rate. We'll also look at some examples of businesses that are using gamification successfully to increase their conversions\n\n

\n

\n Gamification can help improve your website's conversion rate in several ways\n

\n

\n First, it can increase user engagement by providing more fun and interactive experience. Second, it can motivate users to take action by offering rewards for completing desired actions. Finally, it can create a sense of social competition and community involvement that encourages users to keep coming back\n

\n

\n When used correctly, gamification can be a powerful tool for increasing engagement and boosting conversions. If you're looking to improve your website's conversion rate, consider implementing some of these strategies. You might be surprised at how much of a difference they can make\n

\n

\n There are many different ways to gamify a website. One common approach is to use points, badges, and leaderboards. Points can be awarded for taking certain actions on a website, such as signing up for a newsletter or making a purchase. Badges can be awarded for completing tasks or reaching milestones. Leaderboards can be used to encourage competition and motivate users to take more action\n

\n

\n Another way to gamify a website is to use rewards. Rewards can be given for taking certain actions, such as signing up for a newsletter or making a purchase. Rewards can also be given for reaching milestones, such as completing a task or level\n

\n

\n Gamification can be used in many different ways to improve the conversion rate on a website. By incorporating game-like elements, businesses can engage visitors and encourage them to take action. If you’re looking for ways to improve your conversion rate, gamification is definitely worth considering\n

\n `,\n\n comments: 15,\n bookmarked: 13,\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailFutureOfAdvertising: {\n blog: {\n img: require(\"@src/assets/images/banner/5.jpg\").default,\n title:\n \"Why Wiply.com is the Future of Advertising: Add Innovation for Maximum Results\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n createdTime: \"Jul 07, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n metaDescription:\n \"Why Wiply.com is the Future of Advertising: Add Innovation for Maximum Results\",\n metaTitle: \"Add Innovation for Maximum Results \",\n content: `\n

\n Have you ever been to a website and been inundated with ads? It can be really frustrating, especially when they are irrelevant to what you are looking for. Well, Wiply.com is the future of advertising, and it will change the way you see online ads forever! With Wiply.com, you can add innovation to your advertising for maximum results\n

\n\n

\n So, what is Wiply.com? Wiply.com is an online platform that helps businesses connect with customers in a more innovative way. With Wiply.com, businesses can create ads that are interactive and engaging, rather than the traditional static ads. This means that customers are more likely to pay attention to the ad, and they are also more likely to remember the product or service\n

\n

\n In addition, Wiply.com offers a range of features that make it easy for businesses to target their ads. For example, you can target ads by location, demographics, interests, and even behaviors. This ensures that your ad reaches the right people, and it also makes it more likely that they will take action\n

\n

\nSo, if you are looking for a more innovative way to advertise, then look no further than Wiply.com! With Wiply.com, you can add innovation to your advertising for maximum results. Try it today and see the difference!\n

\n

\nWhen it comes to advertising, the goal is to reach your target audience in the most effective way possible. Wiply.com does just that by offering interactive and engaging ads that are easy to remember. In addition, businesses can target their ads using a variety of criteria such as location, demographics, interests, and behaviors. This ensures that your ad reaches the right people and is more likely to result in conversions. If you are looking for a more innovative way to advertise, then look no further than Wiply.com! Try it today and see the difference!\n

\n\n

\n Why Wiply.com is the Future of Advertising: Add Innovation for Maximum Results\n

\n

\nIf you're anything like me, you're sick and tired of seeing the same boring ads online. You know, the ones that are just a bunch of text or a single image? Yeah, those are pretty much the worst.\n\n

\n

\nThankfully, there's a new kid on the block that's shaking things up. Wiply.com is an online platform that helps businesses connect with customers in a more innovative way. With Wiply.com, businesses can create ads that are interactive and engaging, rather than the traditional static ads. This means that customers are more likely to pay attention to the ad, and they are also more likely to remember the product or service.\n\n

\n

\n\n

\n `,\n\n comments: 15,\n bookmarked: 13,\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailGamificationTactics: {\n blog: {\n img: require(\"@src/assets/images/banner/2.jpg\").default,\n title: \"5 Ways to Create Conversion Rates of 5%-8%: Gamification Tactics\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n createdTime: \"Jul 03, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n metaDescription:\n \"How Gamification Can Improve the Conversion Rate on Your Website\",\n metaTitle:\n \"How Gamification Can Improve the Conversion Rate on Your Website \",\n content: `\n

\n There are many ways to improve the conversion rate on a website. Some business owners focus on improving the design of their website, while others focus on generating more traffic. However, one of the most effective ways to improve conversions is through gamification. In this article, we will discuss how gamification can help improve your conversion rate.\nGamification is the process of applying game-thinking and mechanics to non-gaming activities in order to engage users and motivate them to achieve their goals. When it comes to conversion rate optimization, gamification can be a powerful tool for increasing engagement and boosting conversions. In this blog post, we will discuss how gamification can help improve your website's conversion rate. We'll also look at some examples of businesses that are using gamification successfully to increase their conversions\n\n

\n
    \n
  1. \n

    \n One way to use gamification to increase conversion rates is to offer rewards for taking the desired action. For example, you could offer a discount on a purchase, or entry into a contest, for people who sign up for your email list. Another tactic is to create a sense of urgency by offering limited-time discounts or bonuses. This encourages people to act now rather than wait, which can increase conversion rates.\n

    \n
  2. \n
  3. \n

    \n You can also use gamification to create a sense of social proof. This is when people see others taking the desired action and feel more likely to do it themselves. For example, you could show how many people have already signed up for your email list, or how many people have liked your Facebook page.\n\n

    \n
  4. \n
  5. \n

    \n Finally, you can use gamification to make the desired action feel more fun and engaging. For example, you could add a game element to your website or make the sign-up process for your email list more interactive. By making the experience more enjoyable, people are more likely to take the desired action.\n\n\n

    \n
  6. \n\n\n
\n\n\n\n

\n All of these tactics can help you increase your conversion rates. However, it's important to experiment and find what works best for your business. There is no one-size-fits-all solution when it comes to conversion rates. But if you use these gamification tactics, you'll be well on your way to achieving the desired results.\n\n\n

\n\n `,\n\n comments: 15,\n bookmarked: 13,\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\n },\n ],\n },\n blogDetailWebsiteBudget: {\n blog: {\n img: require(\"@src/assets/images/banner/7.jpg\").default,\n title: \"How to Gamify Your E-commerce Website on a Budget\",\n avatar: require(\"@src/assets/images/portrait/small/avatar-s-5.jpg\")\n .default,\n userFullName: \"John Mory\",\n createdTime: \"Aug 15, 2022\",\n tags: [\"Conversion\", \"Sales\"],\n metaDescription:\n \" Wiply.com is a great solution for businesses looking to add gamification to their website on a budget. Read more >> \",\n metaTitle: \"How to Gamify Your E-commerce Website on a Budget\",\n content: `\n

\n When it comes to e-commerce, there is no question that businesses need to find ways to stand out from the competition. One way to do this is by gamifying your website. This can be a costly endeavor, however – or is it? Wiply.com offers e-commerce gamification for only $49 per month, and we believe it is one of the best values ​​on the market. In this article, we will discuss the benefits of e-commerce gamification and how wiply.com can help you get started without breaking the bank.\n

\n\n

\n Gamification is the process of adding Gamify elements to your website in order to engage and motivate users. Common features include points, badges, leaderboards, and rewards. When done correctly, gamification can increase user engagement, loyalty, and conversions. It can also help you collect valuable data about your users' behavior.\n\n

\n

\n\nThere are many benefits to Gamify your e-commerce website. First, it can help you stand out from the competition. With so many businesses selling similar products, anything you can do to make your site more unique is a valuable asset. Gamification can also increase loyalty and repeat customers. Users who have invested time and effort into earning points and badges are more likely to come back to your site in the future. Finally, gamification can increase conversions by motivating users to take action.\n\n

\n

\n Wiply.com is a great solution for businesses looking to add gamification to their website on a budget. For only $49 per month, you get access to all the features you need to get started, including points, badges, leaderboards, and rewards. You also get access to our team of experts who can help you customize your gamification strategy to fit your unique needs.\n\n

\n

\n If you're ready to take your e-commerce business to the next level, contact wiply.com today and let us show you how gamification can help you achieve your goals.\n\n

\n `,\n\n comments: 15,\n bookmarked: 13,\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, 2022\",\n commentText:\n \"A variation on the question technique above, the multiple-choice question great way to engage your reader.\",\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, 2022\",\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]);\n// mock.onGet('/blog/list/data/detail').reply(() => [200, data.blogDetail])\nmock.onGet(\"/blog/list/data/edit\").reply(() => [200, data.blogEdit]);\nmock\n .onGet(\"/blog/list/data/detail/1\")\n .reply(() => [200, data.blogDetailIncreasingUserEngagement]);\nmock\n .onGet(\"/blog/list/data/detail/2\")\n .reply(() => [200, data.blogDetailMobileCommerce]);\nmock\n .onGet(\"/blog/list/data/detail/3\")\n .reply(() => [200, data.blogDetailBenefitsOfGamifying]);\nmock\n .onGet(\"/blog/list/data/detail/4\")\n .reply(() => [200, data.blogDetailOptimizeWebsiteContent]);\nmock.onGet(\"/blog/list/data/detail/5\").reply(() => [200, data.blogDetailCTR]);\nmock\n .onGet(\"/blog/list/data/detail/6\")\n .reply(() => [200, data.blogDetailIncreaseClickThroughRate]);\nmock\n .onGet(\"/blog/list/data/detail/7\")\n .reply(() => [200, data.blogDetailConversionRateOptimization]);\nmock\n .onGet(\"/blog/list/data/detail/8\")\n .reply(() => [200, data.blogDetailConversionRateOptimizationPracticalSteps]);\nmock\n .onGet(\"/blog/list/data/detail/9\")\n .reply(() => [200, data.blogDetailGamificationStrategyTips]);\nmock\n .onGet(\"/blog/list/data/detail/10\")\n .reply(() => [200, data.blogDetailGamificationToImproveUX]);\nmock\n .onGet(\"/blog/list/data/detail/11\")\n .reply(() => [200, data.blogDetailGuideUsingWiply]);\nmock\n .onGet(\"/blog/list/data/detail/12\")\n .reply(() => [200, data.blogDetailImproveConversionRate]);\nmock\n .onGet(\"/blog/list/data/detail/13\")\n .reply(() => [200, data.blogDetailFutureOfAdvertising]);\nmock\n .onGet(\"/blog/list/data/detail/14\")\n .reply(() => [200, data.blogDetailWebsiteBudget]);\nmock\n .onGet(\"/blog/list/data/detail/15\")\n .reply(() => [200, data.blogDetailGamificationTactics]);\n","import mock from '../mock'\nconst data = {\n accountSetting: {\n general: {\n avatar: require('@src/assets/images/portrait/small/avatar-s-11.jpg').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').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: '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'\n// import './pages/faq'\n// import './apps/chat'\n// import './apps/todo'\n// import './apps/email'\n// import './apps/invoice'\n// import './apps/calendar'\n// import './apps/userList'\n// import './pages/profile'\n// import './apps/eCommerce'\n import './pages/blog-data'\n// import './tables/datatables'\n// import './pages/pricing-data'\n// import './navbar/navbarSearch'\n// import './pages/knowledge-base'\n// import './apps/permissionsList'\n// import './cards/card-analytics'\n// import './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(/^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/)\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 (response.status === 404 || (contentType !== null && contentType.indexOf('javascript') === -1)) {\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('No internet connection found. App is running in offline mode.')\n })\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister()\n })\n }\n}\n","// ** React Imports\nimport { Suspense, lazy } from 'react'\nimport ReactDOM from 'react-dom'\n\n// ** Redux Imports\nimport { Provider } from 'react-redux'\nimport { store } from './redux/store'\n\n// ** Intl & ThemeColors Context\nimport ability from './configs/acl/ability'\nimport { ToastContainer } from 'react-toastify'\nimport { AbilityContext } from './utility/context/Can'\nimport { ThemeContext } from \"./utility/context/ThemeColors\";\n\nimport oauth, { loadUserFromStorage } from \"./services/oauth\";\nimport AuthProvider from \"./utils/authProvider\";\n\nimport \"./configs/i18n\";\n// ** Spinner (Splash Screen)\nimport Spinner from \"./@core/components/spinner/Fallback-spinner\";\n\n// ** Ripple Button\nimport \"./@core/components/ripple-button\";\n\nimport \"./@fake-db\";\n// ** PrismJS\nimport \"prismjs\";\nimport \"prismjs/themes/prism-tomorrow.css\";\nimport \"prismjs/components/prism-jsx.min\";\n\nimport TagManager from \"react-gtm-module\";\n\n// ** React Perfect Scrollbar\nimport \"react-perfect-scrollbar/dist/css/styles.css\";\n\n// ** React Toastify\nimport \"@styles/react/libs/toastify/toastify.scss\";\n\n// ** Core styles\nimport \"./@core/assets/fonts/feather/iconfont.css\";\nimport \"./@core/scss/core.scss\";\nimport \"./assets/scss/style.scss\";\n// import './styles/globals.css'\n// ** Service Worker\nimport * as serviceWorker from \"./serviceWorker\";\n\nconst tagManagerArgs = {\n gtmId: \"GTM-5LMXJG6V\",\n};\n\nconsole.log(\"tagManagerArgs yoel\", tagManagerArgs);\n\n// const options = {\n// // licenseKey: 'gmrchk',\n// focusableElementsOffsetX: 5,\n// focusableElementsOffsetY: 5,\n// //color: '#666666',\n// color: \"linear-gradient( 90deg, rgba(88,8,251,1) 0%, rgba(153,41,234,1) 100% )\",\n// dotColor: \"#620DF9\",\n// invert: false,\n// focusableElements:\n// \"[data-blobity], a:not([data-no-blobity]), button:not([data-no-blobity]), [data-blobity-tooltip]\",\n// font: \"'Montserrat','Source Sans Pro',-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif\",\n// fontSize: 14,\n// fontWeight: 400,\n// opacity: 0.8,\n// // zIndex: 10, mnhkjhk\n// fontColor: \"#ffffff\",\n// zIndex: -1,\n// size: 40,\n// radius: 4,\n// };\n\nTagManager.initialize(tagManagerArgs);\n// ** Lazy load app\nconst LazyApp = lazy(() => import(\"./App\"));\n// new Blobity(options)\n// const blobityInstance = Blobity(options);\n// const blobity = useBlobity();\nReactDOM.render(\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","export default __webpack_public_path__ + \"static/media/avatar-s-11.1d46cc62.jpg\";"],"sourceRoot":""}