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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
use json::{JsonValue, object};
use crate::{Field};

/// 数字
///
/// * require 是否必填
/// * field 字段名
/// * mode 模式 string
/// * title 字段描述
/// * length 字段总长度(含小数位)
/// * def 默认值
/// * dec 符号
pub struct Int {
    pub require: bool,
    pub field: String,
    pub mode: String,
    pub title: String,
    pub def: i64,
    pub length: i32,
    pub dec: String,
}

impl Int {
    pub fn new(require: bool, field: &str, title: &str, length: i32, default: i64) -> Self {
        Self {
            require,
            field: field.to_string(),
            mode: "int".to_string(),
            title: title.to_string(),
            def: default,
            length,
            dec: "".to_string(),
        }
    }
}

impl Field for Int {
    fn sql(&mut self, model: &str) -> String {
        let mut sql = format!("{} int({})", self.field, self.length);
        if self.require {
            sql = format!("{} not null", sql.clone())
        };
        sql = format!("{} default {}", sql.clone(), self.def);
        match model {
            "sqlite" => sql,
            _ => format!("{} comment '{}|{}|{}|{}|{}|{}'", sql.clone(), self.mode, self.require, self.title, self.length, self.def, self.dec)
        }
    }
    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
    }
}


/// 自增主键
///
/// * field 字段名
/// * mode 模式
/// * title 字段描述
/// * length 字段总长度(含小数位)
/// * def 默认值
/// * dec 无效
pub struct AutoKey {
    pub require: bool,
    pub field: String,
    pub mode: String,
    pub title: String,
    pub length: i32,
}

impl AutoKey {
    pub fn new(require: bool, field: &str, title: &str) -> Self {
        Self {
            require,
            field: field.to_string(),
            mode: "autokey".to_string(),
            title: title.to_string(),
            length: 0,
        }
    }
}

impl Field for AutoKey {
    fn sql(&mut self, model: &str) -> String {
        let mut sql = "".to_string();
        //PRIMARY KEY
        match model {
            "sqlite" => {
                sql = format!("{}{} INTEGER PRIMARY KEY", sql.clone(), self.field);
                sql = format!("{} AUTOINCREMENT", sql.clone());
                return sql;
            }
            _ => {
                sql = format!("{}{} int({})", sql.clone(), self.field, self.length);
                sql = format!("{} not null AUTO_INCREMENT", sql.clone());
                format!("{} comment '{}|{}|{}|{}'", sql.clone(), self.mode, self.require, self.title, self.length)
            }
        }
    }
    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
    }
}


/// 开关
///
/// * field 字段名
/// * mode 模式 string
/// * title 字段描述
/// * default 默认值
/// * empty 是否可空
pub struct Switch {
    pub require: bool,
    pub field: String,
    pub mode: String,
    pub title: String,
    pub def: bool,
}

impl Switch {
    pub fn new(require: bool, field: &str, title: &str, default: bool) -> Self {
        Self {
            require,
            field: field.to_string(),
            mode: "switch".to_string(),
            title: title.to_string(),
            def: default,
        }
    }
}

impl Field for Switch {
    fn sql(&mut self, model: &str) -> String {
        let mut sql = format!("{} bool", self.field);
        if self.require {
            sql = format!("{} not null", sql.clone())
        };
        sql = format!("{} default {}", sql.clone(), self.def);
        match model {
            "sqlite" => sql,
            _ => format!("{} comment '{}|{}|{}|{}'", sql.clone(), self.mode, self.require, self.title, self.def)
        }
    }
    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("def", JsonValue::from(self.def.clone())).unwrap();
        field
    }
}