index.vue 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <template>
  2. <FlexCol :gap="20" :padding="20">
  3. <SearchBar placeholder="输入关键词搜索" />
  4. <FlexCol :radius="15" overflow="hidden">
  5. <ImageSwiper
  6. :height="200"
  7. :images="[
  8. 'https://mn.wenlvti.net/app_static/minnan/images/home/BackgroundBanner5.jpg',
  9. 'https://mn.wenlvti.net/app_static/minnan/images/home/BackgroundBanner4.jpg',
  10. 'https://mn.wenlvti.net/app_static/minnan/images/home/BackgroundBanner3.jpg',
  11. ]"
  12. />
  13. </FlexCol>
  14. <Box title="主题导览" icon="/static/images/home/icon-compass.png">
  15. <ProvideVar :vars="{
  16. GridItemIconSize: 70,
  17. GridItemBackgroundColor: 'transparent',
  18. GridItemPaddingHorizontal: 0,
  19. }">
  20. <Grid :borderGrid="false" :mainAxisCount="3">
  21. <GridItem title="全部" icon="/static/images/icons/icon-all.png" touchable />
  22. <GridItem title="拍摄标准" icon="/static/images/icons/icon-camera.png" touchable />
  23. <GridItem title="命名规则" icon="/static/images/icons/icon-rules.png" touchable />
  24. <GridItem title="文本规范" icon="/static/images/icons/icon-mark.png" touchable />
  25. <GridItem title="隐私授权" icon="/static/images/icons/icon-pac.png" touchable />
  26. <GridItem title="错误案例" icon="/static/images/icons/icon-route.png" touchable />
  27. </Grid>
  28. </ProvideVar>
  29. </Box>
  30. <Box title="最新" icon="/static/images/home/icon-shining.png" showMore @moreClicked="$emit('goDiscover')">
  31. <SimplePageContentLoader :loader="discoverLoader">
  32. <FlexCol :gap="20">
  33. <Touchable
  34. v-for="(item, i) in discoverLoader.content.value"
  35. :key="i"
  36. justify="space-between"
  37. align="center"
  38. direction="row"
  39. >
  40. <FlexCol flex="1" :gap="10">
  41. <Text :text="item.title" fontConfig="h5" />
  42. <Text :text="item.desc" fontConfig="subText" />
  43. <FlexRow :gap="10">
  44. <Tag v-for="tag in item.tags" :key="tag" :text="tag" size="small" type="primary" scheme="light" />
  45. </FlexRow>
  46. </FlexCol>
  47. <Width :width="25" />
  48. <Image
  49. :src="item.thumbnail || item.image"
  50. :width="120"
  51. :height="120"
  52. :radius="15"
  53. mode="aspectFill"
  54. round
  55. />
  56. </Touchable>
  57. </FlexCol>
  58. </SimplePageContentLoader>
  59. </Box>
  60. <Loadmore status="nomore" />
  61. <Height :height="150" />
  62. </FlexCol>
  63. </template>
  64. <script setup lang="ts">
  65. import Box from '@/common/components/parts/Box.vue';
  66. import ImageSwiper from '@/common/components/parts/ImageSwiper.vue';
  67. import SimplePageContentLoader from '@/common/components/SimplePageContentLoader.vue';
  68. import { useSimpleDataLoader } from '@/common/composeabe/SimpleDataLoader';
  69. import AppCofig from '@/common/config/AppCofig';
  70. import Image from '@/components/basic/Image.vue';
  71. import Text from '@/components/basic/Text.vue';
  72. import Loadmore from '@/components/display/loading/Loadmore.vue';
  73. import Tag from '@/components/display/Tag.vue';
  74. import Touchable from '@/components/feedback/Touchable.vue';
  75. import SearchBar from '@/components/form/SearchBar.vue';
  76. import FlexCol from '@/components/layout/FlexCol.vue';
  77. import FlexRow from '@/components/layout/FlexRow.vue';
  78. import Grid from '@/components/layout/grid/Grid.vue';
  79. import GridItem from '@/components/layout/grid/GridItem.vue';
  80. import Height from '@/components/layout/space/Height.vue';
  81. import Width from '@/components/layout/space/Width.vue';
  82. import ProvideVar from '@/components/theme/ProvideVar.vue';
  83. import { RandomUtils } from '@imengyu/imengyu-utils';
  84. function testImage() {
  85. return 'https://mncdn.wenlvti.net/app_static/minnan/images/home/ImageTest' + RandomUtils.genRandom(1, 5) +'.jpg';
  86. }
  87. const discoverLoader = useSimpleDataLoader(async () => {
  88. return new Array(12).fill(0).map((_, i) => ({
  89. title: '茶艺传承作坊' + i,
  90. desc: '多馆联展,沉浸式交互体验。',
  91. tags: ['拍摄标准', '命名规则','拍摄标准', '命名规则'],
  92. image: testImage(),
  93. thumbnail: testImage(),
  94. }));
  95. });
  96. </script>