YUI datable Фильтрация данных на стороне клиента с раскрывающимся списком HTML - PullRequest
0 голосов
/ 05 ноября 2011

Я использую YUI с возможностью фильтрации данных на стороне клиента с раскрывающимся списком HTML (варианты: AAA, BBB, CCC).Это корректная фильтрация, когда я изменяю / выбираю опцию раскрывающегося списка (Пример AAA), когда я загружаю таблицу данных YUI в первый раз с помощью gAllReminderCallsArray, но не фильтрует вообще, когда я перезагружаю таблицу данных YUI с обновленным gAllReminderCallsArray с тем же значением, выбранным в раскрывающемся меню (AAA).

YAHOO.example.ReminderCallsTable = function() 
                {               
                    MyDataSource = new YAHOO.util.DataSource(gAllReminderCallsArray,{
                        responseType : YAHOO.util.DataSource.TYPE_JSARRAY,
                        responseSchema : {fields : ["OpportunityID","button","ReminderCallOutcome","SchedulingAssistant"]}
                        ,doBeforeCallback : function (req,raw,res,cb) {
                            // This is the filter function
                            var data = res.results || [],
                            filtered = [],
                            i,l;

                            if (req) {
                            req = req.toLowerCase();
                            for (i = 0, l = data.length; i < l; ++i) {
                                if (!data[i].SchedulingAssistant.toLowerCase().indexOf(req)) {
                                    filtered.push(data[i]);
                                }
                            }
                            res.results = filtered;
                            }

                            return res;
                        }
                    });

                    var MyColumnDefs = [            
                        {key:"OpportunityID", label: "Opportunity ID"},                                                                                  
                        {key:"button", label:"Update/Show", formatter:YAHOO.widget.DataTable.formatButton}, 
                        {key:"ReminderCallOutcome", label: "Outcome",sortable:true,formatter:YAHOO.widget.DataTable.formatImage},  
                        {key:"SchedulingAssistant", label: "CSR",sortable:true}
                        ];  

                    var MyConfigs = {paginator : new YAHOO.widget.Paginator({rowsPerPage: 20})};                            
                    var MyDataTable = new YAHOO.widget.DataTable("ReminderCallsTable", MyColumnDefs, MyDataSource,MyConfigs); 

                    filterTimeout = null;
                    updateFilter  = function () {
                        // Reset timeout
                        filterTimeout = null;                           

                        // Get filtered data
                        MyDataSource.sendRequest(YAHOO.util.Dom.get('ServiceCoordinator').value,{
                        success : MyDataTable.onDataReturnInitializeTable,
                        failure : MyDataTable.onDataReturnInitializeTable,
                        scope   : MyDataTable,
                        argument: state
                        });
                    };

                    YAHOO.util.Event.on('ServiceCoordinator','change',function (e) {                       
                        clearTimeout(filterTimeout);
                        setTimeout(updateFilter,600);
                    });                                       

                    MyDataTable.subscribe("rowMouseoverEvent", MyDataTable.onEventHighlightRow); 
                    MyDataTable.subscribe("rowMouseoutEvent", MyDataTable.onEventUnhighlightRow); 
                    MyDataTable.subscribe("rowClickEvent",MyDataTable.onEventSelectRow);                        
                    gAllRecords = MyDataTable;                              

                    MyDataTable.subscribe("buttonClickEvent", function(oArgs){                   
                    var oRecord = this.getRecord(oArgs.target);                             
                    gSelectedObjectID = oRecord.getData('EventID');                                                     
                    var CurrentInfo = oRecord.getData("ClaimantName") + " - " +  oRecord.getData("Type");               
                    SelectedReminderCallCurrentOutcome(gSelectedObjectID,CurrentInfo);                                                                              
                    });                         

                    return {
                    oDS: MyDataSource,
                    oDT: MyDataTable
                    };
                }();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...