prj_chance_modify.lview 10.1 KB
Newer Older
Spencer Chang's avatar
Spencer Chang committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180
<?xml version="1.0" encoding="UTF-8"?>
<!--
    $Author: zhangxing5129  
    $Date: 2014-7-30 下午04:25:31  
    $Revision: 1.0  
    $Purpose: 商机维护动态页面
-->
<a:screen xmlns:a="http://www.leaf-framework.org/application" customizationEnabled="true" dynamiccreateenabled="true" trace="true">
    <a:view>
        <a:link id="hls_fin_doc_quotation_link_id" url="${/request/@context_path}/modules/hls/HLS500/hls_fin_doc_quotation.lsc"/>
        <a:link id="hls_fin_calculator_update_link_id" url="${/request/@context_path}/modules/hls/HLS500N/hls_fin_calculator_update_n.lview"/>
        <a:link id="hls_fin_calc_quotation_header_link_id" url="${/request/@context_path}/modules/hls/HLS500/hls_fin_calc_quotation_header.lview"/>
        <a:link id="prj_chance_print_intention_print_link_id" url="${/request/@context_path}/modules/prj/PRJ401/prj_chance_print_intention_detail.lview"/>
        <script type="text/javascript"><![CDATA[
            function open_quote_win(ds_id, record_id, name) {
                var head_ds_id = get_dsid_by_basetable(window['${/parameter/@layout_code}_layoutDataSetList'], 'prj_chance');
                var base_ds = $(ds_id);
                var record = base_ds.findById(record_id);
            
                var head_ds = $(head_ds_id);
                var head_record = head_ds.getAt(0);
                var parent_base_table_pk = 'chance_id';
                var url;
            
            
                if ('${/parameter/@calc_type}' == 'LITE_CALCULATOR') {
                    url = $('hls_fin_calc_quotation_header_link_id').getUrl();
                } else if ('${/parameter/@calc_type}' == 'CLASSIC_CALCULATOR') {
                    url = $('hls_fin_calculator_update_link_id').getUrl();
                } else {
                    Leaf.showMessage('${l:PROMPT}', '${l:HLS.CALC_TYPE_IS_NULL}');
                    return;
                }
                if (head_record.dirty == true) {
                    Leaf.showMessage('${l:PROMPT}', '${l:HLS.EXECUTE_AFTER_SAVE}');
                    return;
                }
                if (base_ds.validate()) {
                    if (!record.get('price_list') || !record.get('currency') || !record.get('lease_times')) {
                        Leaf.showMessage('${l:PROMPT}', '${l:HLS.QUOTATION_EXECUTE_AFTER_SAVE}');
                        return;
                    }
            
                    window['${/parameter/@layout_code}_lock_layout_dynamic_window'];
            
                    var parent_pk_value = head_record.get(parent_base_table_pk);
                    record.set('function_code', '${/parameter/@function_code}');
                    record.set('function_usage', '${/parameter/@function_usage}');
                    record.set(parent_base_table_pk, parent_pk_value);
                    record.set('to_doc_table', 'HLS_FIN_CALCULATOR_HD');
                    var calc_recreate_L_formula;
                    if (record.get('quotation_id') && !record.get('calc_session_id')) {
                        calc_recreate_L_formula = 'Y';
                        record.set('_status', 'update');
                    } else if (record.get('quotation_id') && record.get('calc_session_id')) {
                        calc_recreate_L_formula = 'N';
                        record.set('_status', 'execute');
                    } else {
                        calc_recreate_L_formula = 'Y';
                        record.set('_status', 'insert');
                    }
                    if ('${/parameter/@document_category}' == 'CHANCE') {
                        record.set('from_doc_table', 'PRJ_QUOTATION');
                        record.set('from_doc_pk', record.get('quotation_id'));
                        record.set('calculate_flag', 'N');
                    } else if ('${/parameter/@document_category}' == 'CONTRACT') {
                        record.set('from_doc_table', 'CON_CONTRACT');
                        record.set('from_doc_pk', parent_pk_value);
                        record.set('calculate_flag', 'N');
                    }
                    if (!'${/parameter/@document_id}') {
                        record.set('document_id', parent_pk_value);
                    }
                    var saveData = [];
                    saveData.push(record.data);
                    Leaf.request({
                        url: $('hls_fin_doc_quotation_link_id').getUrl(),
                        para: saveData,
                        success: function(res) {
                            window['${/parameter/@layout_code}_unlock_layout_dynamic_window'];
                            base_ds.query();
                            var quotation_id = record.get('quotation_id') || res.result.quotation_id;
                            new Leaf.Window({
                                id: 'hls_fin_calc_quotation_link_winid',
                                params: {
                                    document_id: parent_pk_value,
                                    document_category: '${/parameter/@document_category}',
                                    maintain_type: '${/parameter/@maintain_type}',
                                    calc_session_id: res.result.record.calc_session_id,
                                    quotation_id: quotation_id,
                                    dsId: ds_id,
                                    winId: 'hls_fin_calc_quotation_link_winid',
                                    global_flag: 'Y',
                                    id_num: 0,
                                    calc_type: '${/parameter/@calc_type}',
                                    recreate_L_formula: calc_recreate_L_formula
                                },
                                url: url,
                                fullScreen: true,
                                draggable: true
                            });
                        },
                        failure: function() {
                            window['${/parameter/@layout_code}_unlock_layout_dynamic_window'];
                        },
                        error: function() {
                            window['${/parameter/@layout_code}_unlock_layout_dynamic_window'];
                        },
                        scope: this
                    });
                }
            };
            
            
            //超链接渲染
            window['${/parameter/@layout_code}_dynamic_link_renderer'] = function(value, record, name, config_record) {
                //报价超链接
                if (!record.isNew && name == 'quote') {
                    return '<a href="javascript:open_quote_win(\'' + record.ds.id + '\',\'' + record.id + '\',\'' + name + '\')">' + config_record.get('prompt') + '</a>';
                } else {
                    return '';
                }
            };
            
            function print_chance_intention(ds_id, record_id, name) {
                var record = $(ds_id).findById(record_id),
                    url = $('prj_chance_print_intention_print_link_id').getUrl();
                if (!record.get('calc_session_id')) {
                    Leaf.showMessage('${l:PROMPT}', '${l:CON500.QUOTATION_NEED_UPDATE}');
                    return;
                }
                var form = document.createElement("form");
                form.target = "prj_intention_word_export_window";
                form.method = "post";
                form.action = url + '?quotation_id=' + record.get('quotation_id');
                var iframe = Ext.get('prj_intention_word_export_window') || new Ext.Template('<iframe id ="prj_intention_word_export_window" name="prj_intention_word_export_window" style="position:absolute;left:-10000px;top:-10000px;width:1px;height:1px;display:none"></iframe>').insertFirst(document.body, {}, true);
                document.body.appendChild(form);
                form.submit();
                Ext.fly(form).remove();
            }
            
            //打印租赁意向书
            window['${/parameter/@layout_code}_dynamic_button_renderer'] = function(value, record, name, config_record) {
                if (name == 'print_intention') {
                    if (Ext.isIE || Ext.isIE9 || Ext.isIE10) {
                        return '<button style="font-size:11px;height:22px;width:70%;text-align:center;padding:0 4px 4px 0" onclick="print_chance_intention(\'' + record.ds.id + '\',\'' + record.id + '\',\'' + name + '\');"><div style="height: 18px; line-height: 16px; text-decoration: none;">' + config_record.get('prompt') + '</div></button>';
                    } else {
                        return '<button style="font-size:11px;height:22px;width:70%;text-align:center;" onclick="print_chance_intention(\'' + record.ds.id + '\',\'' + record.id + '\',\'' + name + '\');">' + config_record.get('prompt') + '</button>';
                    }
                }
            };
            
            //新增报价
            window['${/parameter/@layout_code}_on_layout_dynamic_grid_add'] = function(ds, record, config_records) {
                var records = ds.getAll(),
                    version_num = 0;
                if (records.length) {
                    for (var i = 0;i < records.length;i++) {
                        var current_record = records[i],
                            version = current_record.get('version');
                        if (!Ext.isEmpty(version)) {
                            index = version.indexOf('v');
                            if (index == -1) {
                                version_num = version_num;
                            } else {
                                var current_version = version.substring(index + 1);
                                if (isNaN(current_version) || parseFloat(current_version) <= parseFloat(version_num)) {
                                    version_num = version_num;
                                } else {
                                    version_num = current_version;
                                }
                            }
                        }
                    }
                }
                record.set('version', 'v' + parseInt(plus(version_num, 1)).toFixed(1));
            };
        ]]></script>
    </a:view>
</a:screen>