Skip to content

Commit

Permalink
initial fix
Browse files Browse the repository at this point in the history
  • Loading branch information
plutoless committed Oct 28, 2024
1 parent 41d1a26 commit b85932e
Show file tree
Hide file tree
Showing 7 changed files with 71 additions and 31 deletions.
1 change: 1 addition & 0 deletions playground/src/common/constant.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { IOptions, ColorItem, LanguageOptionItem, VoiceOptionItem, GraphOptionItem } from "@/types"
export const GITHUB_URL = "https://github.com/TEN-framework/TEN-Agent"
export const OPTIONS_KEY = "__options__"
export const OVERRIDEN_PROPERTIES_KEY = "__overriden__"
export const DEFAULT_OPTIONS: IOptions = {
channel: "",
userName: "",
Expand Down
17 changes: 15 additions & 2 deletions playground/src/common/storage.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { IOptions } from "@/types"
import { OPTIONS_KEY, DEFAULT_OPTIONS } from "./constant"
import { OPTIONS_KEY, DEFAULT_OPTIONS, OVERRIDEN_PROPERTIES_KEY } from "./constant"

export const getOptionsFromLocal = () => {
if (typeof window !== "undefined") {
Expand All @@ -11,11 +11,24 @@ export const getOptionsFromLocal = () => {
return DEFAULT_OPTIONS
}

export const getOverridenPropertiesFromLocal = () => {
if (typeof window !== "undefined") {
const data = localStorage.getItem(OVERRIDEN_PROPERTIES_KEY)
if (data) {
return JSON.parse(data)
}
}
return {}
}

export const setOptionsToLocal = (options: IOptions) => {
if (typeof window !== "undefined") {
localStorage.setItem(OPTIONS_KEY, JSON.stringify(options))
}
}


export const setOverridenPropertiesToLocal = (properties: Record<string, any>) => {
if (typeof window !== "undefined") {
localStorage.setItem(OVERRIDEN_PROPERTIES_KEY, JSON.stringify(properties))
}
}
8 changes: 5 additions & 3 deletions playground/src/components/authInitializer/index.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
"use client"

import { ReactNode, useEffect } from "react"
import { useAppDispatch, getOptionsFromLocal, getRandomChannel, getRandomUserId } from "@/common"
import { setOptions, reset } from "@/store/reducers/global"
import { useAppDispatch, getOptionsFromLocal, getRandomChannel, getRandomUserId, getOverridenPropertiesFromLocal } from "@/common"
import { setOptions, reset, setOverridenProperties } from "@/store/reducers/global"

interface AuthInitializerProps {
children: ReactNode;
Expand All @@ -15,16 +15,18 @@ const AuthInitializer = (props: AuthInitializerProps) => {
useEffect(() => {
if (typeof window !== "undefined") {
const options = getOptionsFromLocal()
const overridenProperties = getOverridenPropertiesFromLocal()
if (options && options.channel) {
dispatch(reset())
dispatch(setOptions(options))
} else {
dispatch(reset())
dispatch(setOptions({
dispatch(setOptions({
channel: getRandomChannel(),
userId: getRandomUserId(),
}))
}
dispatch(setOverridenProperties(overridenProperties))
}
}, [dispatch])

Expand Down
10 changes: 6 additions & 4 deletions playground/src/platform/pc/chat/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import {
useGraphExtensions,
apiGetExtensionMetadata,
} from "@/common"
import { setExtensionMetadata, setGraphName, setGraphs, setLanguage, setExtensions } from "@/store/reducers/global"
import { setExtensionMetadata, setGraphName, setGraphs, setLanguage, setExtensions, setOverridenPropertiesByGraph } from "@/store/reducers/global"
import { Button, Modal, Select, Tabs, TabsProps, } from 'antd';
import PdfSelect from "@/components/pdfSelect"

Expand All @@ -31,6 +31,7 @@ const Chat = () => {
const [modal2Open, setModal2Open] = useState(false)
const graphExtensions = useGraphExtensions()
const extensionMetadata = useAppSelector(state => state.global.extensionMetadata)
const overridenProperties = useAppSelector(state => state.global.overridenProperties)


// const chatItems = genRandomChatList(10)
Expand Down Expand Up @@ -109,9 +110,10 @@ const Chat = () => {
initialData={node["property"] || {}}
metadata={metadata ? metadata.api.property : {}}
onUpdate={(data) => {
let nodesMap = JSON.parse(JSON.stringify(graphExtensions))
nodesMap[key]["property"] = data
dispatch(setExtensions({ graphName, nodesMap }))
// clone the overridenProperties
let nodesMap = JSON.parse(JSON.stringify(overridenProperties[graphName] || {}))
nodesMap[key] = data
dispatch(setOverridenPropertiesByGraph({ graphName, nodesMap }))
}}
></EditableTable>
}
Expand Down
32 changes: 18 additions & 14 deletions playground/src/platform/pc/chat/table/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ const EditableTable: React.FC<EditableTableProps> = ({ initialData, onUpdate, me
const [editingKey, setEditingKey] = useState<string>('');
const [form] = Form.useForm();
const inputRef = useRef<InputRef>(null); // Ref to manage focus
const updatedValuesRef = useRef<Record<string, string | number | boolean | null>>({});

// Function to check if the current row is being edited
const isEditing = (record: DataType) => record.key === editingKey;
Expand All @@ -55,25 +56,26 @@ const EditableTable: React.FC<EditableTableProps> = ({ initialData, onUpdate, me
const row = await form.validateFields();
const newData = [...dataSource];
const index = newData.findIndex((item) => key === item.key);

if (index > -1) {
const item = newData[index];
const valueType = metadata[key]?.type || 'string';
const updatedValue = row.value === '' ? null : convertToType(row.value, valueType); // Set to null if empty

newData.splice(index, 1, { ...item, value: updatedValue });
setDataSource(newData);
setEditingKey('');

// Notify the parent component of the update
const updatedData = Object.fromEntries(newData.map(({ key, value }) => [key, value]));
onUpdate(updatedData);

// Store the updated value in the ref
updatedValuesRef.current[key] = updatedValue;

// Notify the parent component of only the updated value
onUpdate({ [key]: updatedValue });
}
} catch (errInfo) {
console.log('Validation Failed:', errInfo);
}
};

};

// Toggle the checkbox for boolean values directly in the table cell
const handleCheckboxChange = (key: string, checked: boolean) => {
Expand All @@ -83,9 +85,11 @@ const EditableTable: React.FC<EditableTableProps> = ({ initialData, onUpdate, me
newData[index].value = checked; // Update the boolean value
setDataSource(newData);

// Notify the parent component of the update
const updatedData = Object.fromEntries(newData.map(({ key, value }) => [key, value]));
onUpdate(updatedData);
// Store the updated value in the ref
updatedValuesRef.current[key] = checked;

// Notify the parent component of only the updated value
onUpdate({ [key]: checked });
}
};

Expand All @@ -111,7 +115,7 @@ const EditableTable: React.FC<EditableTableProps> = ({ initialData, onUpdate, me
key: 'value',
render: (_, record: DataType) => {
const valueType = metadata[record.key]?.type || 'string';

// Always display the checkbox for boolean values
if (valueType === 'bool') {
return (
Expand All @@ -121,7 +125,7 @@ const EditableTable: React.FC<EditableTableProps> = ({ initialData, onUpdate, me
/>
);
}

// Inline editing for other types (string, number)
const editable = isEditing(record);
return editable ? (
Expand All @@ -143,7 +147,7 @@ const EditableTable: React.FC<EditableTableProps> = ({ initialData, onUpdate, me
</div>
);
},
},
},
];

return (
Expand Down
9 changes: 3 additions & 6 deletions playground/src/platform/pc/description/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ const Description = () => {
const [loading, setLoading] = useState(false)
const graphName = useAppSelector(state => state.global.graphName)
const graphNodes = useGraphExtensions()
const overridenProperties = useAppSelector(state => state.global.overridenProperties)

useEffect(() => {
if (channel) {
Expand All @@ -47,18 +48,14 @@ const Description = () => {
message.success("Agent disconnected")
stopPing()
} else {
let properties: Record<string, any> = {}
Object.keys(graphNodes).forEach(extensionName => {
properties[extensionName] = {}
properties[extensionName] = graphNodes[extensionName].property
})
let properties: Record<string, any> = overridenProperties[graphName] || {}
const res = await apiStartService({
channel,
userId,
graphName,
language,
voiceType,
properties: properties
properties
})
const { code, msg } = res || {}
if (code != 0) {
Expand Down
25 changes: 23 additions & 2 deletions playground/src/store/reducers/global.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { IOptions, IChatItem, Language, VoiceType } from "@/types"
import { createSlice, PayloadAction } from "@reduxjs/toolkit"
import { DEFAULT_OPTIONS, COLOR_LIST, setOptionsToLocal, genRandomChatList } from "@/common"
import { DEFAULT_OPTIONS, COLOR_LIST, setOptionsToLocal, genRandomChatList, setOverridenPropertiesToLocal } from "@/common"

export interface InitialState {
options: IOptions
Expand All @@ -13,6 +13,7 @@ export interface InitialState {
graphName: string,
graphs: string[],
extensions: Record<string, any>,
overridenProperties: Record<string, any>,
extensionMetadata: Record<string, any>
}

Expand All @@ -28,10 +29,21 @@ const getInitialState = (): InitialState => {
graphName: "camera.va.openai.azure",
graphs: [],
extensions: {},
overridenProperties: {},
extensionMetadata: {},
}
}

function deepMerge(target: Record<string, any>, source: Record<string, any>): Record<string, any> {
for (const key of Object.keys(source)) {
if (source[key] instanceof Object && key in target) {
Object.assign(source[key], deepMerge(target[key], source[key]));
}
}
// Merge source into target
return { ...target, ...source };
}

export const globalSlice = createSlice({
name: "global",
initialState: getInitialState(),
Expand Down Expand Up @@ -100,6 +112,15 @@ export const globalSlice = createSlice({
let { graphName, nodesMap } = action.payload
state.extensions[graphName] = nodesMap
},
setOverridenProperties: (state, action: PayloadAction<Record<string, any>>) => {
let { properties } = action.payload
state.overridenProperties = properties
},
setOverridenPropertiesByGraph: (state, action: PayloadAction<Record<string, any>>) => {
let { graphName, nodesMap } = action.payload
state.overridenProperties[graphName] = deepMerge(state.overridenProperties[graphName] || {}, nodesMap)
setOverridenPropertiesToLocal(state.overridenProperties)
},
setExtensionMetadata: (state, action: PayloadAction<Record<string, any>>) => {
state.extensionMetadata = action.payload
},
Expand All @@ -115,7 +136,7 @@ export const globalSlice = createSlice({

export const { reset, setOptions,
setRoomConnected, setAgentConnected, setVoiceType,
addChatItem, setThemeColor, setLanguage, setGraphName, setGraphs, setExtensions, setExtensionMetadata } =
addChatItem, setThemeColor, setLanguage, setGraphName, setGraphs, setExtensions, setExtensionMetadata, setOverridenProperties, setOverridenPropertiesByGraph } =
globalSlice.actions

export default globalSlice.reducer

0 comments on commit b85932e

Please sign in to comment.