Compare commits

...

13 Commits

Author SHA1 Message Date
victorAnumudu cb4f9fbb42 fixed selected subscription page 2025-08-18 19:40:49 +01:00
Olusesan Ameye ad4a92ceed Support test/qa envrionment 2025-08-17 10:42:08 +00:00
CHIEFSOFT\ameye d71fe9cc01 env to qa 2025-08-16 06:54:41 -04:00
CHIEFSOFT\ameye aeb9f0512c NODE_ENV 2025-08-16 06:47:27 -04:00
CHIEFSOFT\ameye 62c3a8be82 correct api path 2025-08-16 06:24:44 -04:00
CHIEFSOFT\ameye c7c1da919d subscribe cards 2025-08-16 06:15:09 -04:00
CHIEFSOFT\ameye 669a249499 removed wrong entry 2025-08-16 06:09:16 -04:00
ameye 2cc57f0b0a Merge branch 'page-settings-fix' of MERMS/MermsPanelReactJS into master 2025-08-15 10:50:29 +00:00
victorAnumudu 2be1f2ebd1 fixed page settings return value bug 2025-08-15 08:59:08 +01:00
CHIEFSOFT\ameye 54be47e1c8 Subscribing starter 2025-08-14 12:16:59 -04:00
CHIEFSOFT\ameye 8eefbbede8 subscribe add 2025-08-14 09:12:53 -04:00
ameye fa6b53ede0 Merge branch 'complete-profile-bug' of MERMS/MermsPanelReactJS into master 2025-08-14 11:47:26 +00:00
CHIEFSOFT\ameye a5ac576176 Subscribe and payment starter 2025-08-14 07:47:06 -04:00
16 changed files with 166 additions and 23 deletions
+9 -8
View File
@@ -1,15 +1,16 @@
SKIP_PREFLIGHT_CHECK=true
REACT_APP_NODE_ENV="development"
REACT_APP_SOCKET_URL="https://socket.mermsemr.com"
REACT_APP_MAIN_API="https://api.mermsemr.com"
REACT_APP_MEDIA_SERVER="https://media.mermsemr.com"
REACT_APP_MAIN_SOCKET="https://dsocket.mermsemr.com"
NODE_ENV="development"
REACT_APP_SOCKET_URL="https://devsocket.mermsemr.com"
REACT_APP_MAIN_API="https://devapi.mermsemr.com"
REACT_APP_MEDIA_SERVER="https://qa-media.mermsemr.com"
REACT_APP_MAIN_SOCKET="https://devsocket.mermsemr.com"
# login footer links
REACT_APP_HOME_LINK='https://www.mermsemr.com/'
REACT_APP_ABOUT_LINK='https://www.mermsemr.com/about'
REACT_APP_CONTACTS_LINK='https://www.mermsemr.com/contacts'
REACT_APP_TERMS_LINK='https://www.mermsemr.com/terms'
REACT_APP_HOME_LINK='https://qa-www.mermsemr.com/'
REACT_APP_ABOUT_LINK='https://qa-www.mermsemr.com/about'
REACT_APP_CONTACTS_LINK='https://qa-www.mermsemr.com/contacts'
REACT_APP_TERMS_LINK='https://qa-www.mermsemr.com/terms'
# Inactivity timeout/logout AT 10MINS
REACT_APP_TIMEOUT=600000
+2 -1
View File
@@ -1,7 +1,8 @@
SKIP_PREFLIGHT_CHECK=true
REACT_APP_NODE_ENV="production"
NODE_ENV="production"
REACT_APP_SOCKET_URL="https://socket.mermsemr.com"
REACT_APP_MAIN_API="https://devapi.mermsemr.com"
REACT_APP_MAIN_API="https://api.mermsemr.com"
REACT_APP_MEDIA_SERVER="https://media.mermsemr.com"
REACT_APP_MAIN_SOCKET="https://socket.mermsemr.com"
+1
View File
@@ -1,5 +1,6 @@
SKIP_PREFLIGHT_CHECK=true
REACT_APP_NODE_ENV="development"
NODE_ENV="development"
REACT_APP_SOCKET_URL="https://devsocket.mermsemr.com"
REACT_APP_MAIN_API="https://devapi.mermsemr.com"
REACT_APP_MEDIA_SERVER="https://qa-media.mermsemr.com"
+1 -2
View File
@@ -33,8 +33,7 @@
},
"scripts": {
"start": "react-scripts start -e .env.development",
"build": "react-scripts start -e .env.development",
"build_real": "GENERATE_SOURCEMAP=false react-scripts build -e .env.production",
"build": "GENERATE_SOURCEMAP=false react-scripts build -e .env.production",
"test": "react-scripts test",
"eject": "react-scripts eject"
},
+6 -1
View File
@@ -4,12 +4,17 @@ set -x
export NODE_ENV="${NODE_ENV:-development}"
if [ $NODE_ENV == "development" ]; then
if [ $NODE_ENV = "development" ]; then
# this runs webpack-dev-server with hot reloading
echo "Development build"
npm install --legacy-peer-deps
npm start
# npm run build
elif [ $NODE_ENV = "qa" -o $NODE_ENV = "test" ]; then
echo "QA build"
export NODE_ENV="test"
npm install --legacy-peer-deps
npm start
else
# build the app and serve it via nginx
echo "Production build"
+2 -1
View File
@@ -23,7 +23,7 @@ import SubscriptionPage from './views/SubscriptionPage';
import OnboardPage from "./views/OnboardPage";
import AccPWDResetPage from './views/AccPWDResetPage';
import ProfileCompletePage from './views/ProfileCompletePage';
import SubscribePage from './views/Subscribe'
function AppRouters() {
return (
@@ -55,6 +55,7 @@ function AppRouters() {
<Route path={siteLinks.onboard} element={<OnboardPage />} />
<Route path={siteLinks.calendar} element={<CalendarPage />} />
<Route path={siteLinks.settings} element={<SettingsPage />} />
<Route path={siteLinks.subscribe} element={<SubscribePage />} />
<Route path={siteLinks.help} element={<HelpPage />} />
</Route>
</Route>
@@ -1,12 +1,15 @@
import React, {memo, useState} from 'react'
import { useMutation } from "@tanstack/react-query";
import { useMutation, useQueryClient } from "@tanstack/react-query";
import { pageSettings } from "../../../services/services";
import SiteTemplateSelector from './SiteTemplateSelector';
import NoYesBooleanDropdown from './NoYesBooleanDropdown';
import { IoMdArrowDropdown } from 'react-icons/io';
import queryKeys from '../../../services/queryKeys';
const GeneralTab = memo(({name='Full Name', data, isCustom, productData, backendValues, setFieldsChanged}) =>{
const queryClient = useQueryClient()
const [reqStatus, setReqStatus] = useState({error: null, message: ''})
const fieldData = {}
@@ -41,6 +44,9 @@ const GeneralTab = memo(({name='Full Name', data, isCustom, productData, backend
setReqStatus({error: true, message: 'Unable to complete, try again later'})
},
onSettled: () => {
queryClient.refetchQueries({ // refetches productProvision API call
queryKey: [...queryKeys.settingsData],
})
setTimeout(()=>{
setReqStatus({error: null, message: ''})
},3000)
@@ -8,7 +8,9 @@ import getImage from "../../utils/getImage";
import { IoMdArrowDropdown } from "react-icons/io";
import { completeProfile, getCommonPractice } from '../../services/services';
import siteLinks from "../../links/siteLinks";
import { useNavigate } from "react-router-dom";
import { useLocation, useNavigate } from "react-router-dom";
import { updateUserDetails } from "../../store/UserDetails";
import { useDispatch } from "react-redux";
// const validationSchema = Yup.object().shape({
@@ -26,8 +28,12 @@ import { useNavigate } from "react-router-dom";
export default function ProfileCompleteCom(){
const dispatch = useDispatch()
const navigate = useNavigate()
const {state:{redirectLink}} = useLocation()
const [practices, setPractices] = useState([])
const [initialValues, setInitialValues] = useState({
@@ -58,8 +64,12 @@ export default function ProfileCompleteCom(){
setTimeout(()=>{mutation.reset()}, 4000)
},
onSuccess: (res) => {
if(res.data.resultCode != '0'){
throw({message: res?.data?.resultDescription})
}
dispatch(updateUserDetails({profile_completed: res?.data?.profile_completed }));
setTimeout(()=>{
navigate(siteLinks.home)
navigate(redirectLink)
},2000)
// console.log('res', res)
}
@@ -104,7 +114,7 @@ export default function ProfileCompleteCom(){
return <>
<BreadcrumbComBS title='Update Profile' paths={['Dashboard', 'Profile']} />
<BreadcrumbComBS title='Tell us more about your practice.' paths={['Dashboard', 'Profile']} />
{commonPractices?.isFetching ?
<>
@@ -0,0 +1,30 @@
import React from 'react'
export default function SubcribePaymentOptions(){
return <>
<div className="card-header">
<div className="card-heading">
<h4 className="card-title">Select Payment Option</h4>
</div>
</div>
<div className="card-body">
<div className="form-check form-check-inline">
<input className="form-check-input" type="radio" name="inlineRadioOptions" id="inlineRadio1"
value="option1" />
<label className="form-check-label" htmlFor="inlineRadio1">Previous Cards</label>
</div>
<div className="form-check form-check-inline">
<input className="form-check-input" type="radio" name="inlineRadioOptions" id="inlineRadio2"
value="option2" />
<label className="form-check-label" htmlFor="inlineRadio2">Add New card</label>
</div>
</div>
{/*<div className="card card-statistics"> </div>*/}
</>
}
+64
View File
@@ -0,0 +1,64 @@
import React from 'react'
import BreadcrumbComBS from "../breadcrumb/BreadcrumbComBS";
import getImage from "../../utils/getImage";
import { getSubscriptions } from '../../services/services';
import { useQuery } from '@tanstack/react-query';
import queryKeys from '../../services/queryKeys';
import siteLinks from "../../links/siteLinks";
import { Link, useLocation } from 'react-router-dom'
import SubscribeNewCard from "./SubscribeNewCard";
import SubscribePreviousCard from "./SubscribePreviousCard";
import SubcribePaymentOptions from "./SubcribePaymentOptions";
export default function Subscribe() {
const {state:{selectedSubscription}} = useLocation()
// console.log('selectedSubscription', selectedSubscription)
return (
<>
<BreadcrumbComBS title='Activate or Update your Subscription' paths={['Dashboard', 'subscribe']} />
<div className="row">
<div className="col-12 col-lg-6 col-xl-6">
<div className="card card-statistics text-center py-3">
<div className="card-body pricing-content">
<div className="pricing-content-card">
<h5>Current Subscription(s)</h5>
{/*<h2 className="text-primary pt-3">{currentSubscription?.display_name}</h2>*/}
<SubcribePaymentOptions />
<SubscribeNewCard />
<SubscribePreviousCard />
</div>
</div>
</div>
</div>
<>
<div key="basic" className="col-12 col-lg-6 col-xl-6">
<div className="card card-statistics text-center py-3">
<div className="card-body pricing-content">
<div className="pricing-content-card">
<h5>{selectedSubscription.display_name}</h5>
<h2 className="text-primary pt-3">${selectedSubscription.monthly}</h2>
<p className="text-primary pb-3">/ Monthly</p>
<ul className="py-2">
{selectedSubscription?.items?.map(item =>(
<li key={item}>{item}</li>
))}
</ul>
{/*<div className="pt-2">*/}
{/* <button className="btn btn-inverse-secondary btn-round btn-sm">Go {subscriptionSelection.display_name}</button>*/}
{/*</div>*/}
</div>
</div>
</div>
</div>
</>
</div>
</>
)
}
@@ -0,0 +1,6 @@
import React from 'react'
export default function SubscribeNewCard(){
return <>Previous Card</>
}
@@ -0,0 +1,6 @@
import React from 'react'
export default function SubscribePreviousCard(){
return <>Previous Card</>
}
+6 -4
View File
@@ -4,9 +4,11 @@ import getImage from "../../utils/getImage";
import { getSubscriptions } from '../../services/services';
import { useQuery } from '@tanstack/react-query';
import queryKeys from '../../services/queryKeys';
import siteLinks from "../../links/siteLinks";
import { Link, useNavigate } from 'react-router-dom'
export default function Subscription() {
const navigate = useNavigate()
const pricingFields ={
starter: { name: 'Starter', price: 5.99, active: true },
basic: { name: 'Basic', price: 12.99, active: true },
@@ -26,7 +28,7 @@ export default function Subscription() {
const currentSubscription = data?.data?.current_product
const otherSubscriptions = data?.data?.options
console.log('urlData', data?.data)
// console.log('urlData', data?.data)
return (
<>
@@ -71,7 +73,7 @@ export default function Subscription() {
))}
</ul>
<div className="pt-2">
<button className="btn btn-inverse-secondary btn-round btn-sm">Go {value.display_name}</button>
<button onClick={()=>{navigate(siteLinks.subscribe, {state:{selectedSubscription: value}})}} className="btn btn-inverse-secondary btn-round btn-sm">Go {value.display_name}</button>
</div>
</div>
</div>
@@ -85,4 +87,4 @@ export default function Subscription() {
}
</>
)
}
}
+1
View File
@@ -9,6 +9,7 @@ const siteLinks = {
comments: '/comments',
reports: '/reports',
subscription: '/subscription',
subscribe: '/subscribe',
onboard: '/subscription',
user: '/user',
calendar: '/calendar',
+3 -2
View File
@@ -2,18 +2,19 @@ import React, { useEffect } from 'react'
import ProductFactory from '../component/product/ProductFactory'
import { useSelector } from 'react-redux';
import siteLinks from '../links/siteLinks';
import { useNavigate } from 'react-router-dom';
import { useLocation, useNavigate } from 'react-router-dom';
export default function ProductPage() {
const navigate = useNavigate()
let {pathname} = useLocation()
const { userDetails: { profile_completed }} = useSelector((state) => state?.userDetails); // CHECKS IF USER Details are avaliable, to determine if user is active
useEffect(()=>{
if(!profile_completed){
navigate(siteLinks.profile_complete, {replace: true, state:{profile_completed: false}})
navigate(siteLinks.profile_complete, {replace: true, state:{redirectLink: pathname}})
}
},[])
+9
View File
@@ -0,0 +1,9 @@
import React from 'react'
//import Signup2 from '../component/auth/Signup2'
import Subscribe from '../component/subscribe/Subscribe'
export default function SubscribePage() {
return (
<Subscribe />
)
}