V-Tiger 6如何制作具有数据库值的选择列表

时间:2016-05-16 09:55:35

标签: vtiger picklist vtigercrm

我是非常新的V-Tiger CRM。我想要实现的是。我在创建供应商表单中有一个自定义选项列表。我知道我可以通过添加PickList值来填充它。但我想从我的自定义数据库表中获取国籍。 我的国籍表看起来像(nationality_id nationality_name)。我需要在我的vendore创建表单中将这些值提取到自定义选项列表

1 个答案:

答案 0 :(得分:0)

您可以使用自定义功能实现以下目标:

  1. 打开modules\Vendors\views\Edit.php
  2. process函数中添加以下代码:

    $sql_get = 'SELECT * FROM nationality_table_name'; 
    $sql_get_result =  $adb->query($sql_get); 
    for($i=0;$i<$adb->num_rows($sql_get_result);$i++){
        $nationality[$i]['code'] = $adb->query_result($sql_get_result,$i,'nationality_id'); 
        $nationality[$i]['name'] = $adb->query_result($sql_get_result,$i,'nationality_name'); 
    }    
    $viewer->assign('nationality', $nationality);    
    parent::process($request);
    

    2:在给定位置创建新文件

      

    \布局\ vlayout \模块\厂商\ uitypes \ Picklist.tpl

    {strip}
    {assign var="FIELD_INFO" value=Zend_Json::encode($FIELD_MODEL->getFieldInfo())}
    {assign var=PICKLIST_VALUES value=$FIELD_MODEL->getPicklistValues()}
    {assign var="SPECIAL_VALIDATOR" value=$FIELD_MODEL->getValidator()}
    {assign var=FIELD_NAME value=$FIELD_MODEL->getFieldName()}
    
    {assign var=FIELD_NAME value=$FIELD_MODEL->getFieldName()}
    
    {if $FIELD_NAME eq 'nationality_dropdown_name'}
    <select class="chzn-select {if $OCCUPY_COMPLETE_WIDTH} row-fluid {/if}" name="{$FIELD_NAME}" data-validation-engine="validate[{if $FIELD_MODEL->isMandatory() eq true} required,{/if}funcCall[Vtiger_Base_Validator_Js.invokeValidation]]" data-fieldinfo='{$FIELD_INFO|escape}' {if !empty($SPECIAL_VALIDATOR)}data-validator='{Zend_Json::encode($SPECIAL_VALIDATOR)}'{/if} data-selected-value='{$FIELD_MODEL->get('fieldvalue')}'>
     {if $FIELD_MODEL->isEmptyPicklistOptionAllowed()}<option value="">{vtranslate('LBL_SELECT_OPTION','Vtiger')}</option>{/if}
     {foreach item=PICKLIST_VALUE key=PICKLIST_NAME from=$nationality}
                <option value="{$PICKLIST_VALUE['code']}" {if trim(decode_html($FIELD_MODEL->get('fieldvalue'))) eq trim($PICKLIST_VALUE['code'])} selected {/if}>{$PICKLIST_VALUE['name']}</option>
     {/foreach}
     </select>
     {/if}     
    {/strip}
    

    请根据您的字段名称和测试更新代码。干杯!!