- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何实现字段标签、帮助文本等的国际化支持。字段的标准乘法似乎不起作用例如文档中给出的用于创建联系表单的示例。我尝试为其他语言添加额外的字段(文档中描述的第一种方法)
from django.db import models
from wagtail.core.models import Page
from modelcluster.fields import ParentalKey
from wagtail.admin.edit_handlers import (
FieldPanel, FieldRowPanel,
InlinePanel, MultiFieldPanel
)
from wagtail.core.fields import RichTextField
from wagtail.contrib.forms.models import (
AbstractEmailForm, AbstractForm, AbstractFormField
)
from wagtail.contrib.forms.edit_handlers import FormSubmissionsPanel
from dimaplus.languages import TranslatedField
# Create your models here.
class FormField(AbstractFormField):
page = ParentalKey(
'FormPage',
on_delete=models.CASCADE,
related_name='form_fields',
)
label_fa = models.CharField(max_length=255)
label_ru = models.CharField(max_length=255)
label_ar = models.CharField(max_length=255)
tr_label_tag = TranslatedField(
'label',
'label_fa',
'label_ar',
'label_ru',
)
panels = AbstractFormField.panels + [
FieldPanel('label_fa'),
FieldPanel('label_ru'),
FieldPanel('label_ar'),
]
class FormPage(AbstractEmailForm, Page):
intro = RichTextField(blank=True)
intro_fa = RichTextField(blank=True)
intro_ar = RichTextField(blank=True)
intro_ru = RichTextField(blank=True)
thank_you_text = RichTextField(blank=True)
thank_you_text_fa = RichTextField(blank=True)
thank_you_text_ar = RichTextField(blank=True)
thank_you_text_ru = RichTextField(blank=True)
# 'body',
# 'body_fa',
# 'body_ar',
# 'body_ru',
tr_intro = TranslatedField(
'intro',
'intro_fa',
'intro_ar',
'intro_ru'
)
tr_thank_you_text = TranslatedField(
'thank_you_text',
'thank_you_text_fa',
'thank_you_text_ar',
'thank_you_text_ru'
)
content_panels = AbstractEmailForm.content_panels + [
FormSubmissionsPanel(),
FieldPanel('intro_fa', classname='full'),
InlinePanel('form_fields', label="Form fields"),
FieldPanel('thank_you_text_fa', classname="full"),
MultiFieldPanel([
FieldPanel('intro'),
FieldPanel('thank_you_text'),
FieldPanel('intro_ar'),
FieldPanel('thank_you_text_ar'),
FieldPanel('intro_ru'),
FieldPanel('thank_you_text_ru'),
]),
MultiFieldPanel([
FieldRowPanel([
FieldPanel('from_address', classname="col6"),
FieldPanel('to_address', classname="col6"),
]),
FieldPanel('subject'),
], "Email"),
]
'TranslatedField' 类在文档中简单给出:
from django.utils import translation
from django.utils.translation import gettext_lazy as _
#translation class
class TranslatedField:
def __init__(self,
en_field,
fa_field,
ar_field,
ru_field):
self.en_field = en_field
self.fa_field = fa_field
self.ar_field = ar_field
self.ru_field = ru_field
def __get__(self, instance, owner):
lang = translation.get_language()
if lang == 'fa':
return getattr(instance, self.fa_field)
elif lang == 'ar':
return getattr(instance, self.ar_field)
elif lang == 'ru':
return getattr(instance, self.ru_field)
else:
return getattr(instance, self.en_field)
最佳答案
以防有人偶然发现这个。可以使用文档中的示例来执行此操作。您必须使用标签字段本身进行翻译,因为那是 wagtail 用来构建表单的字段。只需用翻译后的字段覆盖它即可。
class FormField(AbstractFormField):
label_en = models.CharField(max_length=250)
label_de = models.CharField(max_length=250)
label_fr = models.CharField(max_length=250)
label_ru = models.CharField(max_length=250)
label = TranslatedField(
'label_en',
'label_de',
'label_fr',
'label_ru'
)
# this is to remove the original label from the field panels
# you could also just copy the panels from the AbstractFormFieldClass
# wagtail will throw an error otherwise
AbstractFormField.panels.remove(next((x for x in AbstractFormField.panels if x.field_name == 'label'), None))
content_panels = AbstractFormField._panels + [
FieldPanel('label_en'),
FieldPanel('label_de'),
FieldPanel('label_fr'),
FieldPanel('label_ru'),
]
对于帮助文本字段,情况是一样的。这些是类使用的字段:
panels = [
FieldPanel('label'),
FieldPanel('help_text'),
FieldPanel('required'),
FieldPanel('field_type', classname="formbuilder-type"),
FieldPanel('choices', classname="formbuilder-choices"),
FieldPanel('default_value', classname="formbuilder-default"),
]
关于表单字段的 Wagtail 国际化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51297460/
我有一个 Java 字符串,但在处理时遇到了问题。我有一个字符串 s,它的值为丞(我随机选择的一个汉字,我不会说中文)。如果我打电话 String t = new String(s.getBytes(
在Qt中,所有的输入部件和文本绘制方式对Qt支持的所有语言都提供了内置的支持。Qt内置的字体引擎可以在同一时间正确而且精细地绘制不同的文本,这些文本可以包含来自众多不同书写系统的字符。如果想了解更多的
如何实现字段标签、帮助文本等的国际化支持。字段的标准乘法似乎不起作用例如文档中给出的用于创建联系表单的示例。我尝试为其他语言添加额外的字段(文档中描述的第一种方法) from django.db
是否有可能当我在操作类中使用“getText(”keyName”); 时,我可以指定仅从 ENGLISH 资源包中选择值。因为我只想将此值用于日志记录目的。 任何想法我怎么能做到这一点? BR 标准委
我有一些关于 GWT 的国际化解决方法的问题。 1) 处理直接写入 ui.xml 文件的静态文本的最佳方式是什么? 目前,我正在使用 Messages-Interface 来翻译 Java 生成的文本
我在 Symfony 2 中遇到了一个奇怪的翻译问题。 这是我的config.yml imports: - { resource: parameters.yml } - { resou
对于我的大部分应用程序,我可以使用 https://developers.google.com/web-toolkit/doc/latest/DevGuideI18n 中列出的推荐国际化技术。 (主要
我使用 Android Studio 创建了一个新的 Flutter 项目。我正在使用null-safety,并且正在物理设备上运行应用程序,但代码生成无法正常工作,没有flutter_gen.dar
这里是菜鸟。 我正在尝试对基于命令行的程序实现国际化。以下是 java 国际化路径中可用的内容。 import java.util.*; public class I18NSample { s
我使用 Android Studio 创建了一个新的 Flutter 项目。我正在使用null-safety,并且正在物理设备上运行应用程序,但代码生成无法正常工作,没有flutter_gen.dar
我正在开发一个需要多语言的应用程序。 我正在尝试关注 this国际化教程。但是,当我尝试“使用基本国际化”时, View 中没有列出我的 Storyboard。 我正在使用 XCode 4.6.3 我
我住在印度(有超过20种语言)我正在尝试在网站中实现java国际化。 但是在 Locale.getAvailableLocales() 中,本地语言不可用。我的情况是否可以实现国际化? 如果可能的话字
我有以下 SDN 4 实体: 决策、特征和值: @NodeEntity public class Value { private final static String SET_FOR = "
关于MySql,是否有支持所有或绝大多数语言的字符集? 最佳答案 统一码。它有几种编码:UTF-8、UTF-16 和 UTF-32。 来自 http://en.wikipedia.org/wiki/U
我目前正在使用 Vuepress。但是我想要在我的 Vuepress 站点中使用多种语言。经过 3 天的挣扎,我决定把我的问题放在这里。 (是的,我查看了 Vuepress 文档:https://vu
我需要返回一个 strftime() 调用,该调用使用与我本地机器/操作系统上设置的语言不同的语言。是否可以选择返回语言? 最佳答案 对于可靠的 i18n/L10N,可由必须在同一运行中提供不同本地化
我有一些按钮,按下它们后我想播放一些音频。按钮的名称是音频文件的名称 private func playAudio(title : String){ audioPlayer = AVAudio
如何更改 HTML5 的消息(或者它会根据浏览器的语言自动更改?) 例如: E-mail: 当我在 Opera 运行此代码(来自 W3schools)
我发现很多关于 url schemes 的话题,最常见的是: www.mysite.com/fr/products www.mysite.com/en/products www.mysite.com/
在 Android WebView 中处理国际化/本地化的最佳方式是什么。理想情况下,我想访问以下位置的所有字符串资源: res/values/strings.xmlres/values-de/str
我是一名优秀的程序员,十分优秀!