Пример #1
0
        /// <summary>
        /// 根据部门ID得到进出库信息
        /// </summary>
        public dynamic Load(string username, int orgId, int pageindex, int pagesize)
        {
            _authoriseService.GetUserAccessed(username);
            if (_authoriseService.Orgs.Count == 0) //用户没有任何可见机构
            {
                return(new
                {
                    total = 0,
                    pageCurrent = pageindex
                });
            }

            var orgIds = _authoriseService.Orgs.Select(u => u.Id).ToArray(); //用户可访问的机构ID

            var orgs = _orgRepository.GetSubWithOwn(orgId)                   //点击的节点与用户可访问的机构合并
                       .Where(u => orgIds.Contains(u.Id))
                       .Select(u => u.Id).ToArray();

            var keys = _authoriseService.Resources.Select(r => r.Key);    //用户可访问的资源的KEY列表

            //由于库存Stock表开始没有设计资源有关的字段,暂时用User字段代替
            Expression <Func <Stock, bool> > exp = u => orgs.Contains(u.OrgId) && (u.User == "" || keys.Contains(u.User));
            var stocks = _repository.Find(pageindex, pagesize, "", exp);
            int total  = _repository.GetCount(exp);


            return(new
            {
                total = total,
                list = stocks,
                pageCurrent = pageindex
            });
        }