@blocklet/pages-kit 0.2.413 → 0.2.414

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -35,7 +35,8 @@ export function useRuntimeState() {
35
35
  yield sessionState.getState().load();
36
36
  }), [authSession, sessionState]);
37
37
  const execute = useCallback((args) => __awaiter(this, void 0, void 0, function* () {
38
- if (!authSession.user) {
38
+ var _a;
39
+ if (!((_a = agent.access) === null || _a === void 0 ? void 0 : _a.noLoginRequired) && !authSession.user) {
39
40
  yield login();
40
41
  }
41
42
  return exec(Object.assign(Object.assign({}, args), { blockletDid, working }));
@@ -236,12 +236,10 @@ export const createSessionState = ({ aid }) => {
236
236
  }),
237
237
  execute: (_a) => __awaiter(void 0, void 0, void 0, function* () {
238
238
  var { blockletDid, aid, working, parameters, onResponseStart } = _a, args = __rest(_a, ["blockletDid", "aid", "working", "parameters", "onResponseStart"]);
239
- const sessionId = args.sessionId ||
240
- get().currentSessionId ||
241
- (yield get().createSession({
242
- name: parameters === null || parameters === void 0 ? void 0 : parameters.question,
243
- })).id;
244
239
  const identity = parseIdentity(aid, { rejectWhenError: true });
240
+ let responseStarted = false;
241
+ let mainTaskId;
242
+ let sessionId = args.sessionId || get().currentSessionId;
245
243
  let message;
246
244
  set((state) => {
247
245
  var _a;
@@ -260,8 +258,6 @@ export const createSessionState = ({ aid }) => {
260
258
  inputs: Object.assign(Object.assign({}, parameters), { $clientTime: new Date().toISOString() }),
261
259
  responseType: 'stream',
262
260
  });
263
- let responseStarted = false;
264
- let mainTaskId;
265
261
  const reader = res.getReader();
266
262
  for (;;) {
267
263
  const { value, done } = yield reader.read();
@@ -274,6 +270,37 @@ export const createSessionState = ({ aid }) => {
274
270
  if ((value === null || value === void 0 ? void 0 : value.type) === 'CHUNK') {
275
271
  if (!message) {
276
272
  mainTaskId = value.taskId;
273
+ sessionId = value.sessionId;
274
+ // set current session state for anonymous session
275
+ if (sessionId && sessionId !== args.sessionId) {
276
+ set((state) => {
277
+ var _a, _b;
278
+ state.sessions = [
279
+ ...((_a = state.sessions) !== null && _a !== void 0 ? _a : []),
280
+ {
281
+ id: sessionId,
282
+ projectId: identity.projectId,
283
+ agentId: identity.agentId,
284
+ createdAt: new Date().toISOString(),
285
+ updatedAt: new Date().toISOString(),
286
+ },
287
+ ];
288
+ state.currentSessionId = sessionId;
289
+ state.sessionMap = Object.fromEntries(state.sessions.map((i) => {
290
+ var _a;
291
+ return [
292
+ i.id,
293
+ Object.assign(Object.assign(Object.assign({}, (_a = state.sessionMap) === null || _a === void 0 ? void 0 : _a[i.id]), { session: i }), (i.id === sessionId ? { messages: [], loaded: true } : {})),
294
+ ];
295
+ }));
296
+ const s = (_b = state.sessionMap) === null || _b === void 0 ? void 0 : _b[sessionId];
297
+ if (!s)
298
+ return;
299
+ s.running = true;
300
+ s.error = undefined;
301
+ state.currentSessionId = sessionId;
302
+ });
303
+ }
277
304
  message = {
278
305
  id: value.messageId,
279
306
  agentId: identity.agentId,