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
use json::{JsonValue, object};
use crate::Field;
pub struct Radio {
pub require: bool,
pub field: String,
pub mode: String,
pub title: String,
pub def: String,
pub option: Vec<String>,
pub dec: usize,
pub length: i32,
}
impl Radio {
pub fn new(require: bool, field: &str, title: &str, option: Vec<&str>, default: &str) -> Self {
Self {
require,
field: field.to_string(),
mode: "radio".to_string(),
title: title.to_string(),
def: default.to_string(),
option: option.iter().map(|c| c.to_string()).collect(),
dec: 0,
length: 0,
}
}
}
impl Field for Radio {
fn sql(&mut self, model: &str) -> String {
let mut sql = format!("{}", self.field);
if !self.require {
self.option.push("".to_string());
}
let options = format!("'{}'", self.option.join("','"));
match model {
"sqlite" => format!("{} varchar(50) default '{}'", sql.clone(), self.def),
_ => {
sql = format!("{} enum({}) default '{}'", sql.clone(), options, self.def);
format!("{} comment '{}|{}|{}|{}|{}|{}|{}'", sql.clone(), self.mode, self.require, self.title, self.length, self.def, self.dec, self.option.join("|"))
}
}
}
fn field(&mut self) -> JsonValue {
let mut field = object! {};
field.insert("require", JsonValue::from(self.require.clone())).unwrap();
field.insert("field", JsonValue::from(self.field.clone())).unwrap();
field.insert("mode", JsonValue::from(self.mode.clone())).unwrap();
field.insert("title", JsonValue::from(self.title.clone())).unwrap();
field.insert("length", JsonValue::from(self.length.clone())).unwrap();
field.insert("def", JsonValue::from(self.def.clone())).unwrap();
field.insert("dec", JsonValue::from(self.dec.clone())).unwrap();
field.insert("option", JsonValue::from(self.option.clone())).unwrap();
field
}
}
pub struct Select {
pub require: bool,
pub field: String,
pub mode: String,
pub title: String,
pub option: Vec<String>,
pub def: Vec<String>,
pub dec: usize,
pub length: i32,
}
impl Select {
pub fn new(require: bool, field: &str, title: &str, option: Vec<&str>, default: Vec<&str>) -> Self {
Self {
require,
field: field.to_string(),
mode: "select".to_string(),
title: title.to_string(),
def: default.iter().map(|c| c.to_string()).collect(),
dec: 0,
option: option.iter().map(|c| c.to_string()).collect(),
length: 0,
}
}
}
impl Field for Select {
fn sql(&mut self, model: &str) -> String {
let mut sql = format!("{}", self.field);
if !self.require {
self.option.push("".to_string());
}
let def = self.def.join(",");
let options = format!("'{}'", self.option.join("','"));
match model {
"sqlite" => {
format!("{} varchar(50) default '{}'", sql.clone(), def)
}
_ => {
sql = format!("{} set({}) default '{}'", sql.clone(), options, def);
format!("{} comment '{}|{}|{}|{}|{}|{}|{}'", sql.clone(), self.mode, self.require, self.title, self.length, self.def.join("|"), self.dec, self.option.join("|"))
}
}
}
fn field(&mut self) -> JsonValue {
let mut field = object! {};
field.insert("require", JsonValue::from(self.require.clone())).unwrap();
field.insert("field", JsonValue::from(self.field.clone())).unwrap();
field.insert("mode", JsonValue::from(self.mode.clone())).unwrap();
field.insert("title", JsonValue::from(self.title.clone())).unwrap();
field.insert("length", JsonValue::from(self.length.clone())).unwrap();
field.insert("def", JsonValue::from(self.def.clone())).unwrap();
field.insert("dec", JsonValue::from(self.dec.clone())).unwrap();
field.insert("option", JsonValue::from(self.option.clone())).unwrap();
field
}
}