174 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			174 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <div class="wrapper-xs">
 | |
|     <form id="dialog-{{$search['query']['id']}}-search-form" class="form-inline" method="get">
 | |
|         @include('searchForm6')
 | |
|     </form>
 | |
| </div>
 | |
| 
 | |
| <div id="dialog-{{$search['query']['id']}}" class="ag-theme-balham" style="width:100%;height:200px;"></div>
 | |
| <div class="m-t-xs">
 | |
|     <div id="promotion_customer_order_data" class="ag-theme-balham" style="width:100%;height:240px;"></div>
 | |
| </div>
 | |
| 
 | |
| <div class="clearfix"></div>
 | |
| 
 | |
| <script>
 | |
| var $promotion_customer_order = null;
 | |
| var $promotion_customer_order_data = null;
 | |
| (function ($) {
 | |
|     var search = JSON.parse('{{json_encode($search)}}');
 | |
|     var params = search.query;
 | |
| 
 | |
|     var option = gdoo.formKey(params);
 | |
|     var event = gdoo.event.get(option.key);
 | |
|     event.trigger('query', params);
 | |
| 
 | |
|     var sid = params.prefix == 1 ? 'sid' : 'id';
 | |
|     var multiple = params.multi == 0 ? false : true;
 | |
|     var mGrid = new agGridOptions();
 | |
| 
 | |
|     params['master'] = 1;
 | |
|     mGrid.remoteDataUrl = '{{url()}}';
 | |
|     mGrid.remoteParams = params;
 | |
|     mGrid.rowSelection = multiple ? 'multiple' : 'single';
 | |
|     mGrid.suppressRowClickSelection = true;
 | |
|     mGrid.columnDefs = [
 | |
|         {suppressMenu: true, cellClass:'text-center', checkboxSelection: true, headerCheckboxSelection: multiple, suppressSizeToFit: true, sortable: false, width: 40},
 | |
|         {suppressMenu: true, cellClass:'text-center', field: 'sn', headerName: '单据编号', minWidth: 160},
 | |
|         {suppressMenu: true, cellClass:'text-center', sortable: false, type: 'datetime', field: 'created_at', headerName: '单据日期', width: 140},
 | |
|         {suppressMenu: true, cellClass:'text-center', field: 'customer_code', headerName: '客户编号', width: 120},
 | |
|         {suppressMenu: true, cellClass:'text-left', field: 'customer_name', headerName: '客户名称', width: 220},
 | |
|         {suppressMenu: true, cellClass:'text-right', field: 'total_money', headerName: '订单金额', width: 120},
 | |
|         {suppressMenu: true, cellClass:'text-center', field: 'id', headerName: 'ID', width: 80}
 | |
|     ];
 | |
| 
 | |
|     mGrid.onRowClicked = function(row) {
 | |
|         var selected = row.node.isSelected();
 | |
|         if (selected === false) {
 | |
|             row.node.setSelected(true, true);
 | |
|         }
 | |
|         var rows = mGrid.api.getSelectedRows();
 | |
|         var ids = [];
 | |
|         for (let i = 0; i < rows.length; i++) {
 | |
|             ids.push(rows[i].id);
 | |
|         }
 | |
|         params.ids = ids;
 | |
|         sGrid.remoteData(params);
 | |
|     };
 | |
| 
 | |
|     mGrid.onRowDoubleClicked = function (row) {
 | |
|         var ret = writeSelected();
 | |
|         if (ret == true) {
 | |
|             $('#gdoo-dialog-' + params.dialog_index).dialog('close');
 | |
|         }
 | |
|     };
 | |
| 
 | |
|     /**
 | |
|      * 初始化选择
 | |
|      */
 | |
|     function initSelected() {
 | |
|         if (params.is_grid) {
 | |
|         } else {
 | |
|             var rows = {};
 | |
|             var id = $('#'+option.id).val();
 | |
|             if (id) {
 | |
|                 var ids = id.split(',');
 | |
|                 for (var i = 0; i < ids.length; i++) {
 | |
|                     rows[ids[i]] = ids[i];
 | |
|                 }
 | |
|             }
 | |
|             mGrid.api.forEachNode(function(node) {
 | |
|                 var key = node.data[sid];
 | |
|                 if (rows[key] != undefined) {
 | |
|                     node.setSelected(true);
 | |
|                 }
 | |
|             });
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 写入选中
 | |
|      */
 | |
|     function writeSelected() {
 | |
|         var rows = mGrid.api.getSelectedRows();
 | |
|         if (params.is_grid) {
 | |
|             var list = gdoo.forms[params.form_id];
 | |
|             list.api.dialogSelected(params);
 | |
|         } else {
 | |
|             var id = [];
 | |
|             var text = [];
 | |
|             $.each(rows, function(k, row) {
 | |
|                 id.push(row[sid]);
 | |
|                 text.push(row.name);
 | |
|             });
 | |
|             $('#'+option.id).val(id.join(','));
 | |
|             $('#'+option.id+'_text').val(text.join(','));
 | |
| 
 | |
|             if (event.exist('onSelect')) {
 | |
|                 return event.trigger('onSelect', multiple ? rows : rows[0]);
 | |
|             }
 | |
|         }
 | |
|         return true;
 | |
|     }
 | |
|     mGrid.writeSelected = writeSelected;
 | |
|     gdoo.dialogs[option.id] = mGrid;
 | |
| 
 | |
|     var gridDiv = document.querySelector("#dialog-{{$search['query']['id']}}");
 | |
|     new agGrid.Grid(gridDiv, mGrid);
 | |
|     // 读取数据
 | |
|     mGrid.remoteData();
 | |
|     // 数据载入成功
 | |
|     mGrid.remoteSuccessed = function() {
 | |
|         initSelected();
 | |
|     }
 | |
| 
 | |
|     params['master'] = 0;
 | |
|     var sGridDiv = document.querySelector("#promotion_customer_order_data");
 | |
|     var sGrid = new agGridOptions();
 | |
|     sGrid.remoteDataUrl = '{{url()}}';
 | |
|     sGrid.remoteParams = params;
 | |
|     sGrid.rowMultiSelectWithClick = true;
 | |
|     sGrid.rowSelection = 'multiple';
 | |
|     sGrid.autoColumnsToFit = false;
 | |
|     sGrid.defaultColDef.suppressMenu = true;
 | |
|     sGrid.defaultColDef.sortable = false;
 | |
|     sGrid.getRowClass = function(params) {
 | |
|         var data = params.data;
 | |
|         params.node.setSelected(true);
 | |
|     };
 | |
|     sGrid.columnDefs = [
 | |
|         {cellClass:'text-center', checkboxSelection: true, headerCheckboxSelection: true, suppressSizeToFit: true, width: 40},
 | |
|         {cellClass:'text-center', field: 'product_code', headerName: '存货编码', width: 100},
 | |
|         {field: 'product_name', headerName: '商品名称', minWidth: 180},
 | |
|         {cellClass:'text-center', field: 'product_spec', headerName: '商品规格', width: 140},
 | |
|         {cellClass:'text-center', field: 'product_barcode', headerName: '商品条码', width: 100},
 | |
|         {cellClass:'text-center', field: 'product_unit', headerName: '计量单位', width: 80},
 | |
|         {cellClass:'text-right', field: 'quantity', headerName: '数量', width: 80},
 | |
|         {cellClass:'text-right', field: 'price', headerName: '单价(元)', width: 80},
 | |
|         {cellClass:'text-right', field: 'money', headerName: '金额(元)', width: 80},
 | |
|         {cellClass:'text-center', field: 'id', headerName: 'ID', width: 60}
 | |
|     ];
 | |
|     new agGrid.Grid(sGridDiv, sGrid);
 | |
|     // 读取数据
 | |
|     sGrid.remoteData();
 | |
|     $promotion_customer_order_data = sGrid;
 | |
| 
 | |
|     var data = search.forms;
 | |
|     var search = $("#dialog-{{$search['query']['id']}}-search-form").searchForm({
 | |
|         data: data,
 | |
|         init: function(e) {}
 | |
|     });
 | |
|     search.find('#search-submit').on('click', function() {
 | |
|         var query = search.serializeArray();
 | |
|         $.map(query, function(row) {
 | |
|             params[row.name] = row.value;
 | |
|         });
 | |
|         params['master'] = 1;
 | |
|         mGrid.remoteData(params);
 | |
| 
 | |
|         params['master'] = 0;
 | |
|         sGrid.remoteData(params);
 | |
|         return false;
 | |
|     });
 | |
| 
 | |
| })(jQuery);
 | |
| </script> |