Compare commits

...

6 Commits

Author SHA1 Message Date
cc1fdebbd2 Merge branch 'paris_france_app' of http://1.95.131.171:3000/zzkj/smart_storage_app into paris_france_app
# Conflicts:
#	common/locales/homePage/ar.js
#	common/locales/homePage/de.js
#	common/locales/homePage/en.js
2026-03-26 21:00:53 +08:00
2dd2f255c0 更新语言包 2026-03-26 20:35:03 +08:00
a7c986fa3e feat: 远程配置 2026-03-24 08:49:46 +08:00
41b5d50cd4 feat:代码上传 2026-03-16 17:32:56 +08:00
ced281252b Merge branch 'paris_france_app' of http://1.95.131.171:3000/zzkj/smart_storage_app into paris_france_app 2026-03-13 17:33:15 +08:00
878101ceb3 feat: 上位机远程控制完成 2026-03-13 17:33:00 +08:00
20 changed files with 2653 additions and 2510 deletions

File diff suppressed because it is too large Load Diff

View File

@ -176,7 +176,9 @@ const install = (Vue, vm) => {
getStationListByStatus: (params = {}) =>
vm.$u.post(config.adminPath + "/business/station/findListByStationStatus ", params),
getStationPostionData: (params = {}) =>
vm.$u.post(config.adminPath + "/business/dynamicConfig/pointListData", params)
vm.$u.post(config.adminPath + "/business/dynamicConfig/pointListData", params),
getStationPostionSn: (params = {}) =>
vm.$u.post(config.adminPath + "/business/point/getSN", params)
},
//设备

View File

