+
+ setRating({ current: 0, maxAmount: 5, success: false })
+ }
+ />
+
+ setRating({ current: 0, maxAmount: 5, success: false })
+ }
+ />
+
+ )}
+ {showRecordings && (
+
+
setShowRecordings(false)}
+ />
+
+ setShowRecordings(false)} />
+
+
+ )}
+
+ );
+}
diff --git a/sample-apps/react/react-dogfood/components/EndCallSummary/Feedback.tsx b/sample-apps/react/react-dogfood/components/EndCallSummary/Feedback.tsx
new file mode 100644
index 0000000000..a79b5161f4
--- /dev/null
+++ b/sample-apps/react/react-dogfood/components/EndCallSummary/Feedback.tsx
@@ -0,0 +1,213 @@
+import { HTMLInputTypeAttribute, useMemo, useState } from 'react';
+import clsx from 'clsx';
+import { useField, useForm } from 'react-form';
+import { useCall, Icon } from '@stream-io/video-react-sdk';
+import { getCookie } from '../../helpers/getCookie';
+import { FeedbackType } from './FeedbackType';
+
+export type Props = {
+ className?: string;
+ callId?: string;
+ rating?: number;
+ submitSuccess: () => void;
+ callData?: any;
+ onClose: () => void;
+};
+
+function required(value: string | number, name: string) {
+ if (!value) {
+ return `Please enter a ${name}`;
+ }
+ return false;
+}
+
+const Input = (props: {
+ className?: string;
+ type: HTMLInputTypeAttribute;
+ placeholder: string;
+ name: string;
+ required?: boolean;
+}) => {
+ const { name, className, ...rest } = props;
+ const {
+ meta: { error, isTouched },
+ getInputProps,
+ } = useField(name, {
+ validate: props.required ? (value) => required(value, name) : undefined,
+ });
+
+ return (
+
+ );
+};
+
+const TextArea = (props: {
+ className?: string;
+ placeholder: string;
+ name: string;
+ required?: boolean;
+}) => {
+ const { name, className, ...rest } = props;
+ const {
+ meta: { error, isTouched },
+ getInputProps,
+ } = useField(name, {
+ validate: props.required ? (value) => required(value, name) : undefined,
+ });
+
+ return (
+
+ );
+};
+
+type FeedbackFormType = {
+ email?: string;
+ message?: string;
+};
+
+const basePath = process.env.NEXT_PUBLIC_BASE_PATH || '';
+
+export const Feedback = ({
+ className,
+ callId,
+ rating,
+ submitSuccess,
+ callData,
+ onClose,
+}: Props) => {
+ const [errorMessage, setError] = useState
(null);
+ const [selectedFeedbackTypes, setSelectedFeedbackTypes] = useState<
+ string[] | undefined
+ >(undefined);
+ const call = useCall();
+ const defaultValues = useMemo(
+ () => ({
+ email: '',
+ message: '',
+ rating: 0,
+ selectedFeedbackTypes: undefined,
+ callData: undefined,
+ }),
+ [],
+ );
+ const {
+ Form,
+ meta: { isSubmitting },
+ } = useForm({
+ defaultValues,
+ onSubmit: async (values: FeedbackFormType) => {
+ await call
+ ?.submitFeedback(Math.min(Math.max(1, rating || 1), 5), {
+ reason: values.message,
+ custom: {
+ ...values,
+ callData: callData,
+ selectedFeedbackTypes: selectedFeedbackTypes,
+ },
+ })
+ .catch((err) => console.warn(`Failed to submit call feedback`, err));
+
+ const pageUrl = new URL(window.location.href);
+ pageUrl.searchParams.set('id', callId || call?.id || '');
+
+ const response = await fetch(
+ `https://getstream.io/api/crm/video_feedback/`,
+ {
+ method: 'POST',
+ headers: {
+ Accept: 'application/json',
+ 'Content-Type': 'application/json',
+ 'X-CSRFToken': getCookie('csrftoken') || '',
+ },
+ body: JSON.stringify({
+ email: values.email || 'anonymous-feedback@getstream.io',
+ message: values.message || '',
+ rating: rating,
+ page_url: pageUrl.toString(),
+ selected_feedback_types: selectedFeedbackTypes,
+ call_data: callData,
+ }),
+ },
+ );
+ if (response.status >= 400) {
+ setError('Something went wrong, please try again.');
+ } else {
+ submitSuccess();
+ }
+ },
+ debugForm: false,
+ });
+
+ return (
+
+
+
+
+
+

+
+ Let us know what went wrong?
+
+
+ {errorMessage && errorMessage}
+ {!errorMessage && 'We value your feedback'}
+
+
+
setSelectedFeedbackTypes(types)}
+ />
+
+
+
+ );
+};
diff --git a/sample-apps/react/react-dogfood/components/EndCallSummary/FeedbackType.tsx b/sample-apps/react/react-dogfood/components/EndCallSummary/FeedbackType.tsx
new file mode 100644
index 0000000000..a2f38ac344
--- /dev/null
+++ b/sample-apps/react/react-dogfood/components/EndCallSummary/FeedbackType.tsx
@@ -0,0 +1,61 @@
+import { Icon } from '@stream-io/video-react-sdk';
+import { useState, useEffect } from 'react';
+import clsx from 'clsx';
+
+type Props = {
+ handelSelectFeedback: (types: string[] | undefined) => void;
+ className?: string;
+};
+
+export const FeedbackType = ({ handelSelectFeedback, className }: Props) => {
+ const [selectedTypes, setSelectedTypes] = useState(
+ undefined,
+ );
+
+ const types = ['Video', 'Audio', 'Other'];
+
+ const handleSelectType = (type: string) => {
+ setSelectedTypes((prevTypes) => [...(prevTypes || []), type]);
+ };
+
+ const handleRemoveType = (type: string) => {
+ setSelectedTypes((prevTypes) =>
+ (prevTypes || []).filter((t) => t !== type),
+ );
+ };
+
+ useEffect(() => {
+ handelSelectFeedback(selectedTypes);
+ }, [selectedTypes]);
+
+ return (
+
+ {types.map((type) => (
+
+ selectedTypes?.includes(type)
+ ? handleRemoveType(type)
+ : handleSelectType(type)
+ }
+ className={clsx(
+ 'rd__summary-feedback-type-item',
+ selectedTypes?.includes(type) &&
+ 'rd__summary-feedback-type-item--selected',
+ )}
+ >
+ {!selectedTypes?.includes(type) && (
+
+ )}
+ {type}
+ {selectedTypes?.includes(type) && (
+
+ )}
+
+ ))}
+
+ );
+};
diff --git a/sample-apps/react/react-dogfood/components/EndCallSummary/Header.tsx b/sample-apps/react/react-dogfood/components/EndCallSummary/Header.tsx
new file mode 100644
index 0000000000..6f5db4ce96
--- /dev/null
+++ b/sample-apps/react/react-dogfood/components/EndCallSummary/Header.tsx
@@ -0,0 +1,59 @@
+import Image from 'next/image';
+import Link from 'next/link';
+import { Icon } from '@stream-io/video-react-sdk';
+
+export interface HeaderProps {
+ rejoin: () => void;
+ startNewCall: () => void;
+ setShowRecordings: () => void;
+}
+
+export function Header({
+ rejoin,
+ startNewCall,
+ setShowRecordings,
+}: HeaderProps) {
+ return (
+
+
+
+
+
+
+
Your Call Has Ended.
+
+ Rejoin or start a new call to continue testing.
+
+
+
+
+
+
+
+
+
+
+
+ );
+}
diff --git a/sample-apps/react/react-dogfood/components/EndCallSummary/NetworkStatus.tsx b/sample-apps/react/react-dogfood/components/EndCallSummary/NetworkStatus.tsx
new file mode 100644
index 0000000000..b6b9d7e14e
--- /dev/null
+++ b/sample-apps/react/react-dogfood/components/EndCallSummary/NetworkStatus.tsx
@@ -0,0 +1,36 @@
+import clsx from 'clsx';
+
+type NetworkStatusProps = {
+ status: 'red' | 'yellow' | 'green' | 'neutral';
+ children: React.ReactNode;
+ className?: string;
+};
+
+export function NetworkStatus({
+ status,
+ children,
+ className,
+}: NetworkStatusProps) {
+ let bars = undefined;
+
+ bars = Array.from({ length: 12 }, (_, index) => {
+ return (
+
+ );
+ });
+
+ return (
+
+ );
+}
diff --git a/sample-apps/react/react-dogfood/components/EndCallSummary/Notification.tsx b/sample-apps/react/react-dogfood/components/EndCallSummary/Notification.tsx
new file mode 100644
index 0000000000..b5f30ec6d2
--- /dev/null
+++ b/sample-apps/react/react-dogfood/components/EndCallSummary/Notification.tsx
@@ -0,0 +1,30 @@
+import clsx from 'clsx';
+import { Icon } from '@stream-io/video-react-sdk';
+
+type NotificationProps = {
+ message: string;
+ variant: 'success' | 'error' | 'info' | 'caution';
+};
+
+export const Notification = ({ message, variant }: NotificationProps) => {
+ const icon = {
+ success: 'success',
+ error: 'error',
+ info: 'info',
+ caution: 'caution',
+ };
+
+ return (
+
+
+ {message}
+
+ );
+};
diff --git a/sample-apps/react/react-dogfood/components/EndCallSummary/Rating.tsx b/sample-apps/react/react-dogfood/components/EndCallSummary/Rating.tsx
new file mode 100644
index 0000000000..78f4dc73c3
--- /dev/null
+++ b/sample-apps/react/react-dogfood/components/EndCallSummary/Rating.tsx
@@ -0,0 +1,61 @@
+import { Icon } from '@stream-io/video-react-sdk';
+import clsx from 'clsx';
+import { useCallback, useState } from 'react';
+
+type RatingProps = {
+ rating: { current: number; maxAmount: number };
+ handleSetRating: (value: { current: number; maxAmount: number }) => void;
+};
+
+export function Rating({ rating, handleSetRating }: RatingProps) {
+ const [hoveredGrade, setHoveredGrade] = useState(null);
+
+ const getColor = (v: number) =>
+ v <= 2 ? 'bad' : v > 2 && v <= 4 ? 'good' : 'great';
+
+ const handleRating = useCallback(
+ (grade: number) => {
+ handleSetRating({
+ ...rating,
+ maxAmount: rating.maxAmount,
+ current: grade,
+ });
+ },
+ [handleSetRating, rating],
+ );
+
+ return (
+
+ {[...new Array(rating.maxAmount)].map((_, index) => {
+ const grade = index + 1;
+ const active = grade <= rating.current;
+ const isHovered = hoveredGrade !== null && grade <= hoveredGrade;
+
+ const modifier = isHovered
+ ? getColor(hoveredGrade!)
+ : active
+ ? getColor(rating.current)
+ : getColor(grade);
+
+ return (
+
handleRating(grade)}
+ onMouseEnter={() => setHoveredGrade(grade)}
+ onMouseLeave={() => setHoveredGrade(null)}
+ >
+
+
+ );
+ })}
+
+ );
+}
diff --git a/sample-apps/react/react-dogfood/components/EndCallSummary/Recordings.tsx b/sample-apps/react/react-dogfood/components/EndCallSummary/Recordings.tsx
new file mode 100644
index 0000000000..2c3e5eece1
--- /dev/null
+++ b/sample-apps/react/react-dogfood/components/EndCallSummary/Recordings.tsx
@@ -0,0 +1,19 @@
+import { CallRecordings } from '../CallRecordings';
+import { Icon } from '@stream-io/video-react-sdk';
+
+export function Recordings({
+ className,
+ onClose,
+}: {
+ className?: string;
+ onClose: () => void;
+}) {
+ return (
+
+ );
+}
diff --git a/sample-apps/react/react-dogfood/components/EndCallSummary/edges.ts b/sample-apps/react/react-dogfood/components/EndCallSummary/edges.ts
new file mode 100644
index 0000000000..849e0e6ac7
--- /dev/null
+++ b/sample-apps/react/react-dogfood/components/EndCallSummary/edges.ts
@@ -0,0 +1,26 @@
+export const edges = {
+ 'aws-cap1.sfu-93774aa259f5': 'Cape Town',
+ 'aws-jak1.sfu-165e19e75f19': 'Jakarta',
+ 'aws-sin1.sfu-1f22fbe52d75': 'Singapore',
+ 'aws-hyd1.sfu-47983ecf3d2a': 'Hyderabad',
+ 'aws-mum1.sfu-615b2388f3ce': 'Mumbai',
+ 'aws-mum1.sfu-63b101084fd8': 'Mumbai',
+ 'aws-mum1.sfu-81f0b5a91d07': 'Mumbai',
+ 'aws-tel1.sfu-8a5b3af98a3a': 'Tel Aviv',
+ 'aws-tok1.sfu-cdd6cec09da4': 'Tokyo',
+ 'aws-uae1.sfu-ec81f73f238c': 'Dubai',
+ 'aws-ire1.sfu-34b3d1decec4': 'Dublin',
+ 'aws-fra1.sfu-4fb57bd52b53': 'Frankfurt',
+ 'aws-mil1.sfu-8d6cac798fcf': 'Milan',
+ 'aws-par1.sfu-93ba78cd9a6e': 'Paris',
+ 'aws-lon1.sfu-a7f8e5b12ebc': 'London',
+ 'aws-spa1.sfu-aa9fcf2b7b47': 'Madrid',
+ 'aws-stk1.sfu-bf56b6f0a809': 'Stockholm',
+ 'aws-ohi1.sfu-0be3135dedde': 'Columbus',
+ 'aws-cal1.sfu-39f6c064a25b': 'Fresno',
+ 'aws-ore1.sfu-5ed2e3c83420': 'Bend',
+ 'aws-vir1.sfu-8d90b67cbccc': 'Richmond',
+ 'aws-can1.sfu-fe14e570ea0d': 'Quebec City',
+ 'aws-syd1.sfu-b79b7b557f02': 'Sydney',
+ 'aws-sao1.sfu-6c2a276ec712': 'São Paulo',
+};
diff --git a/sample-apps/react/react-dogfood/components/MeetingUI.tsx b/sample-apps/react/react-dogfood/components/MeetingUI.tsx
index 280fc22fd5..6c21a66050 100644
--- a/sample-apps/react/react-dogfood/components/MeetingUI.tsx
+++ b/sample-apps/react/react-dogfood/components/MeetingUI.tsx
@@ -20,8 +20,7 @@ import {
useWakeLock,
} from '../hooks';
import { ActiveCall } from './ActiveCall';
-import { Feedback } from './Feedback/Feedback';
-import { DefaultAppHeader } from './DefaultAppHeader';
+import { EndCallSummaryView } from './EndCallSummary/EndCallSummaryView';
const contents = {
'error-join': {
@@ -40,6 +39,7 @@ export const MeetingUI = ({ chatClient, mode }: MeetingUIProps) => {
const [show, setShow] = useState<
'lobby' | 'error-join' | 'error-leave' | 'loading' | 'active-call' | 'left'
>('lobby');
+ const [joinTime, setJoinTime] = useState(undefined);
const [lastError, setLastError] = useState();
const router = useRouter();
const call = useCall();
@@ -62,6 +62,7 @@ export const MeetingUI = ({ chatClient, mode }: MeetingUIProps) => {
const onJoin = useCallback(
async ({ fastJoin = false } = {}) => {
+ setJoinTime(new Date());
if (!fastJoin) setShow('loading');
if (!call) throw new Error('No active call found');
try {
@@ -173,14 +174,13 @@ export const MeetingUI = ({ chatClient, mode }: MeetingUIProps) => {
ComponentToRender = ;
} else if (show === 'left') {
ComponentToRender = (
- <>
-
-
- >
+
+ setShow('active-call')}
+ startNewCall={() => setShow('lobby')}
+ joinTime={joinTime}
+ />
+
);
} else if (!call) {
ComponentToRender = (
diff --git a/sample-apps/react/react-dogfood/public/stream-logo-blue.png b/sample-apps/react/react-dogfood/public/stream-logo-blue.png
new file mode 100644
index 0000000000..d972662808
Binary files /dev/null and b/sample-apps/react/react-dogfood/public/stream-logo-blue.png differ
diff --git a/sample-apps/react/react-dogfood/public/stream-logo-blue.svg b/sample-apps/react/react-dogfood/public/stream-logo-blue.svg
new file mode 100644
index 0000000000..4a52f3edd5
--- /dev/null
+++ b/sample-apps/react/react-dogfood/public/stream-logo-blue.svg
@@ -0,0 +1,9 @@
+
diff --git a/sample-apps/react/react-dogfood/public/video-demo-clients.png b/sample-apps/react/react-dogfood/public/video-demo-clients.png
new file mode 100644
index 0000000000..012a82021d
Binary files /dev/null and b/sample-apps/react/react-dogfood/public/video-demo-clients.png differ
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/badge.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/badge.scss
new file mode 100644
index 0000000000..1488e8e489
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/badge.scss
@@ -0,0 +1,86 @@
+.rd__leave{
+ .rd__badge{
+ background-color: var(--str-video__bage-default);
+ color: var(--str-video__badge-default-text);
+ border-radius: var(--str-video__border-radius-sm);
+ padding: var(--str-video__spacing-xxs) var(--str-video__spacing-md);
+ font-weight: 500;
+ display: flex;
+ align-items: center;
+ width: 100%;
+ gap: var(--str-video__spacing-xs);
+ text-decoration: none;
+
+ .str-video__icon{
+ background-color: var(--str-video__badge-default-icon);
+ }
+
+ box-shadow: 0px 0px 24px 8px rgba(0, 0, 0, 0.05);
+
+
+
+ @include respond-above(md) {
+ &--fill{
+ width: 100%;
+ }
+
+ &--contain{
+ width: fit-content;
+ }
+ }
+
+ &--small{
+ font-size: var(--str-video__font-size-sm);
+ min-height: 40px;
+
+ @include respond-above(md) {
+ font-size: var(--str-video__font-size-md);
+ }
+ }
+
+ &--large{
+ font-size: var(--str-video__font-size-md);
+ min-height: 32px;
+
+ @include respond-above(md) {
+ font-size: var(--str-video__font-size-xxl);
+ }
+ }
+
+ &--link{
+ cursor: pointer;
+ color: var(--str-video__icon-default);
+ text-decoration: none;
+ &:hover{
+ background-color: var(--str-video__bage-hover);
+ color: var(--str-video__badge-hover-text);
+
+ .str-video__icon{
+ background-color: var(--str-video__badge-hover-icon);
+ }
+ }
+ }
+
+ &-status{
+ width: 14px;
+ height: 14px;
+ border-radius: var(--str-video__border-radius-sm);
+
+ box-shadow: 0px 1px 4px 0px rgba(255, 255, 255, 0.53) inset;
+ box-shadow: 0px -1px 4px 0px rgba(0, 0, 0, 0.25) inset;
+
+
+ &--good{
+ background-color: var(--str-video__alert-success);
+ }
+
+ &--average{
+ background-color: var(--str-video__alert-caution);
+ }
+
+ &--bad{
+ background-color: var(--str-video__alert-warning);
+ }
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/build-and-ship.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/build-and-ship.scss
new file mode 100644
index 0000000000..eaf593e97b
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/build-and-ship.scss
@@ -0,0 +1,75 @@
+.rd__leave{
+ .rd__build-and-ship{
+ display: flex;
+ flex-direction: column;
+ align-items: flex-start;
+ gap: var(--str-video__spacing-sm);
+ height: 100%;
+ width: 100%;
+ min-height: 350px;
+
+ background-size: cover;
+ background-position: left;
+ background-repeat: no-repeat;
+ // background-image: url("/video-demo-clients.png");
+ background-position-y: 40px;
+
+ @include respond-above(md) {
+ min-height: auto;
+ }
+
+ &--title{
+ font-size: var(--str-video__font-size-xxl);
+ font-weight: 500;
+ color: var(--str-video__icon-default);
+ text-transform: capitalize;
+ margin: 0;
+ color: var(--str-video__header-color);
+ }
+
+ &--description{
+ font-size: var(--str-video__font-size-lg);
+ font-weight: 400;
+ color: #B0B4B7;
+ margin: 0;
+ }
+
+ &--content{
+ max-width: 80%;
+ height: 100%;
+ display: flex;
+ flex-direction: column;
+ justify-content: space-between;
+
+ &-text{
+ display: flex;
+ flex-direction: column;
+ gap: var(--str-video__spacing-md);
+ }
+ }
+
+ &--button-container{
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ justify-content: flex-end;
+ width: 100%;
+ }
+
+ &--button{
+ background-color: var(--str-video__button-primary-active);
+ border-radius: var(--str-video__border-radius-sm);
+ font-weight: 600;
+ color: var( --str-video__text-color);
+ font-size: var(--str-video__font-size-md);
+ border: none;
+ display: flex;
+ align-items: center;
+ width: 100%;
+ width: fit-content;
+ border-radius: var(--str-video__border-radius-lg);
+ padding: var(--str-video__spacing-md) var(--str-video__spacing-lg);
+ text-decoration: none;
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/card.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/card.scss
new file mode 100644
index 0000000000..be0000d265
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/card.scss
@@ -0,0 +1,60 @@
+.rd__leave{
+ .rd__card{
+ width: 100%;
+ display: flex;
+ flex-direction: column;
+ background-color: var(--str-video__base-color6);
+ border-radius: var(--str-video__border-radius-card);
+ gap: var(--str-video__spacing-sm);
+ padding: var(--str-video__spacing-lg);
+
+ &--parent{
+ display: flex;
+ flex-direction: column;
+ padding: 0;
+ }
+
+ &--title{
+ font-size: var(--str-video__font-size-md);
+ font-weight: 400;
+ color: #B0B4B7;
+ text-transform: capitalize;
+ margin: 0;
+ }
+ &--link,
+ &--tooltip{
+ .str-video__icon{
+ width: 24px;
+ height: 24px;
+ background-color: var(--str-video__icon-pressed);
+ &:hover{
+ background-color: var(--str-video__icon-hover);
+ cursor: pointer;
+ }
+ }
+ }
+
+ &--header{
+ display: flex;
+ flex-direction: row;
+ justify-content: space-between;
+ align-items: center;
+ }
+
+ &--content{
+ display: flex;
+ gap: var(--str-video__spacing-sm);
+
+
+ &-row{
+ flex-direction: row;
+
+ }
+ &-column{
+ flex-direction: column;
+ height: 100%;
+ width: 100%;;
+ }
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/edge-server.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/edge-server.scss
new file mode 100644
index 0000000000..1ab4e6a7f5
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/edge-server.scss
@@ -0,0 +1,21 @@
+.rd__leave{
+ .rd__edge-server{
+ display: flex;
+ flex-direction: column;
+ max-height: 100px;
+ overflow-y: scroll;
+ overflow-x: hidden;
+ gap: var(--str-video__spacing-sm);
+ }
+
+ .rd__edge-server--country{
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+ max-width: 80px;
+
+ @include respond-above(md) {
+ max-width: 100%;
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/feedback-type.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/feedback-type.scss
new file mode 100644
index 0000000000..0a673d5989
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/feedback-type.scss
@@ -0,0 +1,43 @@
+.rd__summary-feedback-type {
+ display: flex;
+ flex-direction: row;
+ gap: var(--str-video__spacing-md);
+ flex-wrap: wrap;
+}
+
+.rd__summary-feedback-type-item {
+ display: flex;
+ align-items: center;
+ flex-direction: row;
+ gap: var(--str-video__spacing-lg);
+ border: 1px dashed #656B72;
+
+ border-radius: var(--str-video__border-radius-xs);
+ padding: var(--str-video__spacing-sm) var(--str-video__spacing-md);
+ color:#656B72;
+ font-size: var(--str-video__font-size-md);
+ font-weight: 600;
+
+ &:hover{
+ cursor: pointer;
+ }
+
+ &--selected {
+ color: var(--str-video__text-color1);
+ border: 1px solid transparent;
+
+
+ }
+
+ &--close {
+ background-color: #656B72;
+ width: 16px;
+ height: 16px;
+ }
+ &--add {
+ background-color: #656B72;
+ width: 16px;
+ height: 16px;
+ }
+}
+
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/feedback.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/feedback.scss
new file mode 100644
index 0000000000..30b59b20ee
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/feedback.scss
@@ -0,0 +1,138 @@
+.rd__summary-feedback {
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ text-align: center;
+
+ background-color: #19232D !important;
+ border-radius: var(--str-video__border-radius-lg);
+ padding: 32px;
+
+ width: 100%;
+ border: 1px solid #323B44;
+ box-shadow: 0 14px 34px rgba(0, 0, 0, 0.75);
+
+ height: 100%;
+
+ @include respond-above(md) {
+ height: auto;
+ }
+}
+
+.rd__summary-feedback-close {
+ position: absolute;
+ top: 16px;
+ right: 16px;
+
+ .str-video__icon{
+ height: 28px;
+ width: 28px;
+ background-color: #656B72;
+ }
+
+
+ &:hover{
+ cursor: pointer;
+
+
+ .str-video__icon{
+ background-color: var(--str-video__text-color1);
+ }
+ }
+}
+
+.rd__summary-feedback-header {
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: center;
+ gap: var(--str-video__spacing-md);
+}
+
+.rd__summary-feedback-image {
+ width: 140px;
+}
+
+.rd__summary-feedback-heading {
+ font-weight: 500;
+ font-size: 24px;
+ margin: 0;
+}
+
+.rd__summary-feedback-description {
+ color: var(--str-video__description-default);
+ font-size: var(--str-video__font-size-md);
+ margin: 0;
+}
+
+.rd__summary-feedback-type {
+
+ margin-top: var(--str-video__spacing-lg);
+}
+
+.rd__summary-feedback-form {
+ display: flex;
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+ margin-top: var(--str-video__spacing-lg);
+ width: 100%;
+}
+
+.rd__summary-feedback-input,
+.rd__summary-feedback-textarea {
+ background-color: #323B44;
+ border-radius: var(--str-video__border-radius-md);
+ padding: var(--str-video__spacing-xs) var(--str-video__spacing-md);
+ margin-bottom: var(--str-video__spacing-md);
+ border: 1px solid var(--str-video__base-color3);
+ width: 100%;
+ color:#EFF0F1;
+ border: 1px solid transparent;
+
+ &:placeholder {
+ color: #EFF0F1;
+ }
+
+ &:focus,
+ &:focus-visible {
+ border: 1px solid var(--str-video__base-color1);
+ }
+}
+
+.rd__summary-feedback-textarea {
+ height: 100px;
+}
+
+.rd__summary-feedback-footer {
+ width: 100%;
+ padding-top: var(--str-video__spacing-lg);
+ padding-bottom: var(--str-video__spacing-lg);
+ display: flex;
+ flex-direction: column;
+ gap: var(--str-video__spacing-sm);
+}
+.rd__summary-feedback-actions {
+ display: flex;
+ justify-content: space-between;
+ gap: var(--str-video__spacing-md);
+}
+
+.rd__summary-feedback-consent {
+ color: var(--str-video__icon-pressed);
+ font-size: 10px;
+}
+
+.rd__summary-feedback-submit { background-color: var(--str-video__button-primary-active);
+ border-radius: var(--str-video__border-radius-sm);
+ font-weight: 600;
+ color: var( --str-video__text-color);
+ font-size: var(--str-video__font-size-md);
+ border: none;
+ display: flex;
+ align-items: center;
+ width: 100%;
+ border-radius: var(--str-video__border-radius-lg);
+ padding: var(--str-video__spacing-md) var(--str-video__spacing-lg);
+ justify-content: center;
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/header.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/header.scss
new file mode 100644
index 0000000000..bffa94bb09
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/header.scss
@@ -0,0 +1,152 @@
+
+.rd__leave{
+ &--header{
+ display: flex;
+ flex-direction: column;
+ align-items: flex-start;
+ justify-content: center;
+ gap: var(--str-video__spacing-xl);
+ width: 100%;
+
+ @include respond-above(md) {
+ flex-direction: row;
+ justify-content: space-between;
+ align-items: center;
+ gap: var(--str-video__spacing-sm);
+
+ }
+
+ &-logo{
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: center;
+ gap: var(--str-video__spacing-md);
+ width: 100%;
+
+ @include respond-above(md) {
+ flex-direction: row;
+ justify-content: flex-start;
+ align-items: flex-start;
+
+ }
+ }
+
+ &-text{
+ display: flex;
+ flex-direction: column;
+ gap: var(--str-video__spacing-xs);
+ align-items: center;
+
+ @include respond-above(md) {
+ align-items: flex-start;
+ }
+ }
+
+ &-title{
+ margin: 0;
+ font-size: var(--str-video__font-size-xxl);
+ font-weight: 600;
+ color: #EFF0F1;
+ text-transform: capitalize;
+ }
+
+ &-description{
+ margin: 0;
+ font-size: var(--str-video__font-size-sm);
+ font-weight: 600;
+ color: #656B72;
+ text-align: center;
+
+
+ @include respond-above(md) {
+ text-align: left;
+ font-size: var(--str-video__font-size-md);
+ font-weight: 600;
+ color: #656B72;
+ text-align: left;
+ text-transform: capitalize;
+ }
+ }
+
+ &-links{
+ display: flex;
+ flex-direction: row;
+ gap: var(--str-video__spacing-lg);
+ justify-content: space-between;
+ width: 100%;
+
+ flex-direction: row-reverse;
+
+ @include respond-above(md) {
+ flex-direction: row;
+ justify-content: flex-end;
+ }
+
+ &-buttons{
+ display: flex;
+ flex-direction: row;
+ gap: var(--str-video__spacing-md);
+ }
+ }
+
+ &-link{
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ gap: var(--str-video__spacing-sm);
+ font-size: var(--str-video__font-size-md);
+ font-weight: 600;
+ color: var(--str-video__text-color1);
+ text-transform: capitalize;
+ margin: 0;
+ text-decoration: none;
+ padding: var(--str-video__spacing-md) var(--str-video__spacing-lg);
+ background-color: var(--str-video__base-color4);
+ border: none;
+
+ &:hover{
+ cursor: pointer;
+ text-decoration: underline;
+ text-underline-offset: 4px;
+ }
+
+ &--recordings{
+
+ .rd__leave--header-link-text{
+ display: none;
+
+ @include respond-above(md) {
+ display: block;
+ }
+ }
+ }
+
+ &--rejoin{
+ border-radius: var(--str-video__border-radius-lg);
+ border: 1px solid var(--str-video__button-default-hover);
+
+ &:hover{
+ background-color: var(--str-video__bage-hover);
+ color: var(--str-video__badge-hover-text);
+ cursor: pointer;
+ text-decoration: none;
+ }
+ }
+
+ &--new-call{
+ border-radius: var(--str-video__border-radius-lg);
+ border: 1px solid var(--str-video__base-color6);
+ background-color: var(--str-video__base-color6);
+
+ &:hover{
+ background-color: var(--str-video__bage-hover);
+ color: var(--str-video__badge-hover-text);
+ cursor: pointer;
+ text-decoration: none;
+ }
+
+ }
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/index.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/index.scss
new file mode 100644
index 0000000000..bb566bf072
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/index.scss
@@ -0,0 +1,257 @@
+@import './badge.scss';
+@import './build-and-ship.scss';
+@import './card.scss';
+@import './edge-server.scss';
+@import './feedback.scss';
+@import './feedback-type.scss';
+@import './header.scss';
+@import './modal.scss';
+@import './network-status.scss';
+@import './notifications.scss';
+@import './review.scss';
+@import './recordings.scss';
+@import './rooms.scss';
+@import './sdks.scss';
+@import './shared.scss';
+
+.rd__leave-container{
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ width: 100%;
+ height: 100%;
+}
+
+.rd__leave{
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ width: 100%;
+ height: 100%;
+ overflow-y: scroll;
+
+ color: var(--str-video__icon-default);
+ padding: var(--str-video__spacing-lg);
+ gap: var(--str-video__spacing-sm);
+ max-width: 1092px;
+
+ @include respond-above(md) {
+ justify-content: center;
+
+ }
+
+ &--row{
+ display: grid;
+ width: 100%;
+
+ gap: var(--str-video__spacing-sm);
+
+
+ &-first{
+ grid-template-columns: 1fr 1fr;
+ grid-template-areas: 'quality time-to-connect'
+ 'latency-average video-codex';
+
+ .rd__leave--row-quality{
+ grid-area: quality;
+ }
+
+ .rd__leave--row-time-to-connect{
+ grid-area: time-to-connect;
+ }
+
+ .rd__leave--row-latency-average{
+ grid-area: latency-average;
+ }
+
+ .rd__leave--row-video-codex{
+ grid-area: video-codex;
+ }
+ }
+
+ &-second{
+ grid-template-columns: 1fr;
+ grid-template-areas: 'edge-networks' 'third' 'fourth' ;
+
+ .rd__leave--row-edge-networks{
+ grid-area: edge-networks;
+ }
+
+ .rd__leave--row-rooms{
+ grid-area: rooms;
+ }
+
+ .rd__leave--row-review{
+ grid-area: review;
+ }
+
+ .rd__leave--row-build-and-ship{
+ grid-area: build-and-ship;
+ }
+
+ .rd__leave--row-sdks{
+ grid-area: sdks;
+ }
+
+ .rd__leave--row-third{
+ grid-area: third;
+ display: grid;
+ }
+
+ .rd__leave--row-fourth{
+ grid-area: fourth;
+ display: grid;
+
+ }
+ }
+
+ &-third{
+ grid-template-columns: 1fr;
+ grid-template-areas: 'rooms' 'review';
+ }
+
+ &-fourth{
+ grid-template-columns: 1fr;
+ grid-template-areas: 'sdks' 'build-and-ship';
+ }
+ }
+
+ @include respond-above(sm) {
+ &-first{
+ grid-template-columns: 1fr 1fr;
+ }
+ }
+
+
+
+ @include respond-above(md) {
+ &--row{
+
+ &-first{
+ grid-template-columns: 1fr 1fr 1fr 1fr;
+ grid-template-areas: 'quality time-to-connect latency-average video-codex';
+
+ }
+
+ &-second{
+ grid-template-columns: minmax(347.5px, 0.25fr) 1fr;
+ grid-template-areas: 'edge-networks third'
+ 'edge-networks fourth';
+ }
+
+ &-third{
+ grid-template-columns: 1.1fr 0.9fr;
+ grid-template-areas: 'rooms review';
+ }
+
+ &-fourth{
+ grid-template-columns: 0.5fr 1.5fr;
+ grid-template-areas: 'sdks build-and-ship';
+ }
+ }
+ }
+}
+
+
+:root {
+ --str-video__network-bar-good: #00E2A1;
+ --str-video__network-bar-average: #FFD646;
+ --str-video__network-bar-bad: #DC433B;
+
+ --str-video__network-bar-neutral: #005FFF;
+
+ --str-video__good: #00E2A1;
+ --str-video__average: #FFD646;
+ --str-video__bad: #DC433B;
+
+ --str-video__notification-background-good: #1D2F34;
+ --str-video__notification-background-average: #353830;
+ --str-video__notification-background-bad: #31292F;
+
+ --str-video__border-radius-card: 16px;
+
+ --str-video__header-color: #EFF0F1;
+ --str-video__description-default: #b0b4b7;
+
+ --str-video__sdkIcon-default: #b0b4b7;
+ --str-video__sdkIcon-hover: #eff0f1;
+
+ --str-video__bage-default: #323B44;
+ --str-video__bage-hover:#4C535B;
+ --str-video__badge-default-text: #EFF0F1;
+ --str-video__badge-hover-text: #EFF0F1;
+ --str-video__badge-default-icon: #B0B4B7;
+ --str-video__badge-hover-icon: #EFF0F1;
+
+
+ --str-video__icon-new-tab: url('');
+ --str-video__icon-unity: url('');
+ --str-video__icon-swift: url('');
+ --str-video__icon-react: url('');
+ --str-video__icon--flutter: url('');
+ --str-video__icon--javascript: url('');
+ --str-video__icon--android: url('');
+
+ --str-video__icon--add: url('');
+ --str-video__icon--success: url('');
+ --str-video__icon--caution: url('');
+ --str-video__icon--error: url('');
+
+
+
+
+}
+
+.str-video__icon--new-tab{
+ mask-image: var(--str-video__icon-new-tab)
+}
+
+.str-video__icon--unity{
+ mask-image: var(--str-video__icon-unity);
+}
+
+.str-video__icon--swift{
+ mask-image: var(--str-video__icon-swift);
+}
+
+.str-video__icon--react{
+ mask-image: var(--str-video__icon-react);
+}
+
+.str-video__icon--flutter{
+ mask-image: var(--str-video__icon-flutter);
+}
+
+.str-video__icon--android{
+ mask-image: var(--str-video__icon--android);
+}
+
+.str-video__icon--javascript{
+ mask-image: var(--str-video__icon--javascript);
+}
+
+.str-video__icon--flutter {
+ mask-image: var(--str-video__icon--flutter);
+}
+
+.str-video__icon--add {
+ mask-image: var(--str-video__icon--add);
+}
+
+.str-video__icon--success {
+ mask-image: var(--str-video__icon--success);
+}
+
+.str-video__icon--caution {
+ mask-image: var(--str-video__icon--caution);
+}
+
+.str-video__icon--error {
+ mask-image: var(--str-video__icon--error);
+}
+
+
+
+
+
+
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/modal.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/modal.scss
new file mode 100644
index 0000000000..d049ebba47
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/modal.scss
@@ -0,0 +1,41 @@
+.rd__leave{
+ .rd__modal{
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: center;
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ z-index: 10;
+ gap: var(--str-video__spacing-md);
+
+ &--background{
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+ background-color: rgba(0, 0, 0, 0.3);
+ }
+
+ &--content{
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: center;
+ position: relative;
+ z-index: 11;
+
+ gap: var(--str-video__spacing-md);
+
+ @include respond-above(md) {
+ width: 420px;
+
+ }
+ }
+ }
+
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/network-status.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/network-status.scss
new file mode 100644
index 0000000000..1ad523b981
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/network-status.scss
@@ -0,0 +1,47 @@
+.rd__leave{
+ .rd__network-status{
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ justify-content: space-between;
+ gap: var(--str-video__spacing-md);
+
+ font-size: var(--str-video__font-size-md);
+ font-weight: 600;
+
+ .rd__network-bars{
+ display: flex;
+ flex-direction: row;
+ gap: var(--str-video__spacing-xxs);
+
+ .rd__network-bar {
+ width: 8px;
+ height: 24px;
+ background-color: #e0e0e0;
+ border-radius: var(--str-video__border-radius-sm);
+
+ &--good {
+ background-color: var(--str-video__network-bar-good);
+ }
+
+ &--average {
+ background-color: var(--str-video__network-bar-average);
+ }
+
+ &--bad {
+ background-color: var(--str-video__network-bar-bad);
+ }
+
+ &--neutral {
+ background-color: var(--str-video__network-bar-neutral);
+ }
+ }
+ }
+ }
+
+ .rd__leave--row-edge-networks-used{
+ .str-video__icon{
+ background-color: var(--str-video__network-bar-neutral);
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/notifications.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/notifications.scss
new file mode 100644
index 0000000000..60053684e2
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/notifications.scss
@@ -0,0 +1,50 @@
+.rd__leave{
+
+ .rd__notification{
+ display: flex;
+ flex-direction: row;
+ align-items: center;
+ gap: var(--str-video__spacing-xs);
+ padding: var(--str-video__spacing-sm);
+ border-radius: var(--str-video__border-radius-xs);
+ font-size: var(--str-video__font-size-md);
+ font-weight: 400;
+
+ .str-video__icon{
+ height: 16px;
+ width: 16px;
+ }
+
+ &--success{
+ color: var(--str-video__good);
+ background-color: var( --str-video__notification-background-good);
+ .str-video__icon{
+ background-color: var(--str-video__good);
+ }
+ }
+
+ &--error{
+ color: var(--str-video__bad);
+ background-color: var(--str-video__alert-warning-background);
+ .str-video__icon{
+ background-color: var(--str-video__bad);
+ }
+ }
+
+ &--info{
+ color: var(--str-video__alert-info);
+ background-color: var(--str-video__alert-caution);
+ .str-video__icon{
+ background-color: var(--str-video__alert-info);
+ }
+ }
+
+ &--caution{
+ color: var(--str-video__average);
+ background-color: var(--str-video__alert-caution-background);
+ .str-video__icon{
+ background-color: var(--str-video__average);
+ }
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/recordings.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/recordings.scss
new file mode 100644
index 0000000000..01dec5072c
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/recordings.scss
@@ -0,0 +1,42 @@
+.rd__summary-recordings {
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ text-align: center;
+
+ background-color: #19232D !important;
+ border-radius: var(--str-video__border-radius-lg);
+ padding: 32px;
+
+ width: 100%;
+ border: 1px solid #323B44;
+ box-shadow: 0 14px 34px rgba(0, 0, 0, 0.75);
+
+ height: 100%;
+
+ @include respond-above(md) {
+ height: auto;
+ }
+}
+
+.rd__summary-recordings-close {
+ position: absolute;
+ top: 16px;
+ right: 16px;
+
+ .str-video__icon{
+ height: 28px;
+ width: 28px;
+ background-color: #656B72;
+ }
+
+
+ &:hover{
+ cursor: pointer;
+
+
+ .str-video__icon{
+ background-color: var(--str-video__text-color1);
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/review.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/review.scss
new file mode 100644
index 0000000000..d6a8c2cc0e
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/review.scss
@@ -0,0 +1,77 @@
+.rd__leave{
+ .rd__leave--review{
+ display: flex;
+ flex-direction: column;
+ align-items: flex-start;
+ gap: var(--str-video__spacing-sm);
+
+ &-container{
+ &-success{
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: center;
+ height: 100%;
+ }
+ }
+
+ &-success{
+ align-items: center;
+ justify-content: center;
+ height: 100%;
+ }
+
+ &-title{
+ font-size: var(--str-video__font-size-xxl);
+ font-weight: 500;
+ color: var(--str-video__icon-default);
+ text-transform: capitalize;
+ margin: 0;
+ max-width: 80%;
+
+ &-success{
+ text-align: center;
+ width: 100%;
+ }
+ }
+ }
+
+ .rd__feedback-rating-stars {
+ width: 100%;
+ display: flex;
+ align-items: center;
+
+ gap: var(--str-video__spacing-xs);
+
+
+ @include respond-above(sm) {
+ gap: var(--str-video__spacing-md);
+ }
+
+ @include respond-above(md) {
+ // justify-content: space-between;
+ }
+ }
+
+ .rd__feedback-star {
+ cursor: pointer;
+ width: 44px;
+ height: 44px;
+ background-color: var(--str-video__icon-pressed);
+ }
+
+ .rd__feedback-star--active-bad,
+ .rd__feedback-star--bad:hover {
+ background-color: var(--str-video__bad);
+ }
+
+ .rd__feedback-star--active-good,
+ .rd__feedback-star--good:hover {
+ background-color: var(--str-video__average);
+ }
+
+ .rd__feedback-star--active-great,
+ .rd__feedback-star--great:hover {
+ background-color: var(--str-video__good);
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/rooms.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/rooms.scss
new file mode 100644
index 0000000000..19b94fca56
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/rooms.scss
@@ -0,0 +1,13 @@
+.rd__leave{
+ .rd__leave--rooms{
+ display: grid;
+ grid-template-columns: 1fr 1fr;
+ flex-direction: row;
+ flex-wrap: wrap;
+ gap: var(--str-video__spacing-sm);
+ }
+
+ .rd__leave--rooms-link{
+ text-decoration: none;
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/sdks.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/sdks.scss
new file mode 100644
index 0000000000..4a3d1266fb
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/sdks.scss
@@ -0,0 +1,49 @@
+.rd__leave{
+ .rd__sdks{
+ display: flex;
+ flex-direction: row;
+ justify-content: flex-start;
+ gap: var(--str-video__spacing-xs);
+
+
+
+
+ @include respond-above(sm) {
+ gap: var(--str-video__spacing-sm);
+ }
+
+ @include respond-above(md) {
+ flex-direction: row;
+ flex-wrap: wrap;
+ }
+
+
+
+ &--link{
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ width: fit-content;
+ min-height: 65px;
+ width: 57px;
+
+ @include respond-above(sm) {
+ width: auto;
+ }
+
+ @include respond-above(md) {
+ justify-content: center;
+ width: 65px;
+ }
+
+ &-icon{
+ padding: var(--str-video__spacing-lg) var(--str-video__spacing-sm);
+
+ .str-video__icon{
+ height: 32px;
+ width: 32px;
+ }
+ }
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/EndCallSummary/shared.scss b/sample-apps/react/react-dogfood/style/EndCallSummary/shared.scss
new file mode 100644
index 0000000000..2b4f0c65ae
--- /dev/null
+++ b/sample-apps/react/react-dogfood/style/EndCallSummary/shared.scss
@@ -0,0 +1,40 @@
+.rd__leave{
+ .rd__leave--button{
+ border-radius: var(--str-video__border-radius-sm);
+ font-weight: 600;
+ font-size: var(--str-video__font-size-md);
+ border: none;
+ display: flex;
+ align-items: center;
+ width: 100%;
+ width: fit-content;
+ text-transform: capitalize;
+ border-radius: var(--str-video__border-radius-lg);
+ padding: var(--str-video__spacing-sm) var(--str-video__spacing-md);
+ border: 1px solid transparent;
+
+ &-primary{
+ background-color: var(--str-video__button-primary-active);
+ border: 1px solid var(--str-video__button-primary-active);
+ color: var( --str-video__text-color);
+ }
+
+ &-secondary{
+ border: 1px solid var(--str-video__base-color6);
+ background-color: var(--str-video__base-color6);
+ color: var(--str-video__text-color1);
+
+ }
+
+ &-border{
+ color: var(--str-video__text-color1);
+ border: 1px solid var(--str-video__button-default-hover);
+ }
+ }
+
+ .rd__leave--hover{
+ &:hover{
+ cursor: pointer;
+ }
+ }
+}
diff --git a/sample-apps/react/react-dogfood/style/Feedback/Feedback.scss b/sample-apps/react/react-dogfood/style/Feedback/Feedback.scss
index e95bffff91..5c7e78d9f8 100644
--- a/sample-apps/react/react-dogfood/style/Feedback/Feedback.scss
+++ b/sample-apps/react/react-dogfood/style/Feedback/Feedback.scss
@@ -12,8 +12,17 @@
box-shadow: 0 14px 34px rgba(0, 0, 0, 0.75);
}
+
+
+.rd__feedback-header {
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: center;
+}
+
.rd__feedback-image {
- width: 300px;
+ width: 140px;
}
.rd__feedback-heading {
@@ -25,7 +34,7 @@
.rd__feedback-description {
color: var(--str-video__base-color2);
font-size: var(--str-video__font-size-sm);
- margin: var(--str-video__spacing-lg) 0 var(--str-video__spacing-md) 0;
+ margin: 0;
}
.rd__feedback-form {
@@ -62,36 +71,6 @@
padding-top: var(--str-video__spacing-lg);
padding-bottom: var(--str-video__spacing-lg);
}
-
-.rd__feedback-rating-stars {
- width: 100%;
- display: flex;
- align-items: center;
- justify-content: center;
- margin-bottom: var(--str-video__spacing-lg);
-}
-
-.rd__feedback-star {
- cursor: pointer;
- width: 56px;
- height: 56px;
-}
-
-.rd__feedback-star--active-bad,
-.rd__feedback-star--bad:hover {
- background-color: var(--str-video__alert-warning);
-}
-
-.rd__feedback-star--active-good,
-.rd__feedback-star--good:hover {
- background-color: var(--str-video__alert-caution);
-}
-
-.rd__feedback-star--active-great,
-.rd__feedback-star--great:hover {
- background-color: var(--str-video__alert-success);
-}
-
.rd__feedback-actions {
display: flex;
justify-content: space-between;
diff --git a/sample-apps/react/react-dogfood/style/index.scss b/sample-apps/react/react-dogfood/style/index.scss
index b744e90266..206da39777 100644
--- a/sample-apps/react/react-dogfood/style/index.scss
+++ b/sample-apps/react/react-dogfood/style/index.scss
@@ -41,3 +41,5 @@
@import 'DevMenu';
@import 'delete-account';
+
+@import 'EndCallSummary';
diff --git a/sample-apps/react/react-dogfood/style/leave.scss b/sample-apps/react/react-dogfood/style/leave.scss
index 3c059e831f..e69de29bb2 100644
--- a/sample-apps/react/react-dogfood/style/leave.scss
+++ b/sample-apps/react/react-dogfood/style/leave.scss
@@ -1,28 +0,0 @@
-.rd__leave {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- width: 100%;
- height: 100%;
- padding: var(--str-video__spacing-lg);
-
- &-content {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- text-align: center;
- width: 100%;
-
- .rd__feedback {
- box-shadow: 0px 14px 34px rgba(0, 0, 0, 0.75);
- }
- }
-}
-
-@include respond-above(sm) {
- .rd__leave-content {
- max-width: 35vw;
- }
-}