* docs: add PT v2 and token-info-feedback design docs - Add phonetic-transcription-v2-design.instructions.md (client PT v2 migration) - Add token-info-feedback-v2.instructions.md (client token feedback v2 migration) * fix: update applyTo path for token info feedback v2 migration * feat: Refactor phonetic transcription to v2 models and repository (in progress) * feat: PT v2 migration - tts_phoneme rename, v1 cleanup, disambiguation, TTS integration * feat: Update phonetic transcription v2 design document for endpoint changes and response structure * docs: fix stale _storageKeys claim in pt-v2 design doc * style: reformat PT v2 files with Dart 3.10 formatter (Flutter 3.38) * feat: add speakingRate to TTS request model (default 0.85) Passes speaking_rate to the choreo TTS endpoint. Default preserves current behavior; can be overridden for single-word playback later. * feat: use normal speed (1.0) for single-word TTS playback The 0.85x slowdown is helpful for full sentences but makes single words sound unnaturally slow. tts_controller._speakFromChoreo now sends speakingRate=1.0. Full-sentence TTS via pangea_message_event still defaults to 0.85. * style: clean up formatting and reduce line breaks in TtsController * fix: env goofiness * formatting, fix linter issues * don't return widgets from functions --------- Co-authored-by: ggurdin <ggurdin@gmail.com> Co-authored-by: ggurdin <46800240+ggurdin@users.noreply.github.com>
90 lines
2.7 KiB
Dart
90 lines
2.7 KiB
Dart
import 'package:fluffychat/pangea/events/models/pangea_token_model.dart';
|
|
import 'package:fluffychat/pangea/lemmas/lemma_info_response.dart';
|
|
import 'package:fluffychat/pangea/phonetic_transcription/pt_v2_models.dart';
|
|
|
|
class TokenInfoFeedbackRequestData {
|
|
final String userId;
|
|
final String? roomId;
|
|
final String? fullText;
|
|
final String detectedLanguage;
|
|
final List<PangeaToken> tokens;
|
|
final int selectedToken;
|
|
final LemmaInfoResponse lemmaInfo;
|
|
final PTRequest? ptRequest;
|
|
final PTResponse? ptResponse;
|
|
final String wordCardL1;
|
|
|
|
TokenInfoFeedbackRequestData({
|
|
required this.userId,
|
|
required this.detectedLanguage,
|
|
required this.tokens,
|
|
required this.selectedToken,
|
|
required this.lemmaInfo,
|
|
required this.wordCardL1,
|
|
this.ptRequest,
|
|
this.ptResponse,
|
|
this.roomId,
|
|
this.fullText,
|
|
});
|
|
|
|
@override
|
|
bool operator ==(Object other) =>
|
|
identical(this, other) ||
|
|
other is TokenInfoFeedbackRequestData &&
|
|
runtimeType == other.runtimeType &&
|
|
userId == other.userId &&
|
|
roomId == other.roomId &&
|
|
fullText == other.fullText &&
|
|
detectedLanguage == other.detectedLanguage &&
|
|
selectedToken == other.selectedToken &&
|
|
lemmaInfo == other.lemmaInfo &&
|
|
ptRequest == other.ptRequest &&
|
|
ptResponse == other.ptResponse &&
|
|
wordCardL1 == other.wordCardL1;
|
|
|
|
@override
|
|
int get hashCode =>
|
|
userId.hashCode ^
|
|
roomId.hashCode ^
|
|
fullText.hashCode ^
|
|
detectedLanguage.hashCode ^
|
|
selectedToken.hashCode ^
|
|
lemmaInfo.hashCode ^
|
|
ptRequest.hashCode ^
|
|
ptResponse.hashCode ^
|
|
wordCardL1.hashCode;
|
|
}
|
|
|
|
class TokenInfoFeedbackRequest {
|
|
final TokenInfoFeedbackRequestData data;
|
|
final String userFeedback;
|
|
|
|
TokenInfoFeedbackRequest({required this.data, required this.userFeedback});
|
|
|
|
Map<String, dynamic> toJson() {
|
|
return {
|
|
'user_id': data.userId,
|
|
'room_id': data.roomId,
|
|
'full_text': data.fullText,
|
|
'detected_language': data.detectedLanguage,
|
|
'tokens': data.tokens.map((token) => token.toJson()).toList(),
|
|
'selected_token': data.selectedToken,
|
|
'lemma_info': data.lemmaInfo.toJson(),
|
|
'pt_request': data.ptRequest?.toJson(),
|
|
'pt_response': data.ptResponse?.toJson(),
|
|
'user_feedback': userFeedback,
|
|
'word_card_l1': data.wordCardL1,
|
|
};
|
|
}
|
|
|
|
@override
|
|
bool operator ==(Object other) =>
|
|
identical(this, other) ||
|
|
other is TokenInfoFeedbackRequest &&
|
|
runtimeType == other.runtimeType &&
|
|
data == other.data &&
|
|
userFeedback == other.userFeedback;
|
|
|
|
@override
|
|
int get hashCode => data.hashCode ^ userFeedback.hashCode;
|
|
}
|