index.tsx 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. import NavBarNormal from "@/components/nav-bar-normal/index";
  2. import { View } from "@tarojs/components";
  3. import PageCustom from "@/components/page-custom/index";
  4. import CardList from "@/components/list/card-list";
  5. import TagCertificated from "@/components/tag-certificated";
  6. import CardListItem from "@/components/list/card-list-item";
  7. import Taro, { useRouter } from "@tarojs/taro";
  8. import { useAgentStore } from "@/store/agentStore";
  9. import { TAgentDetail } from "@/types/agent";
  10. const RenderEntCard = (agent: TAgentDetail|null, navToUrl: (url: string)=>void) => {
  11. if(!agent?.entName){
  12. return <></>
  13. }
  14. return <View className="px-16 w-full pt-12">
  15. <CardList>
  16. <View className="py-16 px-20 flex flex-col gap-20">
  17. <CardListItem underline arrow onClick={()=> navToUrl('/pages/editor-pages/editor-company/index')}>
  18. <View className="flex items-center font-normal pb-16">
  19. <View className="flex-1 font-normal">企业</View>
  20. <View className="text-gray-65 mr-8 truncate max-w-[188px]">{agent?.entName}</View>
  21. </View>
  22. </CardListItem>
  23. <CardListItem underline>
  24. <View className="flex items-center font-normal pb-16">
  25. <View className="flex-1 font-normal">企业认证</View>
  26. <TagCertificated />
  27. </View>
  28. </CardListItem>
  29. <CardListItem arrow onClick={()=> navToUrl('/pages/editor-pages/editor-position/index')}>
  30. <View className="flex items-center font-normal pb-16">
  31. <View className="flex-1 font-normal">职位</View>
  32. <View className="text-gray-65 mr-8">{agent?.position}</View>
  33. </View>
  34. </CardListItem>
  35. </View>
  36. </CardList>
  37. </View>
  38. }
  39. export default function Index() {
  40. const router = useRouter()
  41. const {agentId} = router.params
  42. const agent = useAgentStore(state => state.agent)
  43. const navToUrl = (url: string)=> {
  44. Taro.navigateTo({url})
  45. }
  46. return (
  47. <PageCustom>
  48. <NavBarNormal backText="数字名片"></NavBarNormal>
  49. <View className="px-16 w-full pt-4">
  50. <CardList>
  51. <View className="py-16 px-20 flex flex-col gap-20">
  52. <CardListItem underline arrow onClick={()=> navToUrl(`/pages/editor-pages/editor-name/index?agentId=${agentId}`)}>
  53. <View className="flex items-center font-normal pb-16">
  54. <View className="flex-1 font-normal">姓名</View>
  55. <View className="text-gray-65 mr-8">{agent?.name}</View>
  56. </View>
  57. </CardListItem>
  58. <CardListItem underline arrow onClick={()=> navToUrl(`/pages/editor-pages/editor-phone/index?agentId=${agentId}`)}>
  59. <View className="flex items-center font-normal pb-16">
  60. <View className="flex-1 font-normal">手机号码</View>
  61. <View className="text-gray-65 mr-8">{agent?.mobile}</View>
  62. </View>
  63. </CardListItem>
  64. <CardListItem underline arrow onClick={()=> navToUrl(`/pages/editor-pages/editor-email/index?agentId=${agentId}`)}>
  65. <View className="flex items-center font-normal pb-16">
  66. <View className="flex-1 font-normal">联系邮箱</View>
  67. <View className="text-gray-65 mr-8 truncate max-w-[188px]">{agent?.email}</View>
  68. </View>
  69. </CardListItem>
  70. <CardListItem underline arrow>
  71. <View className="flex items-center font-normal pb-16">
  72. <View className="flex-1 font-normal">联系地址</View>
  73. <View className="text-gray-65 mr-8 truncate max-w-[188px]">{agent?.address}</View>
  74. </View>
  75. </CardListItem>
  76. <CardListItem arrow onClick={()=> navToUrl('/pages/editor-pages/editor-qrcode/index')}>
  77. <View className="flex items-center font-normal pb-16">
  78. <View className="flex-1 font-normal">我的二维码</View>
  79. <View className="text-gray-65 mr-8 text-primary">已上传</View>
  80. </View>
  81. </CardListItem>
  82. </View>
  83. </CardList>
  84. </View>
  85. {RenderEntCard(agent, navToUrl)}
  86. </PageCustom>
  87. );
  88. }