* 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>
70 lines
2.4 KiB
Dart
70 lines
2.4 KiB
Dart
import 'package:fluffychat/pangea/events/models/content_feedback.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 TokenInfoFeedbackResponse implements JsonSerializable {
|
|
final String userFriendlyMessage;
|
|
final PangeaToken? updatedToken;
|
|
final LemmaInfoResponse? updatedLemmaInfo;
|
|
final PTResponse? updatedPhonetics;
|
|
final String? updatedLanguage;
|
|
|
|
TokenInfoFeedbackResponse({
|
|
required this.userFriendlyMessage,
|
|
this.updatedToken,
|
|
this.updatedLemmaInfo,
|
|
this.updatedPhonetics,
|
|
this.updatedLanguage,
|
|
});
|
|
|
|
factory TokenInfoFeedbackResponse.fromJson(Map<String, dynamic> json) {
|
|
return TokenInfoFeedbackResponse(
|
|
userFriendlyMessage: json['user_friendly_message'] as String,
|
|
updatedToken: json['updated_token'] != null
|
|
? PangeaToken.fromJson(json['updated_token'] as Map<String, dynamic>)
|
|
: null,
|
|
updatedLemmaInfo: json['updated_lemma_info'] != null
|
|
? LemmaInfoResponse.fromJson(
|
|
json['updated_lemma_info'] as Map<String, dynamic>,
|
|
)
|
|
: null,
|
|
updatedPhonetics: json['updated_phonetics'] != null
|
|
? PTResponse.fromJson(
|
|
json['updated_phonetics'] as Map<String, dynamic>,
|
|
)
|
|
: null,
|
|
updatedLanguage: json['updated_language'] as String?,
|
|
);
|
|
}
|
|
|
|
@override
|
|
Map<String, dynamic> toJson() {
|
|
return {
|
|
'user_friendly_message': userFriendlyMessage,
|
|
'updated_token': updatedToken?.toJson(),
|
|
'updated_lemma_info': updatedLemmaInfo?.toJson(),
|
|
'updated_phonetics': updatedPhonetics?.toJson(),
|
|
'updated_language': updatedLanguage,
|
|
};
|
|
}
|
|
|
|
@override
|
|
bool operator ==(Object other) =>
|
|
identical(this, other) ||
|
|
other is TokenInfoFeedbackResponse &&
|
|
runtimeType == other.runtimeType &&
|
|
userFriendlyMessage == other.userFriendlyMessage &&
|
|
updatedToken == other.updatedToken &&
|
|
updatedLemmaInfo == other.updatedLemmaInfo &&
|
|
updatedPhonetics == other.updatedPhonetics &&
|
|
updatedLanguage == other.updatedLanguage;
|
|
|
|
@override
|
|
int get hashCode =>
|
|
userFriendlyMessage.hashCode ^
|
|
updatedToken.hashCode ^
|
|
updatedLemmaInfo.hashCode ^
|
|
updatedPhonetics.hashCode ^
|
|
updatedLanguage.hashCode;
|
|
}
|