@ -39,21 +39,21 @@ export default {
}
],
useElecPrice: 'سعر الكهرباء',
workStatus: 'حالة التشغيل: ',
workStatus: 'الحالة:',
standing: 'خامل',
activePowerpcs: 'الطاقة النشطة: ',
operatingPower: 'طاقة التشغيل',
accumulatedElectricityConsumption: 'الاستهلاك التراكمي للكهرباء',
operatingPower: 'قوة',
accumulatedElectricityConsumption: 'الطاقة الإجمالية',
pvKpi: 'KPI للطاقة الكهروضوئية',
saveStandardCoal: 'توفير الفحم القياسي (طن)',
equivalentCo2Reduction: 'انبعاثات CO2 المخفضة (طن)',
equivalentTreePlantings: 'الأشجار المزروعة المكافئة (شجرة)',
dailyPowerGeneration: 'التوليد اليومي',
cumulativePowerGeneration: 'التوليد التراكمي',
cumulativePowerGeneration: 'إجمالي التوليد',
socialContribution: 'المساهمة الاجتماعية',
energyStorageRevenueReport: 'تقرير إيرادات تخزين الطاقة',
pvStorageRevenueReport: 'تقرير إيرادات الألواح الكهروضوئية',
projectMonthlyPower: 'حجم التوليد الشهري للمشروع',
projectMonthlyPower: 'التوليد الشهري',
powerGeneration: 'حجم التوليد',
mpptTopu: 'مخطط طوبولوجيا MPPT',
powerGenerationCapacity: 'طاقة التوليد',
@ -63,20 +63,20 @@ export default {
busCurrent: 'تيار BAT',
dc: 'تيار التيار المستمر',
dcVoltage: 'جهد التيار المستمر',
operatingPower: 'طاقة التشغيل',
operatingPower: 'قوة',
pvPower: 'الطاقة',
enmonthTotalChargePrice: 'إجمالي المبلغ الإجمالي لإجمالي حجم الشحن الشهري (يوان صيني)',
enmonthTotalDisChargePrice: جمالي المبلغ الإجمالي لحجم التفريغ الشهري (يوان صيني)',
enmonthTotalChargePrice: 'تكلفة الشحن الشهرية',
enmonthTotalDisChargePrice: يراد التفريغ الشهري',
enearnings: 'الإيرادات (يوان صيني)',
pvSwitch: 'مفتاح PV',
stationDatacom: 'بيانات محطة توليد الكهرباء',
sevenDaycom:'أسابيع',
todayEarning: 'مكاسب اليوم ( EGP )',
sevenDaycom:'أسبوع',
todayEarning: 'مكاسب اليوم (EGP)',
totalRevenue: 'الدخل التراكمي(EGP)',
ratedPower: 'تصنيف السلطة(kW)',
currentMonthlyPowerGeneration: 'توليد الطاقة في هذا الشهر',
currentMonthlyPowerGeneration: 'التوليد الشهري',
ratedPowernokw: 'تصنيف السلطة',
powerGenerationStatus: 'مشروع توليد الطاقة',
powerGenerationStatus: 'نظرة عامة على التوليد',
monthlyIncome: 'دخل الشهر(EGP)',
lowV:'الجهد المنخفض الجانب',
lowI:'الجانب المنخفض الحالي',
@ -130,7 +130,7 @@ export default {
standby: 'الاستعداد',
run: 'التشغيل',
allActivePower: 'إجمالي الطاقة النشطة (كيلوواط): ',
cabinet: 'خزانة تخزين الطاقة',
cabinet: 'خزانة',
gridMeter: 'عداد جانب الشبكة',
photovoltaic: 'الطاقة الكهروضوئية',
battery: 'البطارية',
@ -144,27 +144,27 @@ export default {
policy: 'استراتيجية',
stationTopo: 'توبولوجيا محطة الطاقة',
deviceMonitor: 'مراقبة المعدات',
runCurve: 'منحنيات التشغيل',
runCurve: 'منحنى التشغيل',
chargeDisData: 'بيانات الشحن والتفريغ',
stationData: 'بيانات محطة الطاقة',
environmentalData: 'بيانات التحكم البيئي',
sevenDay: 'آخر سبعة أيام',
monthDay: 'آخر شهر',
sevenDay: 'أسبوع',
monthDay: 'شهر',
monthThree: 'آخر ثلاثة أشهر',
yearDay: 'العام الماضي',
yearDay: 'سنة',
tip: 'تنبيه',
loading: 'تحميل الموارد...',
power: 'الطاقة (كيلوواط)',
photovoltaicCharge: 'الشحن الكهروضوئي',
chargingandDischarging: 'حجم الشحن والتفريغ',
safeDaysUnit: 'أيام التشغيل الآمن (أيام)',
totalCapacity: 'إجمالي السعة المركبة',
photovoltaicCharge: 'شحن شمسي',
chargingandDischarging: 'شحن وتفريغ',
safeDaysUnit: 'أيام التشغيل الآمن',
totalCapacity: 'السعة الإجمالية',
systemConversionEfficiency: 'كفاءة تحويل النظام',
currentPower: 'الطاقة الحالية',
totalCharge: 'إجمالي حجم الشحن',
totalDischarge: 'إجمالي حجم التفريغ',
dailyCharge: 'حجم الشحن اليومي',
dailyDischarge: 'حجم التفريغ اليومي',
totalCharge: 'إجمالي الشحن',
totalDischarge: 'إجمالي التفريغ',
dailyCharge: 'الشحن اليومي',
dailyDischarge: 'التفريغ اليومي',
dayPhotovoltaic: 'حجم التوليد الكهروضوئي',
noData: 'لا توجد بيانات متاحة',
station: 'محطة طاقة',
@ -271,6 +271,7 @@ export default {
cancel: 'الغاء',
messageDetail: 'تفاصيل الرسالة',
operateSuccess: 'نجح العملية',
operateFail: 'فشل العملية',
messageReaded: 'تمت قراءة هذه الرسالة، لا داعي لتكرار الإجراء'
},
device: {
@ -295,10 +296,10 @@ export default {
DCVol: 'جهد التيار المستمر',
DCCurrent: 'تيار التيار المستمر',
acbreaker: 'قطع زرارة التيار المتردد',
dcbreaker: 'قطع زرارة التيار المستمر',
dcbreakerCom: 'قطع زرارة التيار المستمر',
runState: 'حالة التشغيل',
rsState: 'حالة التوصيل عن بعد أو بالقرب من الشبكة',
gridMode: 'حالة التوصيل والانفصال عن الشبكة',
gridModeCom: 'حالة الشبكة',
deviceState: 'حالة الجهاز',
totalActivePower: 'إجمالي الطاقة النشطة',
totalReactivePower: 'إجمالي الطاقة التفاعلية',
@ -352,8 +353,8 @@ export default {
},
clusterTotalVol: 'مستوى الجهد الكلي للبطارية / SOC',
runData: 'بيانات التشغيل',
cumCharge: 'الشحن التراكمي',
cumDischarge: 'التفريغ التراكمي',
cumCharge: 'إجمالي الشحن',
cumDischarge: 'إجمالي التفريغ',
avgTem: 'متوسط درجة الحرارة',
avgVol: 'متوسط الجهد',
maxCellVol: 'الجهد الأقصى للخلية',
@ -372,10 +373,10 @@ export default {
bvol: 'جهد فاز B',
cvol: 'جهد فاز C',
zxygzdl: 'إجمالي الطاقة النشطة الأمامية',
dlj: 'الطاقة (ذروة)',
dlf: 'الطاقة (قمة)',
dlp: 'الطاقة (عادية)',
dlg: 'الطاقة (وادي)',
dlj: 'ذروة حرجة',
dlf: 'ذروة',
dlp: 'مستوى متوسط',
dlg: 'خارج الذروة',
fxygzdl: 'إجمالي الطاقة النشطة العكسية',
hxyggl: 'الطاقة النشطة للطور المركب',
hxwggl: 'الطاقة التفاعلية للطور المركب',
@ -428,7 +429,7 @@ export default {
stackTotalCurrent: 'تيار التجميع الكلي',
stackSoc: 'SOC للتجميع',
CumulativeCharge: 'الشحن التراكمي',
CumulativeDischarge: 'التفريغ التراكمي',
CumulativeDischarge: 'إجمالي التفريغ',
zdz: 'مقاومة العزل الموجبة',
fdz: 'مقاومة العزل السالبة',
rechargeCapacity: 'الطاقة الممكنة للشحن',
@ -442,17 +443,17 @@ export default {
historyData: 'البيانات التاريخية'
},
earning: {
changeDischargePro: 'نظرة عامة على شحن وتفريغ المشروع',
capacity: 'السعة المركبة',
monthTotalCharge: 'إجمالي طاقة الشحن لهذا الشهر',
monthTotalDischarge: 'إجمالي طاقة التفريغ لهذا الشهر',
monthEff: 'كفاءة تحويل النظام الشهرية',
chargeVol: 'الشحن التراكمي',
dischargeVol: 'التفريغ التراكمي',
totalEff: 'كفاءة تحويل النظام التراكمية',
changeDischargePro: 'نظرة عامة للشحن والتفريغ',
capacity: 'السعة',
monthTotalCharge: 'الشحن الشهري',
monthTotalDischarge: 'التفريغ الشهري',
monthEff: 'كفاءة النظام الشهرية',
chargeVol: 'إجمالي الشحن',
dischargeVol: 'إجمالي التفريغ',
totalEff: 'الكفاءة الإجمالية للنظام',
projectRevenue: 'حالة إيرادات المشروع',
monthTotalChargePrice: 'إجمالي المبلغ لإجمالي حجم الشحن الشهري (يوان صيني)',
monthTotalDisChargePrice: جمالي المبلغ لإجمالي حجم التفريغ الشهري (يوان صيني)',
monthTotalChargePrice: 'تكلفة الشحن الشهرية',
monthTotalDisChargePrice: يراد التفريغ الشهري',
earnings: 'الإيرادات (يوان صيني)',
earningsDetail: 'تفاصيل الإيرادات',
charge: 'الشحن',
@ -469,15 +470,15 @@ export default {
second: 'ثانية'
},
policy: {
planCurve: 'منحنى الجدول الزمني',
planCurveTem: 'قالب منحنى الجدول الزمني',
IssueDevice: 'جهاز إصدار الأوامر',
operateOrNot: 'سواء في التشغيل',
socUplimit: 'الحد الأعلى لـ SOC',
socDownlimit: 'الحد الأدنى لـ SOC',
effectiveTime: 'وقت السريان',
selectEffectiveTime: 'يرجى تحديد وقت السريان',
distributeResult: 'نتيجة الإصدار',
planCurve: 'منحنى الجدول الزمني',
planCurveTem: 'قالب الجدول',
IssueDevice: 'الجهاز المستهدف',
operateOrNot: 'قيد التشغيل',
socUplimit: 'الحد الأعلى SOC',
socDownlimit: 'الحد الأدنى SOC',
effectiveTime: 'وقت البدء',
selectEffectiveTime: 'اختر الوقت',
distributeResult: 'نتيجة الأمر',
notDelivered: 'لم يتم الإصدار',
commandDistribution: 'إصدار الأوامر',
controlDistribution: 'إصدار التحكم',
@ -496,15 +497,15 @@ export default {
],
radioList: [
{
name: 'تشغيل',
name: 'نعم',
disabled: false
},
{
name: 'عدم تشغيل',
name: ا',
disabled: false
}
],
selectIssueDevice: 'يرجى تحديد جهاز إصدار الأوامر',
selectIssueDevice: 'اختر الجهاز',
deliverErrorNewTip: 'خطأ في تكوين التعيين أو لم يتم التكوين، يرجى التحقق وإعادة المحاولة!',
passwordSuccess: 'كلمة المرور صحيحة',
passwordError: 'كلمة المرور غير صحيحة',
@ -516,9 +517,10 @@ export default {
saveSuccess: 'نجح الحفظ',
saveError: 'فشل الحفظ',
delivered: 'اكتمل الإصدار',
selectPlanCurveTem: 'يرجى تحديد قالب منحنى الجدول الزمني',
selectPlanCurveTem: 'اختر قالب الجدول',
deliverErrorTip: 'تجاوز طاقة الشحن والتفريغ الطاقة المقدرة، يرجى التحقق من إعدادات منحنى الجدول الزمني!',
deliverTip: 'سواء تأكيد إصدار الأمر?'
policyTitle: 'إصدار الاستراتيجية'
}
}

View File

@ -39,21 +39,21 @@ export default {
}
],
useElecPrice: 'Strompreis',
workStatus: 'Betriebsstatus: ',
workStatus: 'Status: ',
standing: 'Ruhezustand',
activePowerpcs: 'Wirkleistung: ',
operatingPower: 'Betriebsleistung',
accumulatedElectricityConsumption: 'Kumulierte Strommenge',
operatingPower: 'Leistung',
accumulatedElectricityConsumption: 'Gesamtenergie',
pvKpi: 'Photovoltaik-KPI',
saveStandardCoal: 'Eingesparte Standardkohle (Tonnen)',
equivalentCo2Reduction: 'CO₂-Reduktion (Tonnen)',
equivalentTreePlantings: 'Equivalent gepflanzt Bäume (Stück)',
dailyPowerGeneration: 'Täglicher Stromertrag',
cumulativePowerGeneration: 'Kumulierter Stromertrag',
cumulativePowerGeneration: 'Gesamterzeugung',
socialContribution: 'Gesellschaftlicher Beitrag',
energyStorageRevenueReport: 'Energiespeicher-Ertragsbericht',
pvStorageRevenueReport: 'Photovoltaik-Ertragsbericht',
projectMonthlyPower: 'Monatlicher Stromertrag des Projekts',
projectMonthlyPower: 'Monatserzeugung',
powerGeneration: 'Stromertrag',
mpptTopu: 'MPPT-Topologiediagramm',
powerGenerationCapacity: 'Erzeugungsleistung',
@ -63,10 +63,10 @@ export default {
busCurrent: 'BAT-Strom',
dc: 'Gleichstrom',
dcVoltage: 'Gleichspannung',
operatingPower: 'Betriebsleistung',
operatingPower: 'Leistung',
pvPower: 'Leistung',
enmonthTotalChargePrice: 'Gesamtwert der monatlichen Ladungsmenge (EUR)',
enmonthTotalDisChargePrice: 'Gesamtwert der monatlichen Entladungsmenge (EUR)',
enmonthTotalChargePrice: 'Monatliche Ladekosten(EUR)',
enmonthTotalDisChargePrice: 'Monatliche Entladeerlöse(EUR)',
enearnings: 'Ertrag (EUR)',
pvSwitch: 'PV-Schalter',
stationDatacom: 'Kraftwerksdaten',
@ -74,36 +74,36 @@ export default {
todayEarning: 'Heutiger Gewinn (EUR)',
totalRevenue: 'Gesamtgewinn (EUR)',
ratedPower: 'Nennleistung (kW)',
currentMonthlyPowerGeneration: 'Stromerzeugung in diesem Monat',
currentMonthlyPowerGeneration: 'Monatserzeugung',
ratedPowernokw: 'Nennleistung',
powerGenerationStatus: 'Projekterzeugung',
powerGenerationStatus: 'Erzeugungsübersicht',
monthlyIncome: 'Gewinn in diesem Monat (EUR)',
lowV: 'Niederspannung Seitenspannung',
lowI: 'Niederspannungs-Seitenstrom',
highV: 'Hochspannung Seitenspannung',
timesArr: [
{
text: '1 Minute',
text: '1 min',
value: 1
},
{
text: '5 Minuten',
text: '5 min',
value: 5
},
{
text: '10 Minuten',
text: '10 min',
value: 10
},
{
text: '15 Minuten',
text: '15 min',
value: 15
},
{
text: '20 Minuten',
text: '20 min',
value: 20
},
{
text: '30 Minuten',
text: '30 min',
value: 30
}
],
@ -131,7 +131,7 @@ export default {
standby: 'Standby',
run: 'Betrieb',
allActivePower: 'Gesamtwirkleistung (kW):',
cabinet: 'Energiespeicherschrank',
cabinet: 'Schrank',
gridMeter: 'Netzseitiger Zähler',
photovoltaic: 'Photovoltaik',
battery: 'Batterie',
@ -145,27 +145,27 @@ export default {
policy: 'Strategie',
stationTopo: 'Kraftwerkstopologie',
deviceMonitor: 'Geräteüberwachung',
runCurve: 'Betriebskurve',
runCurve: 'Laufkurve',
chargeDisData: 'Lade- und Entladedaten',
stationData: 'Kraftwerksdaten',
environmentalData: 'Umgebungskontrollsl Daten',
sevenDay: 'Letzte 7 Tage',
monthDay: 'Letzter Monat',
sevenDay: 'Woche',
monthDay: 'Monat',
monthThree: 'Letzte 3 Monate',
yearDay: 'Letztes Jahr',
yearDay: 'Jahr',
tip: 'Hinweis',
loading: 'Ressourcen werden geladen...',
power: 'Leistung (kW)',
photovoltaicCharge: 'Photovoltaik-Ladung',
chargingandDischarging: 'Lade- und Entlademenge',
safeDaysUnit: 'Tage des sicheren Betriebs (Tage)',
totalCapacity: 'Installierte Gesamtkapazität',
photovoltaicCharge: 'PV-Ladung',
chargingandDischarging: 'Laden/Entladen',
safeDaysUnit: 'Sichere Tage(Tage)',
totalCapacity: 'Gesamtkapazität',
systemConversionEfficiency: 'Systemumwandlungseffizienz',
currentPower: 'Aktuelle Leistung',
totalCharge: 'Gesamtladungsmenge',
totalDischarge: 'Gesamtentladungsmenge',
dailyCharge: 'Tägliche Ladungsmenge',
dailyDischarge: 'Tägliche Entladungsmenge',
totalCharge: 'Gesamtladung',
totalDischarge: 'Gesamtentladung',
dailyCharge: 'Tagesladung',
dailyDischarge: 'Tagesentladung',
dayPhotovoltaic: 'Photovoltaik-Stromerzeugung',
noData: 'Keine Daten verfügbar',
station: 'Kraftwerk',
@ -272,6 +272,7 @@ export default {
cancel: 'Abbrechen',
messageDetail: 'Nachrichtendetails',
operateSuccess: 'Aktion erfolgreich',
operateFail: 'Aktion fehlgeschlagen',
messageReaded: 'Diese Nachricht wurde bereits gelesen, keine Wiederholung der Aktion erforderlich'
},
device: {
@ -296,10 +297,10 @@ export default {
DCVol: 'Gleichspannung',
DCCurrent: 'Gleichstrom',
acbreaker: 'Wechselstromschalter',
dcbreaker: 'Gleichstromschalter',
dcbreakerCom: 'Gleichstromschalter',
runState: 'Betriebsstatus',
rsState: 'Fern-/Vor-Ort-Status',
gridMode: 'Netzparallel-/Inselbetriebsstatus',
gridModeCom: 'Netzstatus',
deviceState: 'Gerätestatus',
totalActivePower: 'Gesamtwirkleistung',
totalReactivePower: 'Gesamtblindleistung',
@ -318,27 +319,27 @@ export default {
localManual: 'Lokal manuell',
timesArr: [
{
label: '1 Minute',
label: '1 min',
value: 1
},
{
label: '5 Minuten',
label: '5 min',
value: 5
},
{
label: '10 Minuten',
label: '10 min',
value: 10
},
{
label: '15 Minuten',
label: '15 min',
value: 15
},
{
label: '20 Minuten',
label: '20 min',
value: 20
},
{
label: '30 Minuten',
label: '30 min',
value: 30
}
],
@ -353,8 +354,8 @@ export default {
},
clusterTotalVol: 'Bundesamtsspannung/SOC',
runData: 'Betriebsdaten',
cumCharge: 'Kumulierte Ladungsmenge',
cumDischarge: 'Kumulierte Entladungsmenge',
cumCharge: 'Gesamtladung',
cumDischarge: 'Gesamtentladung',
avgTem: 'Durchschnittstemperatur',
avgVol: 'Durchschnittsspannung',
maxCellVol: 'Maximale Einzelzellenspannung',
@ -373,10 +374,10 @@ export default {
bvol: 'B-Phasenspannung',
cvol: 'C-Phasenspannung',
zxygzdl: 'Vorwärts-Wirkgesamtenergie',
dlj: 'Energie (Spitzenspitze)',
dlf: 'Energie (Spitze)',
dlp: 'Energie (Normal)',
dlg: 'Energie (Talast)',
dlj: 'Spitzenlast',
dlf: 'Spitze',
dlp: 'Mittel',
dlg: 'Niedrig',
fxygzdl: 'Rückwärts-Wirkgesamtenergie',
hxyggl: 'Gesamtwirkleistung',
hxwggl: 'Gesamtblindleistung',
@ -429,7 +430,7 @@ export default {
stackTotalCurrent: 'Stapelgesamtstrom',
stackSoc: 'Stapel-SOC',
CumulativeCharge: 'Kumulierte Ladungsmenge',
CumulativeDischarge: 'Kumulierte Entladungsmenge',
CumulativeDischarge: 'Gesamtentladung',
zdz: 'Isolationspositivwiderstand',
fdz: 'Isolationsnegativwiderstand',
rechargeCapacity: 'Ladelfähige Menge',
@ -443,17 +444,17 @@ export default {
historyData: 'Verlaufsdaten'
},
earning: {
changeDischargePro: 'Projekt-Lade- und Entladeübersicht',
capacity: 'Installierte Kapazität',
monthTotalCharge: 'Monatliche Gesamtladungsmenge',
monthTotalDischarge: 'Monatliche Gesamtentladungsmenge',
monthEff: 'Monatliche Systemumwandlungseffizienz',
chargeVol: 'Kumulierte Ladungsmenge',
dischargeVol: 'Kumulierte Entladungsmenge',
totalEff: 'Kumulierte Systemumwandlungseffizienz',
changeDischargePro: 'Lade/Entlade Übersicht',
capacity: 'Kapazität',
monthTotalCharge: 'Monatsladung',
monthTotalDischarge: 'Monatsentladung',
monthEff: 'Monatseffizienz',
chargeVol: 'Gesamtladung',
dischargeVol: 'Gesamtentladung',
totalEff: 'Gesamteffizienz',
projectRevenue: 'Projektertragssituation',
monthTotalChargePrice: 'Gesamtwert der monatlichen Ladungsmenge (EUR)',
monthTotalDisChargePrice: 'Gesamtwert der monatlichen Entladungsmenge (EUR)',
monthTotalChargePrice: 'Monatliche Ladekosten(EUR)',
monthTotalDisChargePrice: 'Monatliche Entladeerlöse(EUR)',
earnings: 'Ertrag (EUR)',
earningsDetail: 'Ertragsdetails',
charge: 'Laden',
@ -507,14 +508,14 @@ export default {
},
policy: {
planCurve: 'Plan-Kurve',
planCurveTem: 'Plan-Kurvenvorlage',
IssueDevice: 'Befehlszielgerät',
planCurveTem: 'Planvorlage',
IssueDevice: 'Zielgerät',
operateOrNot: 'In Betrieb',
socUplimit: 'SOC-Obergrenze',
socDownlimit: 'SOC-Untergrenze',
effectiveTime: 'Gültigkeitszeit',
selectEffectiveTime: 'Bitte wählen Sie die Gültigkeitszeit',
distributeResult: 'Übertragungsergebnis',
socUplimit: 'SOC Obergrenze',
socDownlimit: 'SOC Untergrenze',
effectiveTime: 'Startzeit',
selectEffectiveTime: 'Zeit wählen',
distributeResult: 'Befehlsergebnis',
notDelivered: 'Nicht übertragen',
commandDistribution: 'Befehlssendung',
controlDistribution: 'Steuerungssendung',
@ -533,15 +534,15 @@ export default {
],
radioList: [
{
name: 'In Betrieb',
name: 'Ja',
disabled: false
},
{
name: 'Außer Betrieb',
name: 'Nein',
disabled: false
}
],
selectIssueDevice: 'Bitte wählen Sie das Befehlssendegerät',
selectIssueDevice: 'Gerät wählen',
deliverErrorNewTip: 'Zuordnungskonfiguration fehlerhaft oder nicht konfiguriert, bitte überprüfen und erneut versuchen!',
passwordSuccess: 'Passwort korrekt',
passwordError: 'Passwort falsch',
@ -553,8 +554,9 @@ export default {
saveSuccess: 'Speichern erfolgreich',
saveError: 'Speichern fehlgeschlagen',
delivered: 'Bereits gesendet',
selectPlanCurveTem: 'Bitte wählen Sie eine Plan-Kurvenvorlage',
selectPlanCurveTem: 'Planvorlage wählen',
deliverErrorTip: 'Lade-/Entladeleistung größer als Nennleistung, bitte überprüfen Sie die Plan-Kurven-Einstellungen!',
deliverTip: 'Befehlssendung wirklich bestätigen?'
policyTitle: 'Strategieübertragung'
}
};

View File

@ -33,21 +33,21 @@ export default {
name: 'Overseas site'
}],
useElecPrice: 'Electricity price',
workStatus: 'Operating status:',
workStatus: 'Status:',
standing: 'Standby',
activePowerpcs: 'Active power:',
operatingPower: 'Operating power',
accumulatedElectricityConsumption: 'Cumulative electricity',
operatingPower: 'Power',
accumulatedElectricityConsumption: 'Total Energy',
pvKpi: 'PV KPI',
saveStandardCoal: 'Standard coal saved (ton)',
equivalentCo2Reduction: 'CO2 emission reduction (ton)',
equivalentTreePlantings: 'Equivalent trees planted (tree)',
dailyPowerGeneration: 'Daily power generation',
cumulativePowerGeneration: 'Cumulative power generation',
cumulativePowerGeneration: 'Total Generation',
socialContribution: 'Social contribution',
energyStorageRevenueReport: 'Energy storage revenue report',
pvStorageRevenueReport: 'PV revenue report',
projectMonthlyPower: 'Monthly project power generation',
projectMonthlyPower: 'Monthly Generation',
powerGeneration: 'Power generation',
mpptTopu: 'MPPT Topology Diagram',
powerGenerationCapacity: 'Generation power',
@ -58,8 +58,8 @@ export default {
dc: 'DC current',
dcVoltage: 'DC voltage',
pvPower: 'Power',
enmonthTotalChargePrice: 'Total charging capacity & price this month (EUR)',
enmonthTotalDisChargePrice: 'Total discharging capacity & price this month',
enmonthTotalChargePrice: 'Monthly Charge Cost(EUR)',
enmonthTotalDisChargePrice: 'Monthly Discharge Revenue(EUR)',
enearnings: 'Revenue (EUR)',
pvSwitch: 'PV switch',
stationDatacom: 'Station Data',
@ -67,30 +67,30 @@ export default {
todayEarning: 'Today Earning(EUR)',
totalRevenue: 'Cumulative Earnings(EUR)',
ratedPower: 'Rated Power(kW)',
currentMonthlyPowerGeneration: 'Current monthly power generation',
currentMonthlyPowerGeneration: 'Monthly Generation',
ratedPowernokw: 'Rated Power',
powerGenerationStatus: 'power Generation Status',
powerGenerationStatus: 'Generation Overview',
monthlyIncome: 'Monthly income(EUR)',
lowV: 'low-side voltage',
lowI: 'low-side current',
highV: 'high-side voltage',
timesArr: [{
text: '1 minute',
text: '1 min',
value: 1
}, {
text: '5 minutes',
text: '5 min',
value: 5
}, {
text: '10 minutes',
text: '10 min',
value: 10
}, {
text: '15 minutes',
text: '15 min',
value: 15
}, {
text: '20 minutes',
text: '20 min',
value: 20
}, {
text: '30 minutes',
text: '30 min',
value: 30
}],
esiCab: 'Integrated energy storage cabinet',
@ -117,7 +117,7 @@ export default {
standby: 'Standby',
run: 'Running',
allActivePower: 'Total active power (kW):',
cabinet: 'Energy storage cabinet',
cabinet: 'Canibet',
gridMeter: 'Grid-side electric meter',
photovoltaic: 'Photovoltaic (PV)',
battery: 'Battery',
@ -131,27 +131,27 @@ export default {
policy: 'Strategy',
stationTopo: 'Power station topology',
deviceMonitor: 'Equipment monitoring',
runCurve: 'Operation curve',
runCurve: 'Run Time Curve',
chargeDisData: 'Charging/Discharging data',
stationData: 'Power station data',
environmentalData: 'Environmental control data',
sevenDay: 'Last 7 days',
monthDay: 'Last month',
sevenDay: 'Week',
monthDay: 'Month',
monthThree: 'Last 3 months',
yearDay: 'Last year',
yearDay: 'Year',
tip: 'Prompt',
loading: 'Resource loading...',
power: 'Power (kW)',
photovoltaicCharge: 'PV charging',
chargingandDischarging: 'Charging/Discharging capacity',
safeDaysUnit: 'Safe operation days',
totalCapacity: 'Total installed capacity',
chargingandDischarging: 'Charge/Discharge Energy',
safeDaysUnit: 'Safe Days',
totalCapacity: 'Total capacity',
systemConversionEfficiency: 'System conversion efficiency',
currentPower: 'Current power',
totalCharge: 'Total charging capacity',
totalDischarge: 'Total discharging capacity',
dailyCharge: 'Daily charging capacity',
dailyDischarge: 'Daily discharging capacity',
totalCharge: 'Total Charge',
totalDischarge: 'Total Discharge',
dailyCharge: 'Daily Charge',
dailyDischarge: 'Daily Discharge',
dayPhotovoltaic: 'PV power generation',
noData: 'No data available',
station: 'Power station',
@ -183,7 +183,7 @@ export default {
eleLevel: 'Electricity price level',
fsdd: 'Time-of-use electricity price',
useElecPrice: 'Electricity price',
dietailUnit: '(RMB/kWh)',
dietailUnit: '(EUR/kWh)',
eleprice: 'Electricity energy price',
nonTime: 'Non-time-of-use electricity price',
proxyPrice: 'Agent purchasing electricity price',
@ -257,6 +257,7 @@ export default {
sureRead: 'Confirm as read',
cancel: 'Cancel',
operateSuccess: 'Operation successful',
operateFail: 'Operation failed',
messageReaded: 'This message has been read. No need to repeat the'
},
device: {
@ -281,10 +282,10 @@ export default {
DCVol: 'DC voltage',
DCCurrent: 'DC current',
acbreaker: 'AC circuit breaker',
dcbreaker: 'DC circuit breaker',
dcbreakerCom: 'DC circuit breaker',
runState: 'Operating status',
rsState: 'Remote/Local status',
gridMode: 'Grid-connected/Off-grid status',
gridModeCom: 'Grid Status',
deviceState: 'Equipment status',
totalActivePower: 'Total active power',
totalReactivePower: 'Total reactive power',
@ -302,22 +303,22 @@ export default {
localAutomatic: 'Local auto',
localManual: 'Local manual',
timesArr: [{
label: '1 Minute',
label: '1 Min',
value: 1
}, {
label: '5 Minutes',
label: '5 Min',
value: 5
}, {
label: '10 Minutes',
label: '10 Min',
value: 10
}, {
label: '15 Minutes',
label: '15 Min',
value: 15
}, {
label: '20 Minutes',
label: '20 Min',
value: 20
}, {
label: '30 Minutes',
label: '30 Min',
value: 30
}],
yx: 'Telesignaling',
@ -331,8 +332,8 @@ export default {
},
clusterTotalVol: 'Total cluster voltage/SOC',
runData: 'Operation data',
cumCharge: 'Cumulative charging capacity',
cumDischarge: 'Cumulative discharging capacity',
cumCharge: 'Total Charge',
cumDischarge: 'Total Discharge',
avgTem: 'Average temperature',
avgVol: 'Average voltage',
maxCellVol: 'Max. cell voltage',
@ -351,10 +352,10 @@ export default {
bvol: 'Phase B voltage',
cvol: 'Phase C voltage',
zxygzdl: 'Total forward active electricity',
dlj: 'Electricity (sharp)',
dlf: 'Electricity (peak)',
dlp: 'Electricity (shoulder)',
dlg: 'Electricity (valley)',
dlj: 'Critical Peak',
dlf: 'Peak',
dlp: 'Shoulder',
dlg: 'Off-peak',
fxygzdl: 'Total reverse active electricity',
hxyggl: 'Combined phase active power',
hxwggl: 'Combined phase reactive power',
@ -405,7 +406,7 @@ export default {
stackTotalCurrent: 'Total stack current',
stackSoc: 'Stack SOC',
CumulativeCharge: 'Cumulative charging capacity',
CumulativeDischarge: 'Cumulative discharging capacity',
CumulativeDischarge: 'Total Discharge',
zdz: 'Positive insulation resistance',
fdz: 'Negative insulation resistance',
rechargeCapacity: 'Chargeable capacity',
@ -419,22 +420,22 @@ export default {
historyData: 'Historical data'
},
earning: {
changeDischargePro: 'Project charging/discharging overview',
capacity: 'Installed capacity',
monthTotalCharge: 'Total charging capacity this month',
monthTotalDischarge: 'Total discharging capacity this month',
monthEff: 'Monthly system conversion efficiency',
chargeVol: 'Cumulative charging capacity',
dischargeVol: 'Cumulative discharging capacity',
totalEff: 'Cumulative system conversion efficiency',
changeDischargePro: 'Charge/Discharge Overview',
capacity: 'Capacity',
monthTotalCharge: 'Monthly Charge',
monthTotalDischarge: 'Monthly Discharge',
monthEff: 'Monthly Efficiency',
chargeVol: 'Total Charge',
dischargeVol: 'Total Discharge',
totalEff: 'Total System Efficiency',
projectRevenue: 'Project revenue status',
monthTotalChargePrice: 'Total charging capacity & price this month (RMB)',
monthTotalDisChargePrice: 'Total discharging capacity & price this month',
earnings: 'Revenue (RMB)',
monthTotalChargePrice: 'Monthly Charge Cost(EUR)',
monthTotalDisChargePrice: 'Monthly Discharge Revenue(EUR)',
earnings: 'Revenue (EUR)',
earningsDetail: 'Revenue details',
charge: 'Charging',
ele: 'Electricity (kWh)',
expend: 'Expense (RMB)',
expend: 'Expense (EUR)',
noChargeData: 'No charging data available',
disCharge: 'Discharging',
noDisChargeData: 'No discharging data available',
@ -480,14 +481,14 @@ export default {
},
policy: {
planCurve: 'Planned curve',
planCurveTem: 'Planned curve template',
IssueDevice: 'Command issuance equipment',
operateOrNot: 'Commission or not',
planCurveTem: 'Schedule Template',
IssueDevice: 'Target Device',
operateOrNot: 'In Operation',
socUplimit: 'SOC upper limit',
socDownlimit: 'SOC lower limit',
effectiveTime: 'Effective time',
selectEffectiveTime: 'Please select effective time',
distributeResult: 'Issuance result',
effectiveTime: 'Effective Time',
selectEffectiveTime: 'Select time',
distributeResult: 'Command Result',
notDelivered: 'Not issued',
commandDistribution: 'Command issuance',
controlDistribution: 'Control issuance',
@ -502,13 +503,13 @@ export default {
name: 'General Settings'
}],
radioList: [{
name: "In Operation",
name: "Yes",
disabled: false
}, {
name: "Not In Operation",
name: "No",
disabled: false
}],
selectIssueDevice: 'Please select command issuance equipment',
selectIssueDevice: 'Select device',
deliverErrorNewTip: 'Mapping configuration error or not configured. Please confirm and try again!',
passwordSuccess: 'Password correct',
passwordError: 'Password incorrect',
@ -520,8 +521,9 @@ export default {
saveSuccess: 'Save successful',
saveError: 'Save failed',
delivered: 'Issued',
selectPlanCurveTem: 'Please select planned curve template',
selectPlanCurveTem: 'Select schedule template',
deliverErrorTip: 'Charging/discharging power exceeds rated power. Please confirm the planned curve.',
deliverTip: 'Confirm command issuance?'
policyTitle: 'Strategy Issuance'
}
}

View File

@ -33,21 +33,21 @@ export default {
name: 'Sitio internacional'
}],
useElecPrice: 'Tarifa de energía',
workStatus: 'Estado de funcionamiento:',
workStatus: 'Estado:',
standing: 'En reposo',
activePowerpcs: 'Potencia activa:',
operatingPower: 'Potencia operativa',
accumulatedElectricityConsumption: 'Energía acumulada',
operatingPower: 'Potencia',
accumulatedElectricityConsumption: 'Energía total',
pvKpi: 'KPI fotovoltaico',
saveStandardCoal: 'Carbón estándar ahorrado (t)',
equivalentCo2Reduction: 'Reducción de CO₂ (t)',
equivalentTreePlantings: 'Árboles equivalentes plantados',
dailyPowerGeneration: 'Generación diaria',
cumulativePowerGeneration: 'Generación acumulada',
cumulativePowerGeneration: 'Generación total',
socialContribution: 'Contribución social',
energyStorageRevenueReport: 'Informe de ingresos del almacenamiento de energía',
pvStorageRevenueReport: 'Informe de ingresos fotovoltaicos',
projectMonthlyPower: 'Generación mensual del proyecto',
projectMonthlyPower: 'Generación mensual',
powerGeneration: 'Generación de energía',
mpptTopu: 'Diagrama de topología MPPT',
powerGenerationCapacity: 'Potencia de generación',
@ -58,8 +58,8 @@ export default {
dc: 'Corriente de DC',
dcVoltage: 'Tensión de DC',
pvPower: 'Potencia',
enmonthTotalChargePrice: 'Precio total de la carga del mes (EUR)',
enmonthTotalDisChargePrice: 'Precio total de la descarga del mes (EUR)',
enmonthTotalChargePrice: 'Costo carga mensual(EUR)',
enmonthTotalDisChargePrice: 'Ingreso descarga mensual(EUR)',
enearnings: 'Ingresos (EUR)',
pvSwitch: 'Interruptor PV',
stationDatacom: 'datos de la central eléctrica',
@ -67,30 +67,30 @@ export default {
todayEarning: 'Ingresos de hoy (EUR)',
totalRevenue: 'Beneficio acumulado (EUR)',
ratedPower: 'Potencia nominal (kW)',
currentMonthlyPowerGeneration: 'Producción de electricidad de este mes',
currentMonthlyPowerGeneration: 'Generación mensual',
ratedPowernokw: 'potencia nominal',
powerGenerationStatus: 'Situación de generación de energía del proyecto',
powerGenerationStatus: 'Resumen generación',
monthlyIncome: 'Ingresos del mes (EUR)',
lowV: 'tensión del lado de baja tensión',
lowI: 'corriente del lado de baja tensión',
highV: 'tensión del lado de alta tensión',
timesArr: [{
text: '1 minuto',
text: '1 min',
value: 1
}, {
text: '5 minutos',
text: '5 min',
value: 5
}, {
text: '10 minutos',
text: '10 min',
value: 10
}, {
text: '15 minutos',
text: '15 min',
value: 15
}, {
text: '20 minutos',
text: '20 min',
value: 20
}, {
text: '30 minutos',
text: '30 min',
value: 30
}],
esiCab: 'Gabinete integrado de almacenamiento de energía',
@ -117,7 +117,7 @@ export default {
standby: 'En espera',
run: 'En funcionamiento',
allActivePower: 'Potencia activa total (kW):',
cabinet: 'Gabinete de almacenamiento de energía',
cabinet: 'Gabinete',
gridMeter: 'Medidor del lado de la red',
photovoltaic: 'Fotovoltaico',
battery: 'Batería',
@ -135,22 +135,22 @@ export default {
chargeDisData: 'Datos de carga y descarga',
stationData: 'Datos de la planta',
environmentalData: 'Datos de control ambiental',
sevenDay: 'Últimos 7 días',
monthDay: 'Último mes',
sevenDay: 'Semana',
monthDay: 'Mes',
monthThree: 'Últimos 3 meses',
yearDay: 'Último año',
yearDay: 'Año',
tip: 'Aviso',
loading: 'Cargando recursos...',
power: 'Potencia (kW)',
photovoltaicCharge: 'Carga fotovoltaica',
chargingandDischarging: 'Energía de carga y descarga',
safeDaysUnit: 'Días de operación segura (días)',
totalCapacity: 'Capacidad total instalada',
photovoltaicCharge: 'Carga PV',
chargingandDischarging: 'Carga/Descarga',
safeDaysUnit: 'Días seguros(días)',
totalCapacity: 'Capacidad total',
systemConversionEfficiency: 'Eficiencia de conversión del sistema',
currentPower: 'Potencia actual',
totalCharge: 'Energía de carga total',
totalCharge: 'Carga total',
totalDischarge: 'Descarga total',
dailyCharge: 'Energía de carga diaria',
dailyCharge: 'Carga diaria',
dailyDischarge: 'Descarga diaria',
dayPhotovoltaic: 'Generación fotovoltaica',
noData: 'Sin datos',
@ -183,7 +183,7 @@ export default {
eleLevel: 'Nivel de tarifa eléctrica',
fsdd: 'Tarifa de energía por franjas horarias',
useElecPrice: 'Tarifa de energía',
dietailUnit: '(yuanes/kWh)',
dietailUnit: '(EUR/kWh)',
eleprice: 'Tarifa de energía eléctrica',
nonTime: 'Tarifa sin discriminación horaria',
proxyPrice: 'Precio de compra de electricidad por intermediario',
@ -257,6 +257,7 @@ export default {
sureRead: 'Confirmar como leído',
cancel: 'Cancelar',
operateSuccess: 'Operación realizada con éxito',
operateFail: 'Operación fallida',
messageReaded: 'Este mensaje ya fue leído; no es necesario repetir la operación'
},
device: {
@ -281,10 +282,10 @@ export default {
DCVol: 'Tensión de DC',
DCCurrent: 'Corriente de DC',
acbreaker: 'Interruptor de AC',
dcbreaker: 'Interruptor de DC',
dcbreakerCom: 'Interruptor de DC',
runState: 'Estado de operación',
rsState: 'Estado remoto/local',
gridMode: 'Estado de conexión/desconexión de la red',
gridModeCom: 'Estado red',
deviceState: 'Estado del equipo',
totalActivePower: 'Potencia activa total',
totalReactivePower: 'Potencia reactiva total',
@ -302,22 +303,22 @@ export default {
localAutomatic: 'Automático local',
localManual: 'Manual local',
timesArr: [{
label: '1 minuto',
label: '1 min',
value: 1
}, {
label: '5 minutos',
label: '5 min',
value: 5
}, {
label: '10 minutos',
label: '10 min',
value: 10
}, {
label: '15 minutos',
label: '15 min',
value: 15
}, {
label: '20 minutos',
label: '20 min',
value: 20
}, {
label: '30 minutos',
label: '30 min',
value: 30
}],
yx: 'Teleindicación',
@ -331,8 +332,8 @@ export default {
},
clusterTotalVol: 'Tensión total del clúster / SOC',
runData: 'Datos de operación',
cumCharge: 'Energía de carga acumulada',
cumDischarge: 'Energía de descarga acumulada',
cumCharge: 'Carga total',
cumDischarge: 'Descarga total',
avgTem: 'Temperatura promedio',
avgVol: 'Tensión promedia',
maxCellVol: 'Tensión máxima de celda',
@ -351,10 +352,10 @@ export default {
bvol: 'Tensión de fase B',
cvol: 'Tensión de fase C',
zxygzdl: 'Energía activa total en sentido directo',
dlj: 'Energía (punta)',
dlf: 'Energía (pico)',
dlp: 'Energía (llano)',
dlg: 'Energía (valle)',
dlj: 'Pico crítico',
dlf: 'Pico',
dlp: 'Medio',
dlg: 'Valle',
fxygzdl: 'Energía activa total en sentido inverso',
hxyggl: 'Potencia activa de fase combinada',
hxwggl: 'Potencia reactiva de fase combinada',
@ -405,7 +406,7 @@ export default {
stackTotalCurrent: 'Corriente total de la pila',
stackSoc: 'SOC de la pila',
CumulativeCharge: 'Energía de carga acumulada',
CumulativeDischarge: 'Energía de descarga acumulada',
CumulativeDischarge: 'Descarga total',
zdz: 'Resistencia de aislamiento positiva',
fdz: 'Resistencia de aislamiento negativa',
rechargeCapacity: 'Energía disponible para carga',
@ -419,22 +420,22 @@ export default {
historyData: 'Datos históricos'
},
earning: {
changeDischargePro: 'Resumen de carga y descarga del proyecto',
capacity: 'Capacidad instalada',
monthTotalCharge: 'Energía total de carga del mes',
monthTotalDischarge: 'Descarga total del mes',
monthEff: 'Eficiencia mensual de conversión del sistema',
chargeVol: 'Energía de carga acumulada',
dischargeVol: 'Energía de descarga acumulada',
totalEff: 'Eficiencia acumulada de conversión del sistema',
changeDischargePro: 'Resumen carga/descarga',
capacity: 'Capacidad',
monthTotalCharge: 'Carga mensual',
monthTotalDischarge: 'Descarga mensual',
monthEff: 'Eficiencia mensual',
chargeVol: 'Carga total',
dischargeVol: 'Descarga total',
totalEff: 'Eficiencia total',
projectRevenue: 'Ingresos del proyecto',
monthTotalChargePrice: 'Precio total de la carga del mes (yuanes)',
monthTotalDisChargePrice: 'Precio total de la descarga del mes (yuanes)',
earnings: 'Ingresos (yuanes)',
monthTotalChargePrice: 'Costo carga mensual(EUR)',
monthTotalDisChargePrice: 'Ingreso descarga mensual(EUR)',
earnings: 'Ingresos (EUR)',
earningsDetail: 'Detalles de ingresos',
charge: 'Carga',
ele: 'Energía (kWh)',
expend: 'Gastos (yuanes)',
expend: 'Gastos (EUR)',
noChargeData: 'No hay datos de carga',
disCharge: 'Descarga',
noDisChargeData: 'No hay datos de descarga',
@ -479,15 +480,16 @@ export default {
confirmTime: 'Hora de confirmación'
},
policy: {
policyTitle: 'Estrategia de envío',
planCurve: 'Curva planificada',
planCurveTem: 'Plantilla de curva planificada',
IssueDevice: 'Equipo para emitir el comando',
operateOrNot: 'Activar/desactivar',
socUplimit: 'Límite superior de SOC',
socDownlimit: 'Límite inferior de SOC',
effectiveTime: 'Hora de entrada en vigor',
selectEffectiveTime: 'Seleccione la hora de entrada en vigor',
distributeResult: 'Resultado de la emisión',
planCurveTem: 'Plantilla programa',
IssueDevice: 'Equipo destino',
operateOrNot: 'En operación',
socUplimit: 'Límite SOC sup.',
socDownlimit: 'Límite SOC inf.',
effectiveTime: 'Hora inicio',
selectEffectiveTime: 'Seleccionar hora',
distributeResult: 'Resultado comando',
notDelivered: 'No emitido',
commandDistribution: 'Emisión de comando',
controlDistribution: 'Emisión de control',
@ -502,13 +504,13 @@ export default {
name: 'Configuración general'
}],
radioList: [{
name: "Activar",
name: "",
disabled: false
}, {
name: "Desactivar",
name: "No",
disabled: false
}],
selectIssueDevice: 'Seleccione el equipo para emitir el comando',
selectIssueDevice: 'Seleccionar equipo',
deliverErrorNewTip: 'La configuración de mapa es incorrecta o no está configurada. Verifíquelo e inténtelo nuevamente!',
passwordSuccess: 'Contraseña correcta',
passwordError: 'Contraseña incorrecta',
@ -520,7 +522,7 @@ export default {
saveSuccess: 'Guardado con éxito',
saveError: 'Error al guardar',
delivered: 'Emitido',
selectPlanCurveTem: 'Seleccione una plantilla de curva planificada',
selectPlanCurveTem: 'Seleccionar plantilla',
deliverErrorTip: 'La potencia de carga/descarga supera la potencia nominal. Verifique la configuración de la curva planificada!',
deliverTip: '¿Confirma la emisión del comando?'
}

View File

@ -33,21 +33,21 @@ export default {
name: 'Site international'
}],
useElecPrice: 'Tarif',
workStatus: 'État de service :',
workStatus: 'Statut:',
standing: 'Inactif',
activePowerpcs: 'Puissance active :',
operatingPower: 'Puissance de service',
accumulatedElectricityConsumption: lectricité cumulée',
operatingPower: 'puissance',
accumulatedElectricityConsumption: nergie totale',
pvKpi: 'Indicateurs clés de performance photovoltaïque',
saveStandardCoal: 'Économies de charbon standard (en tonne)',
equivalentCo2Reduction: 'Réduction des émissions de CO2 (en tonne))',
equivalentTreePlantings: "Plantation d'arbres équivalente (U)",
dailyPowerGeneration: 'Production journalière',
cumulativePowerGeneration: "Quantité cumulative de production d'électricité",
cumulativePowerGeneration: "Production totale",
socialContribution: 'Contribution sociale',
energyStorageRevenueReport: "Bilan de gains du stockage d'énergie",
pvStorageRevenueReport: 'Bilan de gains photovoltaïques',
projectMonthlyPower: 'Production mensuelle du projet',
projectMonthlyPower: 'Production mensuelle',
powerGeneration: "Production d'électricité",
mpptTopu: 'Schéma de topologie MPPT',
powerGenerationCapacity: 'Puissance de production en électricité',
@ -58,8 +58,8 @@ export default {
dc: 'Courant continu',
dcVoltage: 'Tension continue',
pvPower: 'Puissance',
enmonthTotalChargePrice: 'Tarif mensuel total de chargement (EUR)',
enmonthTotalDisChargePrice: 'Tarif mensuel total de déchargement (EUR)',
enmonthTotalChargePrice: 'Coût charge mois(EUR)',
enmonthTotalDisChargePrice: 'Revenu décharge mois(EUR)',
enearnings: 'Gain (EUR)',
pvSwitch: 'Interrupteur photovoltaïque',
stationDatacom: 'Données de la centrale électrique',
@ -67,30 +67,30 @@ export default {
todayEarning: "Revenus d'aujourd'hui (EUR)",
totalRevenue: 'Bénéfices cumulés (EUR)',
ratedPower: 'Puissance nominale (kW)',
currentMonthlyPowerGeneration: "Production d'électricité ce mois-ci",
currentMonthlyPowerGeneration: "Production mensuelle",
ratedPowernokw: 'Puissance nominale',
powerGenerationStatus: "Situation de production d'électricité du projet",
powerGenerationStatus: "Aperçu de la production",
monthlyIncome: 'Revenus du mois (EUR)',
lowV: 'Tension côté basse tension',
lowI: 'Courant côté basse tension',
highV: 'Tension côté haute tension',
timesArr: [{
text: '1 minute',
text: '1 min',
value: 1
}, {
text: '5 minutes',
text: '5 min',
value: 5
}, {
text: '10 minutes',
text: '10 min',
value: 10
}, {
text: '15 minutes',
text: '15 min',
value: 15
}, {
text: '20 minutes',
text: '20 min',
value: 20
}, {
text: '30 minutes',
text: '30 min',
value: 30
}],
esiCab: "Armoire intégrée de stockage d'énergie",
@ -117,7 +117,7 @@ export default {
standby: 'Veille',
run: 'Marche',
allActivePower: 'Puissance active totale (kW) :',
cabinet: "Armoire de stockage d'énergie",
cabinet: "Armoire",
gridMeter: 'Compteur du côté de secteur',
photovoltaic: 'Photovoltaïque',
battery: 'Batterie',
@ -131,27 +131,27 @@ export default {
policy: 'Stratégie',
stationTopo: 'Schéma topologique du poste',
deviceMonitor: 'Surveillance des équipements',
runCurve: 'Courbes opérationnelles',
runCurve: 'Courbes de fonctionnement',
chargeDisData: 'Données de chargement/déchargement',
stationData: 'Données du poste',
environmentalData: 'Données de contrôle environnemental',
sevenDay: '7 derniers jours',
monthDay: '1 dernier mois',
sevenDay: 'Semaine',
monthDay: '1 mois',
monthThree: '3 derniers mois',
yearDay: '1 dernière année',
yearDay: '1 an',
tip: 'Indications',
loading: 'Chargement en cours...',
power: 'Puissance (kW)',
photovoltaicCharge: 'Chargement PV',
chargingandDischarging: 'Énergie chargée et de déchargement',
safeDaysUnit: 'Nombre de jour de service en sécurité (jour)',
totalCapacity: 'Puissance installée totale',
photovoltaicCharge: 'Charge PV',
chargingandDischarging: 'Charge/Décharge',
safeDaysUnit: 'Jours sans incident(jour)',
totalCapacity: 'Capacité totale',
systemConversionEfficiency: 'Efficacité de conversion du système',
currentPower: 'Puissance actuelle',
totalCharge: 'Énergie chargée totale',
totalDischarge: 'Énergie déchargée totale',
dailyCharge: 'Énergie chargée journalière',
dailyDischarge: 'Énergie déchargée journalière',
totalCharge: 'Énergie chargée',
totalDischarge: 'Énergie déchargée',
dailyCharge: 'Charge journalière',
dailyDischarge: 'Décharge journalière',
dayPhotovoltaic: 'Énergie de production photovoltaïque',
noData: 'Aucune donnée disponible',
station: 'Poste',
@ -183,7 +183,7 @@ export default {
eleLevel: 'Tarif',
fsdd: 'Tarif horaire hors heures pleines',
useElecPrice: 'Tarif',
dietailUnit: '(RMB/kWh)',
dietailUnit: '(EUR/kWh)',
eleprice: 'Tarif hors heures pleines',
nonTime: 'Tarif non horaire',
proxyPrice: "Prix d'achat d'électricité par procuration",
@ -257,6 +257,7 @@ export default {
sureRead: 'Confirmer la lecture',
cancel: 'Annuler',
operateSuccess: 'Opération réussie',
operateFail: 'Opération échouée',
messageReaded: "La lecture du message a été effectuée. Aucune répétition n'est nécessaire !"
},
device: {
@ -281,10 +282,10 @@ export default {
DCVol: 'Tension continue',
DCCurrent: 'Courant continu',
acbreaker: 'Disjoncteur CA',
dcbreaker: 'Disjoncteur CC',
dcbreakerCom: 'Disjoncteur CC',
runState: 'État de service',
rsState: 'État distant/local',
gridMode: 'État connecté/déconnecté',
gridModeCom: 'Statut réseau',
deviceState: 'État de périphérique',
totalActivePower: 'Puissance active totale',
totalReactivePower: 'Puissance réactive totale',
@ -302,22 +303,22 @@ export default {
localAutomatic: 'Local automatique',
localManual: 'Local manuel',
timesArr: [{
label: '1 minute',
label: '1 min',
value: 1
}, {
label: '5 minutes',
label: '5 min',
value: 5
}, {
label: '10 minutes',
label: '10 min',
value: 10
}, {
label: '15 minutes',
label: '15 min',
value: 15
}, {
label: '20 minutes',
label: '20 min',
value: 20
}, {
label: '30 minutes',
label: '30 min',
value: 30
}],
yx: 'Télésignalisation',
@ -331,8 +332,8 @@ export default {
},
clusterTotalVol: 'Tension totale de cluster/état de charge',
runData: 'Données de service',
cumCharge: 'Énergie chargée cumulée',
cumDischarge: 'Énergie déchargée cumulée',
cumCharge: 'Charge totale',
cumDischarge: 'Décharge totale',
avgTem: 'Température moyenne',
avgVol: 'Tension moyenne',
maxCellVol: 'Tension maximale par cellule',
@ -351,10 +352,10 @@ export default {
bvol: 'Tension de phase B',
cvol: 'Tension de phase C',
zxygzdl: 'Énergie active positive totale',
dlj: 'Électricité (pointe extrême)',
dlf: 'Électricité (pointe)',
dlp: 'Électricité (pleine)',
dlg: 'Électricité (creuse)',
dlj: 'Pointe+',
dlf: 'HP',
dlp: 'Interm',
dlg: 'HC',
fxygzdl: 'Énergie active négative totale',
hxyggl: "Puissance active d'enclenchement",
hxwggl: "Puissance réactive d'enclenchement",
@ -405,7 +406,7 @@ export default {
stackTotalCurrent: 'Courant total du rack',
stackSoc: 'État de charge du rack',
CumulativeCharge: 'Énergie chargée cumulée',
CumulativeDischarge: 'Énergie déchargée cumulée',
CumulativeDischarge: 'Décharge totale',
zdz: "Résistance d'isolation positive",
fdz: "Résistance d'isolation négative",
rechargeCapacity: 'Énergie chargée disponible',
@ -419,22 +420,22 @@ export default {
historyData: 'Données historiques'
},
earning: {
changeDischargePro: 'Généralités de chargement/déchargement du projet',
capacity: 'Puissance installée',
monthTotalCharge: 'Énergie chargée mensuelle totale',
monthTotalDischarge: 'Énergie déchargée mensuelle totale',
monthEff: 'Efficacité de conversion mensuelle du système',
chargeVol: 'Énergie chargée cumulée',
dischargeVol: 'Énergie déchargée cumulée',
totalEff: 'Efficacité de conversion cumulée du système',
changeDischargePro: 'Aperçu charge/décharge',
capacity: 'Capacité',
monthTotalCharge: 'Charge mois',
monthTotalDischarge: 'Décharge mois',
monthEff: 'Rendement mois',
chargeVol: 'Charge totale',
dischargeVol: 'Décharge totale',
totalEff: 'Rendement total',
projectRevenue: 'Gains du projet',
monthTotalChargePrice: 'Tarif mensuel total de chargement (RMB)',
monthTotalDisChargePrice: 'Tarif mensuel total de déchargement (RMB)',
earnings: 'Gain (RMB)',
monthTotalChargePrice: 'Coût charge mois(EUR)',
monthTotalDisChargePrice: 'Revenu décharge mois(EUR)',
earnings: 'Gain (EUR)',
earningsDetail: 'Détails des gains',
charge: 'Chargement',
ele: 'Énergie (kWh)',
expend: 'Dépenses (RMB)',
expend: 'Dépenses (EUR)',
noChargeData: 'Aucune donnée de chargement disponible',
disCharge: 'Déchargement',
noDisChargeData: 'Aucune donnée de déchargement disponible',
@ -479,14 +480,15 @@ export default {
confirmTime: 'Heure de confirmation'
},
policy: {
policyTitle: 'Stratégie de distribution',
planCurve: 'Courbe programmée',
planCurveTem: 'Modèle de courbe programmée',
IssueDevice: "Équipement cable d'envoi d'ordre",
planCurveTem: 'Modèle de planning',
IssueDevice: "Équipement cible",
operateOrNot: 'Mise en service ?',
socUplimit: "Limite supérieure d'état de charge",
socDownlimit: "Limite inférieure d'état de charge",
effectiveTime: 'Heure de validation',
selectEffectiveTime: "Veuillez choisir l'heure de validation",
socUplimit: "Limite SOC max",
socDownlimit: "Limite SOC min",
effectiveTime: "Heure d'effet",
selectEffectiveTime: "Sélectionner l'heure",
distributeResult: "Résultat d'envoi",
notDelivered: 'Non envoyé',
commandDistribution: "Envoi d'ordre",
@ -502,13 +504,13 @@ export default {
name: 'Réglages généraux'
}],
radioList: [{
name: "Mise en service",
name: "Oui",
disabled: false
}, {
name: "Non mise en service",
name: "Non",
disabled: false
}],
selectIssueDevice: "Veuillez choisir un équipement cable d'envoi d'ordre",
selectIssueDevice: "Sélectionner un équipement",
deliverErrorNewTip: 'Erreur de configuration ou configuration manquante du mapping ! Veuillez réessayer après confirmation !',
passwordSuccess: 'Mot de passe correct',
passwordError: 'Mot de passe incorrect',
@ -520,7 +522,7 @@ export default {
saveSuccess: 'Sauvegarde réussie',
saveError: 'Sauvegarde échouée',
delivered: 'Envoi fini',
selectPlanCurveTem: 'Veuillez choisir un modèle de courbe programmée',
selectPlanCurveTem: 'Sélectionner un modèle',
deliverErrorTip: 'La puissance de chargement/déchargement dépasse la puissance nominale. Veuillez confirmer les réglages de courbe programmée !',
deliverTip: "Voulez-vous envoyer l'ordre ?"
}

View File

@ -39,21 +39,21 @@ export default {
}
],
useElecPrice: 'Taryfa',
workStatus: 'Status pracy: ',
workStatus: 'Status: ',
standing: 'statyczny',
activePowerpcs: 'Moc czynna: ',
operatingPower: 'Moc operacyjna',
accumulatedElectricityConsumption: 'Łączny pobór mocy',
operatingPower: 'Moc',
accumulatedElectricityConsumption: 'Energia całkowita',
pvKpi: 'Fotowoltaiczny wskaźnik KPI',
saveStandardCoal: 'Oszczędność węgla standardowego (w tonach)',
equivalentCo2Reduction: 'Redukcja emisji CO₂ (w tonach)',
equivalentTreePlantings: 'Równoważność nasadzenia drzew (szt.)',
dailyPowerGeneration: 'Dzienne wytwarzanie energii',
cumulativePowerGeneration: 'Łączna produkcja energii',
cumulativePowerGeneration: 'Całkowita produkcja',
socialContribution: 'Wkład społeczny',
energyStorageRevenueReport: 'Rachunek zysków magazynowania energii',
pvStorageRevenueReport: 'Fotowoltaiczny rachunek zysków',
projectMonthlyPower: 'Miesięczna produkcja energii w ramach projektu',
projectMonthlyPower: 'Miesięczna produkcja',
powerGeneration: 'Generowana energia elektryczna',
mpptTopu: 'Schemat topologii MPPT',
powerGenerationCapacity: 'Generowana moc',
@ -63,10 +63,10 @@ export default {
busCurrent: 'Prąd AKU',
dc: 'Prąd stały',
dcVoltage: 'Napięcie stałe',
operatingPower: 'Moc operacyjna',
pvPower: 'Moc',
enmonthTotalChargePrice: 'Całkowita cena ładowania w tym miesiącu (PLN)',
enmonthTotalDisChargePrice: 'Całkowita cena rozładowania w tym miesiącu (PLN)',
operatingPower: 'Moc',
pvPower: 'pv Moc',
enmonthTotalChargePrice: 'Koszt ładowania w miesiącu(PLN)',
enmonthTotalDisChargePrice: 'Przychód z rozładowania w miesiącu(PLN)',
enearnings: 'Wpływy (PLN)',
pvSwitch: 'Przełącznik PV',
stationDatacom: 'Dane elektrowni',
@ -74,35 +74,35 @@ export default {
todayEarning: 'Dzisiejsze zyski (EUR)',
totalRevenue: 'Skumulowane zyski(EUR)',
ratedPower: 'Moc nominalna(kW)',
currentMonthlyPowerGeneration: 'Produkcja energii w tym miesiącu',
currentMonthlyPowerGeneration: 'Miesięczna produkcja',
ratedPowernokw: 'Moc nominalna',
powerGenerationStatus: 'Produkcja energii elektrycznej w projekcie',
powerGenerationStatus: 'Przegląd produkcji energii',
monthlyIncome: 'W tym miesiącu zyski(EUR)',
lowV:'Napięcie boczne niskiego napięcia',
lowI:'Prąd boczny niskiego napięcia',
highV:'Napięcie boczne wysokiego napięcia',
timesArr: [{
text: '1 minuta.',
text: '1 min',
value: 1
},
{
text: '5 minut.',
text: '5 min',
value: 5
},
{
text: '10 minut.',
text: '10 min',
value: 10
},
{
text: '15 minut.',
text: '15 min',
value: 15
},
{
text: '20 minut.',
text: '20 min',
value: 20
},
{
text: '30 minut.',
text: '30 min',
value: 30
}
],
@ -130,7 +130,7 @@ export default {
standby: 'Tryb gotowości',
run: 'Praca',
allActivePower: 'Całkowita moc czynna (kW):',
cabinet: 'Szafa magazyn energii',
cabinet: 'Szafa',
gridMeter: 'Liczniki po stronie sieci',
photovoltaic: 'Fotowoltaika',
battery: 'Akumulator',
@ -144,26 +144,26 @@ export default {
policy: 'Strategia',
stationTopo: 'Topologia stacji',
deviceMonitor: 'Monitorowanie sprzętu',
runCurve: 'Krzywa działania',
runCurve: 'Krzywa pracy',
chargeDisData: 'Dane ładowania i rozładowania',
stationData: 'Dane stacji',
environmentalData: 'Dane kontroli środ.',
sevenDay: 'Ostatnie siedem dni',
monthDay: 'Ostatni miesiąc',
sevenDay: 'Tydzień',
monthDay: 'Miesiąc',
monthThree: 'Ostatnie trzy miesiące',
yearDay: 'Ostatni rok',
yearDay: 'Rok',
tip: 'Informacja',
loading: 'Ładowanie zasobów...',
power: 'Moc (kW)',
photovoltaicCharge: 'Ładowanie fotowoltaiczne',
chargingandDischarging: 'Wolumen ładowania i rozładowania',
safeDaysUnit: 'Dni bezpiecznej pracy',
totalCapacity: 'Całkowita zainstalowana moc',
photovoltaicCharge: 'Ładowanie PV',
chargingandDischarging: 'Ładowanie i rozładowanie',
safeDaysUnit: 'Dni bez awarii',
totalCapacity: 'Całkowita pojemność',
systemConversionEfficiency: 'Wydajność konwersji systemu',
currentPower: 'Bieżąca moc',
totalCharge: 'Całkowite ładowanie',
totalDischarge: 'Całkowite rozładowanie',
dailyCharge: 'Dzienna ładowanie',
dailyCharge: 'Dzienne ładowanie',
dailyDischarge: 'Dzienne rozładowanie',
dayPhotovoltaic: 'Wytworzona energia fotowoltaiczna',
noData: 'Brak danych',
@ -271,6 +271,7 @@ export default {
cancel: 'Anuluj',
messageDetail: 'Szczegóły wiadomości',
operateSuccess: 'Operacja zakończona sukcesem',
operateFail: 'Operacja nie powiodła się',
messageReaded: 'Wiadomość została odczytana, nie ma potrzeby powtarzania akcji.'
},
device: {
@ -295,10 +296,10 @@ export default {
DCVol: 'Napięcie stałe',
DCCurrent: 'Prąd stały',
acbreaker: 'Wyłącznik obwodu prądu zmiennego',
dcbreaker: 'Wyłącznik obwodu prądu stałego',
dcbreakerCom: 'Wyłącznik obwodu prądu stałego',
runState: 'Stan pracy',
rsState: 'Stan zdalny/lokalny',
gridMode: 'Stan sieci/Poza siecią',
gridModeCom: 'Status sieci',
deviceState: 'Stan urządzenia',
totalActivePower: 'Calkowita moc czynna',
totalReactivePower: 'Calkowita moc bierna',
@ -317,27 +318,27 @@ export default {
localManual: 'Lokalnie ręcznie',
timesArr: [
{
label: '1 minuta',
label: '1 min',
value: 1
},
{
label: '5 minut',
label: '5 min',
value: 5
},
{
label: '10 minut',
label: '10 min',
value: 10
},
{
label: '15 minut',
label: '15 min',
value: 15
},
{
label: '20 minut',
label: '20 min',
value: 20
},
{
label: '30 minut',
label: '30 min',
value: 30
}
],
@ -352,8 +353,8 @@ export default {
},
clusterTotalVol: 'Calkowite napięcie klastra/SOC',
runData: 'Dane operacyjne',
cumCharge: 'Łączne obciążenie',
cumDischarge: 'Łączne rozładowanie',
cumCharge: 'Całkowite ładowanie',
cumDischarge: 'Całkowite rozładowanie',
avgTem: 'Średnia temperatura',
avgVol: 'Średnie napięcie',
maxCellVol: 'Maksymalne napięcie na jednostkę',
@ -372,10 +373,10 @@ export default {
bvol: 'Napięcie fazy B',
cvol: 'Napięcie fazy C',
zxygzdl: 'Calkowita dodatnia moc czynna',
dlj: 'Energia elektryczna (super szczyt)',
dlf: 'Energia elektryczna (szczyt)',
dlp: 'Energia elektryczna (zwykły)',
dlg: 'Energia elektryczna (dolina)',
dlj: 'Szczyt krytyczny',
dlf: 'Szczyt',
dlp: 'Poziom średni',
dlg: 'Poza szczytem',
fxygzdl: 'Calkowita odwrotna moc czynna',
hxyggl: 'Moc czynna w fazie kombinowanej',
hxwggl: 'Moc bierna w fazie kombinowanej',
@ -428,7 +429,7 @@ export default {
stackTotalCurrent: 'Prąd stosu',
stackSoc: 'SOC stosu',
CumulativeCharge: 'Łączne obciążenie',
CumulativeDischarge: 'Łączne rozładowanie',
CumulativeDischarge: 'Całkowite rozładowanie',
zdz: 'Dodatnia rezystancja izolacji',
fdz: 'Ujemna rezystancja izolacji',
rechargeCapacity: 'Pojemność ładowania',
@ -442,17 +443,17 @@ export default {
historyData: 'Dane historyczne'
},
earning: {
changeDischargePro: 'Ogólna charakterystyka ładowania i rozładowania projektu',
capacity: 'Zainstalowana moc',
monthTotalCharge: 'Łączna ilość ładowania w tym miesiącu',
monthTotalDischarge: 'Łączna ilość rozładowania w tym miesiącu',
changeDischargePro: 'Przegląd ładowania i rozładowania',
capacity: 'Pojemność',
monthTotalCharge: 'Miesięczne ładowanie',
monthTotalDischarge: 'Miesięczne rozładowanie',
monthEff: 'Miesięczna sprawność systemu',
chargeVol: 'Łączne obciążenie',
dischargeVol: 'Łączne rozładowanie',
totalEff: 'Skumulowana sprawność systemu',
chargeVol: 'Całkowite ładowanie',
dischargeVol: 'Całkowite rozładowanie',
totalEff: 'Całkowita sprawność systemu',
projectRevenue: 'Skumulowana sprawność systemu',
monthTotalChargePrice: 'Całkowita cena ładowania w tym miesiącu (PLN)',
monthTotalDisChargePrice: 'Całkowita cena rozładowania w tym miesiącu (PLN)',
monthTotalChargePrice: 'Koszt ładowania w miesiącu(PLN)',
monthTotalDisChargePrice: 'Przychód z rozładowania w miesiącu(PLN)',
earnings: 'Wpływy (PLN)',
earningsDetail: 'Szczegóły przychodów',
charge: 'Ładowanie',
@ -505,15 +506,16 @@ export default {
confirmTime: 'Czas potwierdzenia'
},
policy: {
policyTitle: 'Strategia dystrybucji',
planCurve: 'Krzywa planowania',
planCurveTem: 'Szablon krzywej planowania',
IssueDevice: 'Polecenie wydane urządzeniu',
operateOrNot: 'Czy uruchomić',
socUplimit: 'Górny limit SOC',
socDownlimit: 'Dolny limit SOC',
effectiveTime: 'Data rozpoczęcia',
selectEffectiveTime: 'Wybierz efektywny czas',
distributeResult: 'Wynik wysłania',
planCurveTem: 'Szablon harmonogramu',
IssueDevice: 'Urządzenie docelowe',
operateOrNot: 'W eksploatacji',
socUplimit: 'Górna granica SOC',
socDownlimit: 'Dolna granica SOC',
effectiveTime: 'Czas rozpoczęcia',
selectEffectiveTime: 'Wybierz czas',
distributeResult: 'Wynik polecenia',
notDelivered: 'Nie wysłano',
commandDistribution: 'Wysłanie polecenia',
controlDistribution: 'Wysłanie sterowania',
@ -532,15 +534,15 @@ export default {
],
radioList: [
{
name: 'uruchomić',
name: 'Tak',
disabled: false
},
{
name: 'nie uruchamiać',
name: 'Nie',
disabled: false
}
],
selectIssueDevice: 'Wybierz urządzenie wydające polecenie',
selectIssueDevice: 'Wybierz urządzenie',
deliverErrorNewTip: 'Relacja mapowania jest nieprawidłowo skonfigurowana lub nie została skonfigurowana, potwierdź i spróbuj ponownie!',
passwordSuccess: 'Hasło jest prawidłowe',
passwordError: 'Błędne hasło',
@ -552,7 +554,7 @@ export default {
saveSuccess: 'Zapisano pomyślnie',
saveError: 'Zapis nie powiódł się',
delivered: 'Wysłano',
selectPlanCurveTem: 'Wybierz szablon krzywej planu',
selectPlanCurveTem: 'Wybierz szablon harmonogramu',
deliverErrorTip: 'Moc ładowania/rozładowania jest większa niż moc znamionowa, sprawdź ustawienie krzywej harmonogramu!',
deliverTip: 'Czy na pewno wysłać polecenie?'
}

View File

@ -264,8 +264,9 @@ export default {
sureRead: '确认已读',
cancel: '取消',
messageDetail: '消息详情',
operateSuccess: '操作成功',
messageReaded: '该消息已读,无需重复操作'
operateSuccess: '操作成功',
operateFail: '操作失败',
messageReaded: '该消息已读,无需重复操作'
},
device: {
inputNameQuery: '输入名称搜索',
@ -289,10 +290,10 @@ export default {
DCVol: '直流电压',
DCCurrent: '直流电流',
acbreaker: '交流断路器',
dcbreaker: '直流断路器',
dcbreakerCom: '直流断路器',
runState: '运行状态',
rsState: '远方/就地状态',
gridMode: '并离网状态',
gridModeCom: '并离网状态',
deviceState: '设备状态',
totalActivePower: '总有功功率',
totalReactivePower: '总无功功率',
@ -549,5 +550,6 @@ export default {
selectPlanCurveTem: '请选择计划曲线模板',
deliverErrorTip: '充放电功率大于额定功率,请确认计划曲线设置!',
deliverTip: '是否确定下发命令?',
policyTitle: '策略下发',
}
};

View File

@ -6,7 +6,7 @@ Vue.config.productionTip = false
App.mpType = 'app'
// 引入全局 uView 框架
import uView from 'uview-ui'
import uView from './uview-ui'
Vue.use(uView)
@ -18,7 +18,7 @@ let vuexStore = require('@/store/$u.mixin.js')
Vue.mixin(vuexStore)
// 引入 uView 对小程序分享的 mixin 封装
let mpShare = require('uview-ui/libs/mixin/mpShare.js')
let mpShare = require('./uview-ui/libs/mixin/mpShare.js')
Vue.mixin(mpShare)
// Vue i18n 国际化

View File

@ -2,8 +2,8 @@
"name" : "Zeta Cloud",
"appid" : "__UNI__86592F3",
"description" : "Zetatech",
"versionName" : "2.0.16",
"versionCode" : 221,
"versionName" : "2.0.18",
"versionCode" : 223,
"transformPx" : false,
"sassImplementationName" : "node-sass",
"app-plus" : {

View File

@ -97,6 +97,7 @@
"navigationStyle": "custom"
}
}
]
},

View File

@ -136,7 +136,7 @@
[3, 120]
],
font: [{
text: this.$t('homePage.device.gridMode') + ':',
text: this.$t('homePage.device.gridModeCom') + ':',
size: 14,
color: "#999999",
width: 50,

View File

@ -7,7 +7,7 @@
</view>
</view>
<view class="box">
<Section :title="$t('homePage.device.totalAcReaPower')">
<Section :title="$t('homePage.device.totalAcReaPower')" :style="language !== 'zh_CN'? 'flex-wrap: wrap;':''">
<view slot="right" style="flex: 1">
<view class="top-right-box">
<span class="time">{{$t('homePage.device.timeGranularity')}}:</span>
@ -287,10 +287,10 @@
{
type: "text",
coord: [
[35, 80]
[3, 80]
],
font: [{
text: this.$t('homePage.device.dcbreaker') + ':',
text: this.$t('homePage.device.dcbreakerCom') + ':',
size: 14,
color: "#999999",
width: 50,
@ -330,7 +330,7 @@
[3, 120]
],
font: [{
text: this.$t('homePage.device.gridMode') + ':',
text: this.$t('homePage.device.gridModeCom') + ':',
size: 14,
color: "#999999",
width: 50,
@ -347,7 +347,7 @@
{
type: "text",
coord: [
[35, 140]
[3, 140]
],
font: [{
text: this.$t('homePage.device.deviceState') + ':',

View File

@ -1,245 +1,348 @@
<template>
<view style="height: 100vh">
<view class="">
<u-navbar title="策略下发" :is-back="true" :background="background" :border-bottom="false"
:custom-back="toback">
</u-navbar>
</view>
<view class="policeForm">
<view class="" v-for="(item, index) in smallArr" :key="index">
<view class="" v-if="item.type == 'Input'">
<u-form-item :label="item[`label_${lang}`]" :prop="item.prop">
<u-input :min="item.min" :max="item.max" v-model.number="item.value" type="number"
:placeholder="item[`place_${lang}`]" @input="handleInput(item, $event)" />
</u-form-item>
</view>
<view class="" v-if="item.type == 'Switch'">
<u-form-item :label="item[`label_${lang}`]" :prop="item.prop">
<u-switch :size="40" v-model="item.value"></u-switch>
</u-form-item>
</view>
<view class="" v-if="item.type == 'Select'" @click="selectShow(item, index)">
<u-form-item :label="item[`label_${lang}`]" :prop="item.prop">
<view class="" v-show="false">
<u-input v-model="item.value" disabled @click="selectShow(item, index)" />
</view>
<view class="">
{{ item.selectLabel || $t("homePage.alarm.placeSelect") }}
</view>
<u-select :key="item.prop" @confirm="confirm($event, item)" v-model="item.isShow"
:list="getSelectList(item)"></u-select>
</u-form-item>
</view>
</view>
<view style="height: 100vh">
<view class="">
<u-navbar
:title="$t('homePage.policy.policyTitle')"
:is-back="true"
title-color="#FFF"
:background="background"
:border-bottom="false"
:custom-back="toback"
>
</u-navbar>
</view>
<view class="policeForm">
<u-form ref="form" labelPosition="top">
<view class="" v-for="(item, index) in smallArr" :key="index">
<view class="" v-if="item.type == 'Input'">
<u-form-item :label="item[`label_${lang}`]" :prop="item.prop">
<u-input
:key="'input_' + item.prop + '_' + item.inputKey"
:min="item.min"
:max="item.max"
:value="item.value"
type="number"
:placeholder="item[`place_${lang}`]"
@input="handleInput(item, $event)"
/>
</u-form-item>
</view>
<view class="" v-if="item.type == 'Switch'">
<u-form-item :label="item[`label_${lang}`]" :prop="item.prop">
<u-switch :size="40" v-model="item.value"></u-switch>
</u-form-item>
</view>
<view class="" v-if="item.type == 'Select'">
<u-form-item :label="item[`label_${lang}`]" :prop="item.prop">
<view class="" v-show="false">
<u-input
v-model="item.value"
disabled
@click="selectShow(item, index)"
/>
</view>
<view class="select-value" @click.stop="selectShow(item, index)">
{{ item.selectLabel || $t("homePage.alarm.placeSelect") }}
</view>
<u-select
:key="item.prop"
@confirm="confirm($event, item)"
v-model="item.isShow"
:list="getSelectList(item)"
></u-select>
</u-form-item>
</view>
</view>
</u-form>
<button @click="submitDevice" type="success" size="mini" style="
<button
@click="submitDevice"
type="success"
size="mini"
style="
background-color: #009458;
padding: 10rpx 0;
color: #fff;
margin-top: 40rpx;
width: 100%;
">
{{ $t("homePage.mine.submit") }}
</button>
</view>
</view>
"
>
{{ $t("homePage.mine.submit") }}
</button>
</view>
<u-toast ref="uToast" />
</view>
</template>
<script>
import {
formList
} from "@/common/form.js";
import {
Langlist
} from "@/common/lang";
import mqtt from "@/uni_modules/leliven-mqtt/index.js";
export default {
import { formList } from "@/common/form.js";
import { Langlist } from "@/common/lang";
import mqtt from "@/uni_modules/leliven-mqtt/index.js";
import pako from "pako";
export default {
data() {
return {
formList: formList,
background: {
backgroundColor: "#0EA17E",
},
data() {
return {
formList: formList,
background: {
backgroundColor: "#0EA17E",
},
lang: 'en',
mqttClient: null,
backData: {},
smallArr: [],
user: {
username: 'admin', // 设置用户名
password: 'zzkj@688737' // 设置密码
}
mqttClient: null,
backData: {},
smallArr: [],
user: {
username: "admin", // 设置用户名
password: "zzkj@688737", // 设置密码
},
};
},
};
},
computed: {
language() {
return this.$store.state.vuex_language
},
currentStation() {
console.log(this.vuex_currentStation)
return this.vuex_currentStation;
},
},
computed: {
lang() {
return (
Langlist.find((v) => v.value == this.$store.state.vuex_language).prop ||
"en"
);
},
currentStation() {
return this.vuex_currentStation;
},
},
onLoad() {
this.getSn();
},
onShow() {
this.initmqttClient()
},
methods: {
getSn() {
this.$u.api.station
.getStationPostionSn({
stationId: this.currentStation.id,
})
.then((res) => {
this.sn = res.data[0]?.sn;
this.initmqttClient();
});
},
initmqttClient() {
console.log(this.lang);
console.log(this.currentStation);
// 初始化客户端连接地址
// #ifdef H5
let mqttClient = mqtt.connect("ws://1.95.170.86:8083/mqtt", {
...this.user,
});
// #endif
// #ifdef MP-WEIXIN||APP-PLUS
let mqttClient = mqtt.connect("wx://1.95.170.86:8083/mqtt", {
...this.user,
});
// #endif
this.mqttClient = mqttClient;
// 连接MQ服务
mqttClient
.on("connect", (res) => {
console.log("连接成功");
// 订阅主题
mqttClient.subscribe(`1/ems/${this.sn}/control/response`, (err) => {
console.log(`1/app/${this.sn}/control/request`);
if (!err) {
// 订阅成功
mqttClient.publish(
`1/app/${this.sn}/control/request`,
JSON.stringify({
fun: "GET",
type: "WJ_Get_NewControlSystem",
content: 0,
}),
);
}
});
})
.on("reconnect", function () {
console.log("重新连接");
})
.on("error", function () {
console.log("连接失败");
})
.on("end", function () {
console.log("连接End");
})
.on("message", (topic, message) => {
console.log(this.decodeGzipBase64(message.toString()), "111");
let data = this.decodeGzipBase64(message.toString());
if (data.content && data.content.params) {
this.control(data.content);
} else if (data.content == 1) {
this.$refs.uToast.show({
title: this.$t("homePage.mine.operateSuccess"),
type: "success",
});
} else {
uni.showToast({
title: this.$t("homePage.mine.operateFail"),
icon: "none",
});
}
});
},
methods: {
initmqttClient() {
// 初始化客户端连接地址
// #ifdef H5
let mqttClient = mqtt.connect('ws://13.39.200.14:8083/mqtt', {
...this.user
})
// #endif
// #ifdef MP-WEIXIN||APP-PLUS
let mqttClient = mqtt.connect('wx://13.39.200.14:8083/mqtt', {
...this.user
})
// #endif
console.log(mqttClient,'888')
this.mqttClient = mqttClient
// 连接MQ服务
mqttClient.on('connect', function(res) {
console.log('连接成功')
console.log(res)
// 订阅主题
mqttClient.subscribe('presence', function(err) {
if (!err) {
// 订阅成功
mqttClient.publish('presence', 'hello mqtt')
}
})
}).on('reconnect', function() {
console.log('重新连接')
}).on('error', function() {
console.log('连接失败')
}).on('end', function() {
console.log('连接End')
}).on('message', function(topic, message) {
// 收到MQ消息
console.log(message.toString())
})
},
decodeGzipBase64(base64Str) {
// 1. base64 → Uint8Array
const binaryStr = atob(base64Str);
const len = binaryStr.length;
const bytes = new Uint8Array(len);
for (let i = 0; i < len; i++) {
bytes[i] = binaryStr.charCodeAt(i);
}
// 2. gunzip 解压
const decompressed = pako.ungzip(bytes, {
to: "string",
});
// 3. 转 JSON如果是 JSON
return JSON.parse(decompressed);
},
getSelectList(item) {
if (item.selectArr && item.selectArr.length > 0) {
return item.selectArr.map((option) => ({
value: option.value.toString(),
label: option[`label_${this.lang}`] || option.label,
}));
}
return [];
},
control(NewControlSystemShow_data) {
console.log(NewControlSystemShow_data, "123");
this.formList.forEach((item) => {
if (
item.type == "Switch" &&
NewControlSystemShow_data?.smallScreen?.includes(item.prop)
) {
this.$set(
item,
"value",
NewControlSystemShow_data?.params[item.prop] ? true : false,
);
}
if (
item.type == "Input" &&
NewControlSystemShow_data?.smallScreen?.includes(item.prop)
) {
this.$set(
item,
"value",
NewControlSystemShow_data?.params[item.prop] ?? item.default,
);
}
if (
item.type == "Select" &&
NewControlSystemShow_data?.smallScreen?.includes(item.prop)
) {
const newValue =
NewControlSystemShow_data?.params[item.prop] ?? item.default;
this.$set(item, "value", newValue);
item.selectLabel = item.selectArr.find((v) => v.value == newValue)?.[
`label_${this.lang}`
];
}
this.$set(item, "isShow", false);
});
this.backData = NewControlSystemShow_data;
this.smallArr = this.formList.filter((v) =>
NewControlSystemShow_data?.smallScreen.includes(v.prop),
);
console.log(this.smallArr, "234");
},
confirm(val, item) {
if (val && val.length > 0) {
this.$set(item, "value", val[0].value);
this.$set(item, "selectLabel", val[0].label);
}
this.$set(item, "isShow", false);
},
handleInput(item, value) {
try {
// u-input 组件 @input 事件直接传递 value 值,不是 event 对象
let iptval = String(value || "").replace(/[^0-9.]/g, "");
const parts = iptval.split(".");
if (parts.length > 2) {
iptval = parts[0] + "." + parts.slice(1).join("");
}
if (!iptval || iptval === ".") {
item.value = 0;
return;
}
let numVal = Number(iptval);
numVal = isNaN(numVal) ? 0 : numVal;
// 检查是否需要强制更新(值被限制)
let needForceUpdate = false;
if (item.min !== undefined && item.min !== null && numVal < item.min) {
numVal = item.min;
needForceUpdate = true;
}
if (item.max !== undefined && item.max !== null && numVal > item.max) {
numVal = item.max;
needForceUpdate = true;
}
decodeGzipBase64(base64Str) {
// 1. base64 → Uint8Array
const binaryStr = atob(base64Str);
const len = binaryStr.length;
const bytes = new Uint8Array(len);
item.value = numVal;
for (let i = 0; i < len; i++) {
bytes[i] = binaryStr.charCodeAt(i);
}
// 如果值被限制,强制重新渲染输入框
if (needForceUpdate) {
this.$set(item, "inputKey", (item.inputKey || 0) + 1);
}
} catch (error) {
console.log("handleInput方法错误:", error);
}
},
// 2. gunzip 解压
const decompressed = pako.ungzip(bytes, {
to: "string"
});
// 3. 转 JSON如果是 JSON
return JSON.parse(decompressed);
},
getSelectList(item) {
if (item.selectArr && item.selectArr.length > 0) {
return item.selectArr.map(option => ({
value: option.value.toString(),
label: option[`label_${this.lang}`] || option.label
}))
}
return []
},
control(NewControlSystemShow_data) {
this.formList.forEach(item => {
if (item.type == "Switch") {
item.value = NewControlSystemShow_data?.params[item.prop] ? true : false
} else {
item.value = NewControlSystemShow_data?.params[item.prop] || item.default
}
if (item.type == 'Select') {
item.selectLabel = item.selectArr.find(v => v.value == item.value)?.[`label_${this.lang}`]
}
item.isShow = false
})
this.backData = NewControlSystemShow_data
this.smallArr = this.formList.filter(v => NewControlSystemShow_data?.smallScreen.includes(v.prop))
},
confirm(val, item) {
if (val && val.length > 0) {
item.value = val[0].value
item.selectLabel = val[0].label
}
item.isShow = false
},
handleInput(item, event) {
try {
let inputValue = event.detail.value;
let iptval = String(inputValue).replace(/[^0-9.]/g, '');
const parts = iptval.split('.');
if (parts.length > 2) {
iptval = parts[0] + '.' + parts.slice(1).join('');
}
if (!iptval || iptval === '.') {
item.value = 0;
return;
}
let numVal = Number(iptval);
if (item.min !== undefined && item.min !== null) {
numVal = Math.max(numVal, item.min);
}
if (item.max !== undefined && item.max !== null) {
numVal = Math.min(numVal, item.max);
}
numVal = isNaN(numVal) ? 0 : numVal;
item.value = numVal;
} catch (error) {
console.log('handleInput方法错误:', error);
}
},
toback() {
uni.navigateBack();
},
selectShow(val, index) {
console.log(123);
this.$set(val, "isShow", true);
},
submitDevice() {
let smallParam = this.smallArr.reduce((pre, cur) => {
pre[cur.prop] = cur.type == "Switch" ? (cur.value ? 1 : 0) : cur.value;
pre[cur.prop] = Number(pre[cur.prop]);
return pre;
}, {});
toback() {
uni.navigateBack()
},
selectShow(val, index) {
val.isShow = true
},
submitDevice() {
let smallParam = this.smallArr.reduce((pre, cur) => {
pre[cur.prop] = cur.type == "Switch" ? cur.value ? 1 : 0 : cur.value
pre[cur.prop] = Number(pre[cur.prop])
return pre
}, {})
console.log(this.mqttClient)
this.mqttClient.publish('presence', JSON.stringify({
fun: 'SET',
type: 'WJ_Set_NewControlSystem',
content: {
...this.backData,
params: {
...this.backData.params,
...smallParam
}
}
}))
},
},
};
this.mqttClient.publish(
`1/app/${this.sn}/control/request`,
JSON.stringify({
fun: "SET",
type: "WJ_Set_NewControlSystem",
content: {
...this.backData,
params: {
...this.backData.params,
...smallParam,
},
},
}),
);
},
},
};
</script>
<style lang="scss" scoped>
.policeForm {
margin: 22rpx;
padding: 22rpx;
background-color: #fff;
box-shadow: 0px 4rpx 16rpx rgba(0, 0, 0, 0.1);
border-radius: 8rpx;
}
</style>
.policeForm {
margin: 22rpx;
padding: 22rpx;
background-color: #fff;
box-shadow: 0px 4rpx 16rpx rgba(0, 0, 0, 0.1);
border-radius: 8rpx;
}
.select-value {
padding: 16rpx 0;
color: #333;
min-height: 60rpx;
}
</style>

View File

@ -84,6 +84,8 @@
{{ $t('homePage.home.emsControl') }}
</button>
</view>
</view>
@ -165,6 +167,7 @@
return this.vuex_language
}
},
watch: {
currentStation: {
handler(val) {
@ -282,12 +285,18 @@
this.userId = this.vuex_user.userId
},
methods: {
toDeviceControl() {
console.log(123)
uni.navigateTo({
url:'/pages/home-page/policy-Config/index'
})
},
toStrategy(){
uni.navigateTo({
url:'/pages/home-page/strategy/index'
})
},
confirmTime(val) {
this.formInfo.effectiveTime = val.hour + ':' + val.minute
this.formInfo.planRefreshH = val.hour

View File

@ -74,9 +74,9 @@
</view>
<view class="box">
<Section :title="$t('homePage.home.chargeDisData')">
<Section :title="$t('homePage.home.chargeDisData')" :style="language !== 'zh_CN'? 'flex-wrap: wrap;':''">
<view slot="right" style="flex: 1">
<view class="top-right-box">
<view class="top-right-box" :style="language !== 'zh_CN'? 'margin-top: 10rpx;':''">
<view class="top-right-item" :class="{ active: activeTime === 'day' }"
@click="changeTime('day')">{{this.$t('homePage.home.sevenDaycom')}}
</view>

View File

@ -1,4 +1,3 @@
import config from '@/common/config.js';
import Vue from 'vue'
import Vuex from 'vuex'
@ -6,20 +5,22 @@ Vue.use(Vuex)
let lifeData = {};
try{
try {
// 尝试获取本地是否存在lifeData变量第一次启动APP时是不存在的
lifeData = uni.getStorageSync('lifeData');
}catch(e){
} catch (e) {
}
// 需要永久存储且下次APP启动需要取出的在state中的变量名
let saveStateKeys = ['vuex_user', 'vuex_token', 'vuex_remember', 'vuex_locale','vuex_isAgent','vuex_language','vuex_stationValue'];
let saveStateKeys = ['vuex_user', 'vuex_token', 'vuex_remember', 'vuex_locale', 'vuex_isAgent', 'vuex_language',
'vuex_stationValue'
];
// 保存变量到本地存储中
const saveLifeData = function(key, value){
const saveLifeData = function(key, value) {
// 判断变量名是否在需要存储的数组中
if(saveStateKeys.indexOf(key) != -1) {
if (saveStateKeys.indexOf(key) != -1) {
// 获取本地存储的lifeData对象将变量添加到对象中
let tmp = uni.getStorageSync('lifeData');
// 第一次打开APP不存在lifeData变量故放一个{}空对象
@ -49,47 +50,46 @@ const store = new Vuex.Store({
vuex_isAgent: lifeData.vuex_isAgent ? lifeData.vuex_isAgent : '',
vuex_iv: lifeData.vuex_iv ? lifeData.vuex_iv : '',
vuex_psdkey: lifeData.vuex_psdkey ? lifeData.vuex_psdkey : '',
vuex_StationShow:lifeData.vuex_StationShow ? lifeData.vuex_StationShow : [0,0,0],
vuex_StationShow: lifeData.vuex_StationShow ? lifeData.vuex_StationShow : [0, 0, 0],
tabbar_current: 0,
vuex_stationValue:lifeData.vuex_stationValue ? lifeData.vuex_stationValue : '',
vuex_inverterFlag:lifeData.vuex_inverterFlag ? lifeData.vuex_inverterFlag : 0,
tabbarList: [
{
"icon": "warning",
"text": "告警",
'name': 'Alarm'
},
// {
// "icon": "order",
// "text": "设备",
// 'name': 'Device'
vuex_stationValue: lifeData.vuex_stationValue ? lifeData.vuex_stationValue : '',
vuex_inverterFlag: lifeData.vuex_inverterFlag ? lifeData.vuex_inverterFlag : 0,
tabbarList: [{
"icon": "warning",
"text": "告警",
'name': 'Alarm'
},
// {
// "icon": "order",
// "text": "设备",
// 'name': 'Device'
// },
{
"icon": "moments",
"text": "数据",
'name': 'Data'
},
{
"icon": "attach",
"text": "收益",
'name': 'Earnings'
},
{
"icon": "attach",
"text": "策略",
'name': 'Policy'
},
{
"icon": "account",
"text": "我的",
'name': 'My'
},
// },
{
"icon": "moments",
"text": "数据",
'name': 'Data'
},
{
"icon": "attach",
"text": "收益",
'name': 'Earnings'
},
{
"icon": "attach",
"text": "策略",
'name': 'Policy'
},
{
"icon": "account",
"text": "我的",
'name': 'My'
},
],
vuex_language:"en_US",
vuex_language: "en_US",
// 如果vuex_version无需保存到本地永久存储无需lifeData.vuex_version方式
vuex_config: config,
vuex_currentComponent:'Data'
vuex_currentComponent: 'Data'
},
mutations: {
$uStore(state, payload) {
@ -97,9 +97,9 @@ const store = new Vuex.Store({
let nameArr = payload.name.split('.');
let saveKey = '';
let len = nameArr.length;
if(len >= 2) {
if (len >= 2) {
let obj = state[nameArr[0]];
for(let i = 1; i < len - 1; i ++) {
for (let i = 1; i < len - 1; i++) {
obj = obj[nameArr[i]];
}
obj[nameArr[len - 1]] = payload.value;
@ -115,4 +115,4 @@ const store = new Vuex.Store({
}
})
export default store
export default store

View File

@ -28,7 +28,7 @@
// 默认箭头显示样式
.right {
position: absolute;
// position: absolute;
text-align: center;
width: 80rpx;
right: 30rpx;

View File

@ -1,6 +1,6 @@
<template>
<view class="container-list-item" >
<view class="content" @click="clickItem($event, item)">
<view class="content" @click="clickItem($event, item)" style="justify-content: space-between;">
<!-- 复选框 -->
<view class="checkbox" v-if="isCheckBox" @click.stop="clickBox($event , item)">
<i v-if="curChecked " :style="{'color' :checkActiveColor}"