跳转至内容
  • 版块
  • 标签
  • 热门
  • 用户
  • 群组
皮肤
  • 浅色
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • 深色
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • 默认(Flatly)
  • 不使用皮肤
折叠

Odoo 中文社区

  1. 主页
  2. 版块
  3. Odoo 开发与实施交流
  4. OpenERP Login窗口显示资料库下拉的中文说明

OpenERP Login窗口显示资料库下拉的中文说明

已定时 已固定 已锁定 已移动 Odoo 开发与实施交流
4 帖子 3 发布者 6.0k 浏览 1 关注中
  • 从旧到新
  • 从新到旧
  • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • V 离线
    V 离线
    vnsoft
    发表于 最后由 编辑
    #1

    在OpenERP中,如果有建立多个资料库,则在登入时就会显示一下select清单,可以让用户选择登入的作业资料库。

    但目前下拉清单中显示的都是资料库的代号,对于有些使用者来讲,很难根据代号知道不同资料库的意义,所以如果能显示中文说明则是最好了。

    经过一些调试,通过更改两个位置的脚本即可实现此功能。

    1.先修改python脚本中,取得资料库清单的部分,脚本在/usr/lib/pymodules/python2.7/openerp/addons/web/controllers/main.py中,编辑此脚本,搜索"db_list"字串,会看到有如下一段代码,红色部分是我加的,就是先定义一个字典变量,保存资料库代号和中文说明的定义,然后将dbs变量重新赋值:

    def get_list(self, req):
            proxy = req.session.proxy("db")
            dbs = proxy.list()
            h = req.httprequest.environ['HTTP_HOST'].split(':')[0]
            d = h.split('.')[0]
            r = req.config.dbfilter.replace('%h', h).replace('%d', d)
            dbs = [i for i in dbs if re.match(r, i)]
            [color=red]dbdic={'erpdb':'Db for ERP','testdb':'Db for Test'}
            dbs=[(d,dbdic[d]) if dbdic.has_key(d) else (d,d)  for d in dbs][/color]
            return {"db_list": dbs}

    2.原来的dbs值是一个简单的列表,经过上述更改后,列表中的元素变成了包含代号和中文说明的元组,所以前端的xml部分也要作些修改,

      xml的脚本是在 /usr/lib/pymodules/python2.7/openerp/addons/web/static/src/xml/base.xml 中,编辑此文件,搜索"db_list"字串,会找到其中一段代码如下,红色内容是我增加的,因为原来db变量只是一个字串,现在变成了一个元组,所以要通过下标来设定其值,另外还有两处是dropdb和backupdb部分有关<option>节点的值也要修改,不然删除和备份时就不能显示正确的资料库:

    <t t-name="Login_dblist">
        <select name="db">
            <t t-foreach="db_list" t-as="db">
                <t t-if="selected_db === db[color=red][0][/color]">
                    <option t-att-value="db[color=red][0][/color]" selected="true">
                            <t t-esc="db[color=red][1][/color]"/>
                    </option>
                </t>
                <t t-if="selected_db !== db[color=red][0][/color]">
                    <option t-att-value="db[color=red][0][/color]"><t t-esc="db[color=red][1][/color]"/></option>
                </t>
            </t>
        </select>
    </t>
    3.上述修改保存后重新启动openerp服务即可。上述环境是在Ubuntu12.04+OpenERP6.1修改,openerp7.0还没有测试,有兴趣的话大家可以试试。

    1 条回复 最后回复
    0
    • M 离线
      M 离线
      mrshelly
      发表于 最后由 编辑
      #2

      不错.... 赞... 要是给贴子再加些适当的 Tag 就更棒了...

      1 条回复 最后回复
      0
      • C 离线
        C 离线
        ccdos
        发表于 最后由 编辑
        #3

        这段python最好是从配制文件读取说明信息。或者从数据库中取得说明信息

        1 条回复 最后回复
        0

        你好!看起来您对这段对话很感兴趣,但您还没有一个账号。

        厌倦了每次访问都刷到同样的帖子?您注册账号后,您每次返回时都能精准定位到您上次浏览的位置,并可选择接收新回复通知(通过邮件或推送通知)。您还能收藏书签、为帖子顶,向社区成员表达您的欣赏。

        有了你的建议,这篇帖子会更精彩哦 💗

        注册 登录
        回复
        • 在新帖中回复
        登录后回复
        • 从旧到新
        • 从新到旧
        • 最多赞同


        • 登录

        • 没有帐号? 注册

        • 登录或注册以进行搜索。
        • 第一个帖子
          最后一个帖子
        0
        • 版块
        • 标签
        • 热门
        • 用户
        • 群组