| 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
 | import React from 'react';
import {StyleProp, Text, TextStyle} from 'react-native';
import {
  isMentionPartType,
  parseValue,
  Part,
  PartType,
} from 'react-native-controlled-mentions';
import {TouchableOpacity} from 'react-native-gesture-handler';
import TaggTypeahead from '../components/common/TaggTypeahead';
import {TAGG_LIGHT_BLUE} from '../constants';
import {UserType} from '../types';
import {normalize} from './layouts';
/**
 * Part renderer
 *
 * https://github.com/dabakovich/react-native-controlled-mentions#rendering-mentioninputs-value
 */
const renderPart = (
  part: Part,
  index: number,
  handlePress: (user: UserType) => void,
) => {
  // Just plain text
  if (!part.partType) {
    return <Text key={index}>{part.text}</Text>;
  }
  // Mention type part
  if (isMentionPartType(part.partType)) {
    return (
      <TouchableOpacity
        key={`${index}-${part.data?.trigger}`}
        onPress={() => {
          if (part.data) {
            handlePress({
              userId: part.data.id,
              username: part.data.name,
            });
          }
        }}>
        <Text style={part.partType.textStyle}>{part.text}</Text>
      </TouchableOpacity>
    );
  }
  // Other styled part types
  return (
    <Text key={`${index}-pattern`} style={part.partType.textStyle}>
      {part.text}
    </Text>
  );
};
interface RenderProps {
  value: string;
  styles: StyleProp<TextStyle>;
  partTypes: PartType[];
  onPress: (user: UserType) => void;
}
/**
 * Value renderer. Parsing value to parts array and then mapping the array using 'renderPart'
 *
 * https://github.com/dabakovich/react-native-controlled-mentions#rendering-mentioninputs-value
 */
export const renderTextWithMentions: React.FC<RenderProps> = ({
  value,
  styles,
  partTypes,
  onPress,
}) => {
  const {parts} = parseValue(value, partTypes);
  return (
    <Text style={styles}>
      {parts.map((part, index) => renderPart(part, index, onPress))}
    </Text>
  );
};
export const mentionPartTypes: (theme: 'blue' | 'white') => PartType[] = (
  theme,
) => {
  return [
    {
      trigger: '@',
      renderSuggestions: (props) => <TaggTypeahead {...props} />,
      allowedSpacesCount: 0,
      isInsertSpaceAfterMention: true,
      textStyle: _textStyle(theme),
    },
  ];
};
const _textStyle: (theme: 'blue' | 'white') => StyleProp<TextStyle> = (
  theme,
) => {
  switch (theme) {
    case 'blue':
      return {
        color: TAGG_LIGHT_BLUE,
        top: normalize(3),
      };
    case 'white':
    default:
      return {
        color: 'white',
        fontWeight: '800',
        top: normalize(3),
      };
  }
};
 |