mirror of
https://github.com/Monadical-SAS/reflector.git
synced 2025-12-20 20:29:06 +00:00
Update room config zulip streams
This commit is contained in:
@@ -30,18 +30,16 @@ import {
|
|||||||
IconButton,
|
IconButton,
|
||||||
Checkbox,
|
Checkbox,
|
||||||
} from "@chakra-ui/react";
|
} from "@chakra-ui/react";
|
||||||
import { useContext, useEffect, useState } from "react";
|
import { useEffect, useState } from "react";
|
||||||
import { Container } from "@chakra-ui/react";
|
import { Container } from "@chakra-ui/react";
|
||||||
import { FaEllipsisVertical, FaTrash, FaPencil, FaLink } from "react-icons/fa6";
|
import { FaEllipsisVertical, FaTrash, FaPencil, FaLink } from "react-icons/fa6";
|
||||||
import useApi from "../../lib/useApi";
|
import useApi from "../../lib/useApi";
|
||||||
import useRoomList from "./useRoomList";
|
import useRoomList from "./useRoomList";
|
||||||
import { DomainContext } from "../../domainContext";
|
|
||||||
import { Select, Options, OptionBase } from "chakra-react-select";
|
import { Select, Options, OptionBase } from "chakra-react-select";
|
||||||
|
|
||||||
interface Stream {
|
interface Stream {
|
||||||
id: number;
|
stream_id: number;
|
||||||
name: string;
|
name: string;
|
||||||
topics: string[];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
interface SelectOption extends OptionBase {
|
interface SelectOption extends OptionBase {
|
||||||
@@ -82,41 +80,63 @@ export default function RoomsList() {
|
|||||||
const [page, setPage] = useState<number>(1);
|
const [page, setPage] = useState<number>(1);
|
||||||
const { loading, response, refetch } = useRoomList(page);
|
const { loading, response, refetch } = useRoomList(page);
|
||||||
const [streams, setStreams] = useState<Stream[]>([]);
|
const [streams, setStreams] = useState<Stream[]>([]);
|
||||||
|
const [topics, setTopics] = useState<Topic[]>([]);
|
||||||
|
|
||||||
const [error, setError] = useState("");
|
const [error, setError] = useState("");
|
||||||
const [linkCopied, setLinkCopied] = useState("");
|
const [linkCopied, setLinkCopied] = useState("");
|
||||||
|
interface Stream {
|
||||||
|
stream_id: number;
|
||||||
|
name: string;
|
||||||
|
}
|
||||||
|
|
||||||
const { zulip_streams } = useContext(DomainContext);
|
interface Topic {
|
||||||
|
name: string;
|
||||||
|
}
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const fetchZulipStreams = async () => {
|
const fetchZulipStreams = async () => {
|
||||||
|
if (!api) return;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const response = await fetch(zulip_streams + "/streams.json");
|
const response = await api.v1ZulipGetStreams();
|
||||||
if (!response.ok) {
|
setStreams(response);
|
||||||
throw new Error("Network response was not ok");
|
} catch (error) {
|
||||||
}
|
console.error("Error fetching Zulip streams:", error);
|
||||||
let data = await response.json();
|
|
||||||
data = data.sort((a: Stream, b: Stream) =>
|
|
||||||
a.name.localeCompare(b.name),
|
|
||||||
);
|
|
||||||
setStreams(data);
|
|
||||||
} catch (err) {
|
|
||||||
console.error("Error fetching streams:", err);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
if (room.zulipAutoPost) {
|
if (room.zulipAutoPost) {
|
||||||
fetchZulipStreams();
|
fetchZulipStreams();
|
||||||
}
|
}
|
||||||
}, [room.zulipAutoPost]);
|
}, [room.zulipAutoPost, !api]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const fetchZulipTopics = async () => {
|
||||||
|
if (!api || !room.zulipStream) return;
|
||||||
|
try {
|
||||||
|
const selectedStream = streams.find((s) => s.name === room.zulipStream);
|
||||||
|
if (selectedStream) {
|
||||||
|
const response = await api.v1ZulipGetTopics({
|
||||||
|
streamId: selectedStream.stream_id,
|
||||||
|
});
|
||||||
|
setTopics(response);
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Error fetching Zulip topics:", error);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
fetchZulipTopics();
|
||||||
|
}, [room.zulipStream, streams, api]);
|
||||||
|
|
||||||
const streamOptions: Options<SelectOption> = streams.map((stream) => {
|
const streamOptions: Options<SelectOption> = streams.map((stream) => {
|
||||||
return { label: stream.name, value: stream.name };
|
return { label: stream.name, value: stream.name };
|
||||||
});
|
});
|
||||||
|
|
||||||
const topicOptions =
|
const topicOptions: Options<SelectOption> = topics.map((topic) => ({
|
||||||
streams
|
label: topic.name,
|
||||||
.find((stream) => stream.name === room.zulipStream)
|
value: topic.name,
|
||||||
?.topics.map((topic) => ({ label: topic, value: topic })) || [];
|
}));
|
||||||
|
|
||||||
const handleCopyUrl = (roomName: string) => {
|
const handleCopyUrl = (roomName: string) => {
|
||||||
const roomUrl = `${window.location.origin}/${roomName}`;
|
const roomUrl = `${window.location.origin}/${roomName}`;
|
||||||
|
|||||||
@@ -13,7 +13,6 @@ export const DomainContext = createContext<DomainContextType>({
|
|||||||
},
|
},
|
||||||
api_url: "",
|
api_url: "",
|
||||||
websocket_url: "",
|
websocket_url: "",
|
||||||
zulip_streams: "",
|
|
||||||
});
|
});
|
||||||
|
|
||||||
export const DomainContextProvider = ({
|
export const DomainContextProvider = ({
|
||||||
|
|||||||
@@ -13,7 +13,6 @@ type EdgeConfig = {
|
|||||||
auth_callback_url: string;
|
auth_callback_url: string;
|
||||||
websocket_url: string;
|
websocket_url: string;
|
||||||
api_url: string;
|
api_url: string;
|
||||||
zulip_streams: string;
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user