* opt: sized

* fix: self send

* feat: ctrl enter to send

* opt: checked

* opt: download notifier

* opt: Future.syncValue

* mod: account

* mod: loading state

* opt: DebounceStreamMixin

* opt: report

* opt: enum map

* opt: file handler

* opt: dyn color

* opt: Uint8List subview

* opt: FileExt

* opt: computeLuminance

* opt: isNullOrEmpty

* opt: Get context

* update [skip ci]

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>

* opt dynamicColor [skip ci]

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>

* fixes [skip ci]

* update

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>

* update

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>

---------

Signed-off-by: My-Responsitories <107370289+My-Responsitories@users.noreply.github.com>
Co-authored-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
My-Responsitories
2025-12-17 17:01:10 +08:00
committed by GitHub
parent 02e0d34127
commit ce5e85e64b
87 changed files with 707 additions and 646 deletions

View File

@@ -46,14 +46,15 @@ class AuthorPanel extends StatelessWidget {
});
Widget _buildAvatar(ModuleAuthorModel moduleAuthor) {
String? pendant = moduleAuthor.pendant?.image;
final pendant = moduleAuthor.pendant?.image;
final hasPendant = pendant != null && pendant.isNotEmpty;
Widget avatar = PendantAvatar(
avatar: moduleAuthor.face,
size: pendant.isNullOrEmpty ? 40 : 34,
size: hasPendant ? 34 : 40,
officialType: null, // 已被注释
garbPendantImage: pendant,
);
if (!pendant.isNullOrEmpty) {
if (hasPendant) {
avatar = Padding(padding: const EdgeInsets.all(3), child: avatar);
}
return avatar;
@@ -477,7 +478,7 @@ class AuthorPanel extends StatelessWidget {
);
}
return UserHttp.dynamicReport(
mid: moduleAuthor.mid,
mid: moduleAuthor.mid!,
dynId: item.idStr,
reasonType: reasonType,
reasonDesc: reasonType == 0 ? reasonDesc : null,