public questStatus List(QueryOptions queryOptions, out FiltersListViewModel filtersListViewModel)
        {
            // Initialize
            questStatus status = null;

            filtersListViewModel = null;


            // List
            QueryResponse queryResponse = null;
            List <Quest.Functional.Logging.FilterLog> filterLogList = null;
            FilterLogsMgr filterLogsMgr = new FilterLogsMgr(this.UserSession);

            status = filterLogsMgr.List(queryOptions, out filterLogList, out queryResponse);
            if (!questStatusDef.IsSuccess(status))
            {
                return(status);
            }

            // Sort
            filterLogList.Sort(delegate(Quest.Functional.Logging.FilterLog i1, Quest.Functional.Logging.FilterLog i2) { return(i2.Created.CompareTo(i1.Created)); });


            // Transfer model.
            // TODO: USE BaseListModeler to xfer queryOptions to QueryOptionsViewModel.
            filtersListViewModel = new FiltersListViewModel(this.UserSession);
            QueryResponseViewModel queryResponseViewModel = null;

            status = TransferQueryResponse(queryResponse, out queryResponseViewModel);
            if (!questStatusDef.IsSuccess(status))
            {
                return(status);
            }
            filtersListViewModel.QueryResponse = queryResponseViewModel;
            foreach (Quest.Functional.Logging.FilterLog filterLog in filterLogList)
            {
                FilterLineItemViewModel filterLineItemViewModel = new FilterLineItemViewModel();
                BufferMgr.TransferBuffer(filterLog, filterLineItemViewModel);
                filtersListViewModel.Items.Add(filterLineItemViewModel);
            }
            return(new questStatus(Severity.Success));
        }
        public questStatus Page(out FiltersListViewModel filtersListViewModel)
        {
            // Initialize
            questStatus status = null;

            filtersListViewModel = null;


            // Set up query options.
            // TEMPORARY: OPTIMIZE THIS
            List <SearchField> searchFieldList = new List <SearchField>();

            SearchOptions searchOptions = new SearchOptions();

            searchOptions.SearchFieldList = searchFieldList;

            QueryOptions queryOptions = new QueryOptions(100, 1);

            queryOptions.SearchOptions = searchOptions;
            QueryResponse queryResponse = null;


            // List
            List <Quest.Functional.Logging.FilterLog> filterLogList = null;
            FilterLogsMgr filterLogsMgr = new FilterLogsMgr(this.UserSession);

            status = filterLogsMgr.List(queryOptions, out filterLogList, out queryResponse);
            if (!questStatusDef.IsSuccess(status))
            {
                return(status);
            }

            // Transfer model.
            filtersListViewModel = new FiltersListViewModel(this.UserSession);
            foreach (Quest.Functional.Logging.FilterLog filterLog in filterLogList)
            {
                FilterLineItemViewModel filterLineItemViewModel = new FilterLineItemViewModel();
                BufferMgr.TransferBuffer(filterLog, filterLineItemViewModel);
                filtersListViewModel.Items.Add(filterLineItemViewModel);
            }
            return(new questStatus(Severity.Success));
        }