forked from brianvoe/gofakeit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcolor.go
116 lines (93 loc) · 3.33 KB
/
color.go
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
package gofakeit
import (
"math/rand"
"github.com/brianvoe/gofakeit/v6/data"
)
// Color will generate a random color string
func Color() string { return color(globalFaker.Rand) }
// Color will generate a random color string
func (f *Faker) Color() string { return color(f.Rand) }
func color(r *rand.Rand) string { return getRandValue(r, []string{"color", "full"}) }
// NiceColor will generate a random safe color string
func NiceColors() []string { return niceColors(globalFaker.Rand) }
// NiceColor will generate a random safe color string
func (f *Faker) NiceColors() []string { return niceColors(f.Rand) }
func niceColors(r *rand.Rand) []string {
return data.ColorsNice[randIntRange(r, 0, len(data.ColorsNice)-1)]
}
// SafeColor will generate a random safe color string
func SafeColor() string { return safeColor(globalFaker.Rand) }
// SafeColor will generate a random safe color string
func (f *Faker) SafeColor() string { return safeColor(f.Rand) }
func safeColor(r *rand.Rand) string { return getRandValue(r, []string{"color", "safe"}) }
// HexColor will generate a random hexadecimal color string
func HexColor() string { return hexColor(globalFaker.Rand) }
// HexColor will generate a random hexadecimal color string
func (f *Faker) HexColor() string { return hexColor(f.Rand) }
func hexColor(r *rand.Rand) string {
color := make([]byte, 6)
hashQuestion := []byte("?#")
for i := 0; i < 6; i++ {
color[i] = hashQuestion[r.Intn(2)]
}
return "#" + replaceWithHexLetters(r, replaceWithNumbers(r, string(color)))
}
// RGBColor will generate a random int slice color
func RGBColor() []int { return rgbColor(globalFaker.Rand) }
// RGBColor will generate a random int slice color
func (f *Faker) RGBColor() []int { return rgbColor(f.Rand) }
func rgbColor(r *rand.Rand) []int {
return []int{randIntRange(r, 0, 255), randIntRange(r, 0, 255), randIntRange(r, 0, 255)}
}
func addColorLookup() {
AddFuncLookup("color", Info{
Display: "Color",
Category: "color",
Description: "Random color",
Example: "MediumOrchid",
Output: "string",
Generate: func(r *rand.Rand, m *MapParams, info *Info) (interface{}, error) {
return color(r), nil
},
})
AddFuncLookup("nicecolors", Info{
Display: "Nice Colors",
Category: "color",
Description: "Random set of nice colors",
Example: "[#5c323e #a82743 #e15e32 #c0d23e #e5f04c]",
Output: "[]string",
Generate: func(r *rand.Rand, m *MapParams, info *Info) (interface{}, error) {
return color(r), nil
},
})
AddFuncLookup("safecolor", Info{
Display: "Safe Color",
Category: "color",
Description: "Random safe color",
Example: "black",
Output: "string",
Generate: func(r *rand.Rand, m *MapParams, info *Info) (interface{}, error) {
return safeColor(r), nil
},
})
AddFuncLookup("hexcolor", Info{
Display: "Hex Color",
Category: "color",
Description: "Random hex color",
Example: "#a99fb4",
Output: "string",
Generate: func(r *rand.Rand, m *MapParams, info *Info) (interface{}, error) {
return hexColor(r), nil
},
})
AddFuncLookup("rgbcolor", Info{
Display: "RGB Color",
Category: "color",
Description: "Random rgb color",
Example: "[152 23 53]",
Output: "string",
Generate: func(r *rand.Rand, m *MapParams, info *Info) (interface{}, error) {
return rgbColor(r), nil
},
})
}