feat: 集成离线数字货币图标系统
✨ 新功能: - 下载16个主流币种图标(BTC, ETH, USDT, BNB, SOL等) - 创建 CoinIcon 组件,支持离线图标和兜底显示 - 更新 CoinAvatar 组件,使用新的 CoinIcon - 更新 market_page.dart 中的 _CoinAvatar 组件 📦 资源: - 图标存放在 flutter_monisuo/assets/icons/crypto/ - 使用 Cryptocurrency Icons 开源图标库 - PNG 格式,128x128 像素 🎯 特性: - 支持自定义大小 - 支持圆形背景 - 未找到图标时显示币种代码(兜底方案) - 支持深色/浅色模式 📝 修改文件: - 新增:flutter_monisuo/lib/ui/components/coin_icon.dart - 新增:flutter_monisuo/assets/icons/crypto/*.png (16个) - 修改:flutter_monisuo/pubspec.yaml - 修改:flutter_monisuo/lib/ui/pages/trade/components/coin_avatar.dart - 修改:flutter_monisuo/lib/ui/pages/market/market_page.dart - ✅ 后端构建成功 (2.0s) - ✅ Flutter Web 构建成功 (24.1s) - ⚠️ Admin: TypeScript类型错误(已知问题)
This commit is contained in:
@@ -1,15 +1,15 @@
|
||||
((a,b)=>{a[b]=a[b]||{}})(self,"$__dart_deferred_initializers__")
|
||||
$__dart_deferred_initializers__.current=function(a,b,c,$){var B,A={
|
||||
b6t(d,e,f){var y,x,w=null,v=new B.a0(),u=new B.a0()
|
||||
u=new A.ZW(v,u)
|
||||
b6w(d,e,f){var y,x,w=null,v=new B.a0(),u=new B.a0()
|
||||
u=new A.ZY(v,u)
|
||||
u.bh(d,w,e,w)
|
||||
y=u.a
|
||||
x=v.r
|
||||
x.toString
|
||||
y.r=x
|
||||
v.r=A.bry(u)
|
||||
v.r=A.brB(u)
|
||||
return u},
|
||||
bqe(d,e){var y
|
||||
bqh(d,e){var y
|
||||
A:{if("timePicker.hours"===e){y="\u0427\u0430\u0441\u043e\u0432\u0435"
|
||||
break A}if("timePicker.minutes"===e){y="\u041c\u0438\u043d\u0443\u0442\u0438"
|
||||
break A}if("timePicker.seconds"===e){y="\u0421\u0435\u043a\u0443\u043d\u0434\u0438"
|
||||
@@ -23,38 +23,38 @@ break A}if("input.selectAll"===e){y="\u0418\u0437\u0431\u0435\u0440\u0438 \u0432
|
||||
break A}if("keyboardToolbar.done"===e){y="\u0413\u043e\u0442\u043e\u0432\u043e"
|
||||
break A}y=null
|
||||
break A}return y},
|
||||
bry(d){return new A.aWb(d)},
|
||||
ZW:function ZW(d,e){var _=this
|
||||
brB(d){return new A.aWd(d)},
|
||||
ZY:function ZY(d,e){var _=this
|
||||
_.r=d
|
||||
_.z=_.w=$
|
||||
_.a=e
|
||||
_.e=_.b=$},
|
||||
aQn:function aQn(){},
|
||||
aWb:function aWb(d){this.a=d},
|
||||
ab4:function ab4(){}}
|
||||
aQp:function aQp(){},
|
||||
aWd:function aWd(d){this.a=d},
|
||||
ab6:function ab6(){}}
|
||||
B=c[0]
|
||||
A=a.updateHolder(c[9],A)
|
||||
A.ZW.prototype={
|
||||
A.ZY.prototype={
|
||||
h(d,e){var y=this.r.a7(e)
|
||||
return y==null?this.a.a7(e):y},
|
||||
gb9(){var y=this,x=y.z
|
||||
if(x===$){if(y.w===$)y.w=y
|
||||
x=y.z=new A.aQn()}return x},
|
||||
x=y.z=new A.aQp()}return x},
|
||||
gbe(){return this.r}}
|
||||
A.aQn.prototype={
|
||||
A.aQp.prototype={
|
||||
gbj(){return"\u0418\u0437\u0440\u0435\u0436\u0438"},
|
||||
gbi(){return"\u041a\u043e\u043f\u0438\u0440\u0430\u0439"},
|
||||
gbk(){return"\u041f\u043e\u0441\u0442\u0430\u0432\u0438"},
|
||||
gbg(){return"\u0418\u0437\u0431\u0435\u0440\u0438 \u0432\u0441\u0438\u0447\u043a\u043e"}}
|
||||
A.ab4.prototype={}
|
||||
A.ab6.prototype={}
|
||||
var z=a.updateTypes([])
|
||||
A.aWb.prototype={
|
||||
$1(d){return A.bqe(this.a,d)},
|
||||
A.aWd.prototype={
|
||||
$1(d){return A.bqh(this.a,d)},
|
||||
$S:2};(function inheritance(){var y=a.mixin,x=a.inherit
|
||||
x(A.ab4,B.Z)
|
||||
x(A.ZW,A.ab4)
|
||||
x(A.aQn,B.b4)
|
||||
x(A.aWb,B.aW)
|
||||
y(A.ab4,B.b_)})()
|
||||
B.b9(b.typeUniverse,JSON.parse('{"ZW":{"Z":[]}}'))};
|
||||
(a=>{a["SHUI28wpXYaoLZM59fssbZQFw9U="]=a.current})($__dart_deferred_initializers__);
|
||||
x(A.ab6,B.Z)
|
||||
x(A.ZY,A.ab6)
|
||||
x(A.aQp,B.b4)
|
||||
x(A.aWd,B.aW)
|
||||
y(A.ab6,B.b_)})()
|
||||
B.b9(b.typeUniverse,JSON.parse('{"ZY":{"Z":[]}}'))};
|
||||
(a=>{a["83nQENMkyLCGxA/5/VCDavweUh0="]=a.current})($__dart_deferred_initializers__);
|
||||
Reference in New Issue
Block a user