zhengyiming
4 天以前 be028017a461af4c9745c69c4df084d4c3e6b296
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
/*
 * @Author: 秦少卫
 * @Date: 2024-05-29 15:39:20
 * @LastEditors: 秦少卫
 * @LastEditTime: 2024-06-09 16:52:59
 * @Description: 通用分页
 */
 
import qs from 'qs';
import { ref } from 'vue';
 
const APIHOST = import.meta.env.APP_APIHOST;
export default function usePageList({
  el,
  apiClient,
  filters = {},
  sort = [],
  formatData,
  fields = [],
}) {
  //  滚动条根据页面适应
  const showScroll = ref(false);
  const scrollHeight = ref(0);
  const startPage = async () => {
    // 滚动
    const myTemplBox = document.querySelector(el);
    scrollHeight.value = myTemplBox.offsetHeight;
    showScroll.value = true;
 
    await startGetList();
  };
 
  // 素材列表
  const pageData = ref([]);
  const page = ref(1);
  const pagination = reactive({
    page: 0,
    pageCount: 0,
    pageSize: 10,
    total: 0,
  });
 
  // 是否到达底部
  const isDownBottom = computed(() => {
    return pagination.page === page.value && pagination.page >= pagination.pageCount;
  });
 
  const pageLoading = ref(false);
  const getPageData = async () => {
    pageLoading.value = true;
    try {
      const query = {
        populate: {
          img: '*',
        },
        filters: {},
        sort: sort,
        fields,
        pagination: {
          page: page.value,
          pageSize: page.value.pageSize,
        },
      };
      const params = addFilterParams(query, filters);
      const res = await apiClient(qs.stringify(params));
      const list = formatData ? formatData(res.data.data) : res.data.data;
      Object.keys(res.data.meta.pagination).forEach((key) => {
        pagination[key] = res.data.meta.pagination[key];
      });
      pageData.value = [...pageData.value, ...list];
    } catch (error) {
      console.log(error);
    }
    // Spin.hide();
    pageLoading.value = false;
  };
 
  const startGetList = () => {
    pageData.value = [];
    page.value = 1;
    getPageData();
  };
 
  const nextPage = () => {
    if (page.value >= pagination.pageCount) return;
    page.value++;
    setTimeout(() => {
      getPageData();
    }, 1000);
  };
 
  const addFilterParams = (query, filters) => {
    Object.keys(filters).forEach((key) => {
      const itemFilter = {};
      Object.keys(filters[key]).forEach((myKey) => {
        const skip = ['$eq', '$contains'];
        const isNone = !filters[key][myKey];
        const isSkip = skip.includes(myKey) && isNone;
        // 不好包含跳过条件
        if (!isSkip) {
          itemFilter[myKey] = filters[key][myKey];
        } else {
          // 跳过条件下 判断是否过滤 默认过滤
          const isFilterEmpty = filters[key].filterEmpty;
          if (!isFilterEmpty) {
            itemFilter[myKey] = filters[key][myKey];
          }
        }
      });
      query.filters[key] = itemFilter;
    });
    return query;
  };
 
  return {
    pageData, // 分页数据
    showScroll,
    scrollHeight,
    pageLoading,
    isDownBottom, // 是否到达底部
    startPage, // 开始分页
    getPageData, // 获取分页数据
    startGetList, // 从第一个开始
    nextPage, // 下一页
  };
}
 
const getMaterialInfoUrl = (info) => {
  const imgUrl = info?.data?.attributes?.url || '';
  return APIHOST + imgUrl;
};
 
const getMaterialPreviewUrl = (info) => {
  const imgUrl = info?.data?.attributes?.formats?.small?.url || info?.data?.attributes?.url || '';
  return APIHOST + imgUrl;
};
 
export { getMaterialInfoUrl, getMaterialPreviewUrl };