mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 08:50:15 +01:00
* feat(api): add googleapis package to package.json
feat(api): add reqDemo.js file to make a request to Google Cloud AI Platform API to get a response from a chatbot model.
* feat: add PaLM2 support
* feat(conversationPreset.js): add support for topP and topK for google endpoint
feat(askGoogle.js): add support for topP and topK for google endpoint
feat(ask/index.js): add google endpoint
feat(endpoints.js): add google endpoint
feat(MessageHeader.jsx): add support for modelLabel for google endpoint
feat(PresetItem.jsx): add support for modelLabel for google endpoint
feat(HoverButtons.jsx): add support for google endpoint
feat(createPayload.ts): add google endpoint
feat(types.ts): add google endpoint
feat(store/endpoints.js): add google endpoint
feat(cleanupPreset.js): add support for topP and topK for google endpoint
feat(getDefaultConversation.js): add support for topP and topK for google endpoint
feat(handleSubmit.js): add support for topP and topK for google endpoint
* fix: messages payload
* refactor(GoogleClient.js): set maxContextTokens based on isTextModel value
feat(GoogleClient.js): add delay option to TextStream constructor
feat(getIcon.jsx): add support for google endpoint and PaLM2 model label
* feat: palm frontend changes
* feat(askGoogle.js): set default example to empty input and output
feat(Examples.jsx): add ability to add and remove examples
refactor(Settings.jsx): remove examples from props and setOption function
style(GoogleOptions): remove unnecessary whitespace after Settings2 import
feat(GoogleOptions): add addExample and removeExample functions to manage examples
fix(cleanupPreset): set default example to [{ input: '', output: ''}]
fix(getDefaultConversation): set default example to [{ input: '', output: ''}]
fix(handleSubmit): set default example to [{ input: '', output: ''}]
* style(client): adjust height of settings and examples components to 350px
fix(client): fix path to palm.png image in getIcon.jsx file
* style(EndpointOptionsPopover.jsx, Examples.jsx, Settings.jsx): improve button styles and update input placeholders
* feat (palm): finalize examples on the frontend
* feat(GoogleClient.js): filter out empty examples in options
feat(GoogleClient.js): add support for promptPrefix in buildPayload method
feat(GoogleClient.js): add support for examples in buildPayload method
feat(conversationPreset.js): add maxOutputTokens field to conversation preset schema
feat(presetSchema.js): add examples field to preset schema
feat(askGoogle.js): add support for examples and promptPrefix in endpointOption
feat(EditPresetDialog.jsx): add Examples component for Google endpoint
feat(EditPresetDialog.jsx): add button to show/hide Examples component
feat(EditPresetDialog.jsx): add functionality to add, remove, and edit examples in Examples component
feat(EndpointOptionsDialog.jsx): change endpoint name to PaLM for Google endpoint
feat(Settings.jsx): add maxHeight prop to limit height of Settings component in EditPresetDialog and EndpointOptionsDialog
fix(Settings.jsx): add examples prop to ChatGPTBrowser component
fix(EndpointItem.jsx): add alternate name for google endpoint
fix(MessageHeader.jsx): change title for google endpoint to PaLM
feat(endpoints.js): add google endpoint to endpointsConfig
fix(cleanupPreset.js): add missing comma in examples array
* chore: change endpoint order
* feat(PaLM 2): complete for testing
* fix(PaLM): handle blocked messages
62 lines
1.5 KiB
JavaScript
62 lines
1.5 KiB
JavaScript
const { Readable } = require('stream');
|
|
|
|
class TextStream extends Readable {
|
|
constructor(text, options = {}) {
|
|
super(options);
|
|
this.text = text;
|
|
this.currentIndex = 0;
|
|
this.delay = options.delay || 20; // Time in milliseconds
|
|
}
|
|
|
|
_read() {
|
|
const minChunkSize = 2;
|
|
const maxChunkSize = 4;
|
|
const { delay } = this;
|
|
|
|
if (this.currentIndex < this.text.length) {
|
|
setTimeout(() => {
|
|
const remainingChars = this.text.length - this.currentIndex;
|
|
const chunkSize = Math.min(
|
|
this.randomInt(minChunkSize, maxChunkSize + 1),
|
|
remainingChars
|
|
);
|
|
|
|
const chunk = this.text.slice(this.currentIndex, this.currentIndex + chunkSize);
|
|
this.push(chunk);
|
|
this.currentIndex += chunkSize;
|
|
}, delay);
|
|
} else {
|
|
this.push(null); // signal end of data
|
|
}
|
|
}
|
|
|
|
randomInt(min, max) {
|
|
return Math.floor(Math.random() * (max - min)) + min;
|
|
}
|
|
|
|
async processTextStream(onProgressCallback) {
|
|
const streamPromise = new Promise((resolve, reject) => {
|
|
this.on('data', (chunk) => {
|
|
onProgressCallback(chunk.toString());
|
|
});
|
|
|
|
this.on('end', () => {
|
|
console.log('Stream ended');
|
|
resolve();
|
|
});
|
|
|
|
this.on('error', (err) => {
|
|
reject(err);
|
|
});
|
|
});
|
|
|
|
try {
|
|
await streamPromise;
|
|
} catch (err) {
|
|
console.error('Error processing text stream:', err);
|
|
// Handle the error appropriately, e.g., return an error message or throw an error
|
|
}
|
|
}
|
|
}
|
|
|
|
module.exports = TextStream;
|