raise-common-lib 0.0.192 → 0.0.194

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/bundles/raise-common-lib.umd.js +1357 -49
  2. package/bundles/raise-common-lib.umd.js.map +1 -1
  3. package/bundles/raise-common-lib.umd.min.js +1 -1
  4. package/bundles/raise-common-lib.umd.min.js.map +1 -1
  5. package/esm2015/lib/common-grid/index.component.js +2 -2
  6. package/esm2015/lib/form/drawer-form/drawer-form.component.js +112 -44
  7. package/esm2015/lib/form/richtexteditor/ai-config.js +70 -0
  8. package/esm2015/lib/form/richtexteditor/data-config.js +273 -0
  9. package/esm2015/lib/form/richtexteditor/index.component.js +601 -0
  10. package/esm2015/lib/form/richtexteditor/openapi.js +175 -0
  11. package/esm2015/lib/layout/page-tab/index.component.js +6 -2
  12. package/esm2015/lib/raise-common-lib.module.js +7 -2
  13. package/esm2015/raise-common-lib.js +5 -4
  14. package/esm5/lib/common-grid/index.component.js +2 -2
  15. package/esm5/lib/form/drawer-form/drawer-form.component.js +123 -45
  16. package/esm5/lib/form/richtexteditor/ai-config.js +73 -0
  17. package/esm5/lib/form/richtexteditor/data-config.js +273 -0
  18. package/esm5/lib/form/richtexteditor/index.component.js +681 -0
  19. package/esm5/lib/form/richtexteditor/openapi.js +208 -0
  20. package/esm5/lib/layout/page-tab/index.component.js +6 -2
  21. package/esm5/lib/raise-common-lib.module.js +7 -2
  22. package/esm5/raise-common-lib.js +5 -4
  23. package/fesm2015/raise-common-lib.js +1230 -48
  24. package/fesm2015/raise-common-lib.js.map +1 -1
  25. package/fesm5/raise-common-lib.js +1356 -49
  26. package/fesm5/raise-common-lib.js.map +1 -1
  27. package/lib/form/drawer-form/drawer-form.component.d.ts +10 -5
  28. package/lib/form/richtexteditor/ai-config.d.ts +10 -0
  29. package/lib/form/richtexteditor/data-config.d.ts +14 -0
  30. package/lib/form/richtexteditor/index.component.d.ts +78 -0
  31. package/lib/form/richtexteditor/openapi.d.ts +3 -0
  32. package/lib/layout/page-tab/index.component.d.ts +1 -0
  33. package/package.json +1 -1
  34. package/raise-common-lib.d.ts +4 -3
  35. package/raise-common-lib.metadata.json +1 -1
  36. package/src/assets/img/editor-copy.svg +5 -0
  37. package/src/assets/img/info.svg +5 -0
  38. package/src/assets/style/reset/grid.scss +2 -1
@@ -0,0 +1,273 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * Generated from: lib/form/richtexteditor/data-config.ts
4
+ * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
+ */
6
+ // font family
7
+ /** @type {?} */
8
+ export var fontFamily = {
9
+ default: "Arial",
10
+ items: [
11
+ {
12
+ text: "Arial",
13
+ value: "Arial, Helvetica, sans-serif",
14
+ cssClass: "e-arial",
15
+ command: "Font",
16
+ subCommand: "FontName",
17
+ },
18
+ {
19
+ text: "Times New Roman",
20
+ value: "Times New Roman,Times,serif",
21
+ cssClass: "e-times-new-roman",
22
+ command: "Font",
23
+ subCommand: "FontName",
24
+ },
25
+ {
26
+ text: "Helvetica",
27
+ value: "Helvetica",
28
+ cssClass: "e-helvetica",
29
+ command: "Font",
30
+ subCommand: "FontName",
31
+ },
32
+ {
33
+ text: "Calibri",
34
+ value: "Calibri, Helvetica, sans-serif",
35
+ cssClass: "e-calibri",
36
+ command: "Font",
37
+ subCommand: "FontName",
38
+ },
39
+ {
40
+ text: "Verdana",
41
+ value: "Verdana,Geneva,sans-serif",
42
+ cssClass: "e-verdana",
43
+ command: "Font",
44
+ subCommand: "FontName",
45
+ },
46
+ {
47
+ text: "Georgia",
48
+ value: "Georgia,serif",
49
+ cssClass: "e-georgia",
50
+ command: "Font",
51
+ subCommand: "FontName",
52
+ },
53
+ {
54
+ text: "Open Sans",
55
+ value: "Open Sans, sans-serif",
56
+ cssClass: "e-open-sans",
57
+ command: "Font",
58
+ subCommand: "FontName",
59
+ },
60
+ {
61
+ text: "Roboto",
62
+ value: "Roboto",
63
+ cssClass: "e-roboto",
64
+ command: "Font",
65
+ subCommand: "FontName",
66
+ },
67
+ {
68
+ text: "Lato",
69
+ value: "Lato, sans-serif",
70
+ cssClass: "e-lato",
71
+ command: "Font",
72
+ subCommand: "FontName",
73
+ },
74
+ {
75
+ text: "Montserrat",
76
+ value: "Montserrat, sans-serif",
77
+ cssClass: "e-montserrat",
78
+ command: "Font",
79
+ subCommand: "FontName",
80
+ },
81
+ {
82
+ text: "Segoe UI",
83
+ value: "Segoe UI",
84
+ cssClass: "e-segoe-ui",
85
+ command: "Font",
86
+ subCommand: "FontName",
87
+ },
88
+ {
89
+ text: "Impact",
90
+ value: "Impact,Charcoal,sans-serif",
91
+ cssClass: "e-impact",
92
+ command: "Font",
93
+ subCommand: "FontName",
94
+ },
95
+ ],
96
+ };
97
+ // line height配置
98
+ /** @type {?} */
99
+ export var lineHeight_items = [
100
+ {
101
+ text: "1.0",
102
+ },
103
+ {
104
+ text: "1.15",
105
+ },
106
+ {
107
+ text: "1.5",
108
+ },
109
+ {
110
+ text: "2.0",
111
+ },
112
+ {
113
+ text: "2.5",
114
+ },
115
+ {
116
+ text: "3.0",
117
+ },
118
+ ];
119
+ /**
120
+ * @record
121
+ */
122
+ export function BulletStyle() { }
123
+ if (false) {
124
+ /** @type {?} */
125
+ BulletStyle.prototype.id;
126
+ /** @type {?} */
127
+ BulletStyle.prototype.text;
128
+ /** @type {?} */
129
+ BulletStyle.prototype.symbol;
130
+ /** @type {?} */
131
+ BulletStyle.prototype.iconCss;
132
+ /** @type {?} */
133
+ BulletStyle.prototype.description;
134
+ }
135
+ /** @type {?} */
136
+ export var BULLET_STYLES = [
137
+ {
138
+ id: "disc",
139
+ text: "● 实心圆点",
140
+ symbol: "●",
141
+ iconCss: "e-icons e-bullet-disc",
142
+ description: "标准实心圆点",
143
+ },
144
+ {
145
+ id: "circle",
146
+ text: "○ 空心圆点",
147
+ symbol: "○",
148
+ iconCss: "e-icons e-bullet-circle",
149
+ description: "空心圆点",
150
+ },
151
+ {
152
+ id: "square",
153
+ text: "■ 实心方块",
154
+ symbol: "■",
155
+ iconCss: "e-icons e-bullet-square",
156
+ description: "实心方块",
157
+ },
158
+ {
159
+ id: "diamond",
160
+ text: "◆ 实心菱形",
161
+ symbol: "◆",
162
+ iconCss: "e-icons e-bullet-diamond",
163
+ description: "实心菱形",
164
+ },
165
+ {
166
+ id: "triangle",
167
+ text: "► 实心三角",
168
+ symbol: "►",
169
+ iconCss: "e-icons e-bullet-triangle",
170
+ description: "实心三角形",
171
+ },
172
+ {
173
+ id: "arrow",
174
+ text: "➤ 箭头",
175
+ symbol: "➤",
176
+ iconCss: "e-icons e-bullet-arrow",
177
+ description: "箭头符号",
178
+ },
179
+ {
180
+ id: "star",
181
+ text: "★ 星形",
182
+ symbol: "★",
183
+ iconCss: "e-icons e-bullet-star",
184
+ description: "星形符号",
185
+ },
186
+ {
187
+ id: "check",
188
+ text: "✓ 对勾",
189
+ symbol: "✓",
190
+ iconCss: "e-icons e-bullet-check",
191
+ description: "对勾符号",
192
+ },
193
+ {
194
+ id: "heart",
195
+ text: "♥ 心形",
196
+ symbol: "♥",
197
+ iconCss: "e-icons e-bullet-heart",
198
+ description: "心形符号",
199
+ },
200
+ {
201
+ id: "bullet",
202
+ text: "• 小圆点",
203
+ symbol: "•",
204
+ iconCss: "e-icons e-bullet-bullet",
205
+ description: "小圆点",
206
+ },
207
+ ];
208
+ // 获取符号样式
209
+ /**
210
+ * @param {?} id
211
+ * @return {?}
212
+ */
213
+ export function getBulletStyle(id) {
214
+ return BULLET_STYLES.find((/**
215
+ * @param {?} style
216
+ * @return {?}
217
+ */
218
+ function (style) { return style.id === id; }));
219
+ }
220
+ // 获取所有符号样式
221
+ /**
222
+ * @return {?}
223
+ */
224
+ export function getAllBulletStyles() {
225
+ return BULLET_STYLES;
226
+ }
227
+ // 应用符号样式到列表
228
+ /**
229
+ * @param {?} ul
230
+ * @param {?} style
231
+ * @return {?}
232
+ */
233
+ export function applyBulletStyle(ul, style) {
234
+ if (style.id === "disc" || style.id === "circle" || style.id === "square") {
235
+ // 使用CSS list-style-type
236
+ ul.style.listStyleType = style.id;
237
+ // 移除自定义符号
238
+ ul.querySelectorAll(".custom-bullet").forEach((/**
239
+ * @param {?} bullet
240
+ * @return {?}
241
+ */
242
+ function (bullet) { return bullet.remove(); }));
243
+ }
244
+ else {
245
+ // 使用自定义符号
246
+ ul.style.listStyleType = "none";
247
+ ul.setAttribute("data-bullet-style", style.id);
248
+ /** @type {?} */
249
+ var listItems = ul.querySelectorAll("li");
250
+ listItems.forEach((/**
251
+ * @param {?} li
252
+ * @return {?}
253
+ */
254
+ function (li) {
255
+ // 移除现有的自定义符号
256
+ /** @type {?} */
257
+ var existingBullet = li.querySelector(".custom-bullet");
258
+ if (existingBullet) {
259
+ existingBullet.remove();
260
+ }
261
+ // 添加新的自定义符号
262
+ /** @type {?} */
263
+ var bullet = document.createElement("span");
264
+ bullet.className = "custom-bullet";
265
+ bullet.textContent = style.symbol;
266
+ bullet.style.marginRight = "8px";
267
+ bullet.style.color = "#666";
268
+ // 将符号插入到列表项的开头
269
+ li.insertBefore(bullet, li.firstChild);
270
+ }));
271
+ }
272
+ }
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-config.js","sourceRoot":"ng://raise-common-lib/","sources":["lib/form/richtexteditor/data-config.ts"],"names":[],"mappings":"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","sourcesContent":["import { ItemModel } from \"@syncfusion/ej2-angular-splitbuttons\";\r\n\r\n// font family\r\n\r\nexport const fontFamily: Object = {\r\n  default: \"Arial\",\r\n  items: [\r\n    {\r\n      text: \"Arial\",\r\n      value: \"Arial, Helvetica, sans-serif\",\r\n      cssClass: \"e-arial\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Times New Roman\",\r\n      value: \"Times New Roman,Times,serif\",\r\n      cssClass: \"e-times-new-roman\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Helvetica\",\r\n      value: \"Helvetica\",\r\n      cssClass: \"e-helvetica\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Calibri\",\r\n      value: \"Calibri, Helvetica, sans-serif\",\r\n      cssClass: \"e-calibri\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Verdana\",\r\n      value: \"Verdana,Geneva,sans-serif\",\r\n      cssClass: \"e-verdana\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Georgia\",\r\n      value: \"Georgia,serif\",\r\n      cssClass: \"e-georgia\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Open Sans\",\r\n      value: \"Open Sans, sans-serif\",\r\n      cssClass: \"e-open-sans\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Roboto\",\r\n      value: \"Roboto\",\r\n      cssClass: \"e-roboto\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Lato\",\r\n      value: \"Lato, sans-serif\",\r\n      cssClass: \"e-lato\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Montserrat\",\r\n      value: \"Montserrat, sans-serif\",\r\n      cssClass: \"e-montserrat\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Segoe UI\",\r\n      value: \"Segoe UI\",\r\n      cssClass: \"e-segoe-ui\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n    {\r\n      text: \"Impact\",\r\n      value: \"Impact,Charcoal,sans-serif\",\r\n      cssClass: \"e-impact\",\r\n      command: \"Font\",\r\n      subCommand: \"FontName\",\r\n    },\r\n  ],\r\n};\r\n\r\n// line height配置\r\nexport const lineHeight_items: ItemModel[] = [\r\n  {\r\n    text: \"1.0\",\r\n  },\r\n  {\r\n    text: \"1.15\",\r\n  },\r\n  {\r\n    text: \"1.5\",\r\n  },\r\n  {\r\n    text: \"2.0\",\r\n  },\r\n  {\r\n    text: \"2.5\",\r\n  },\r\n  {\r\n    text: \"3.0\",\r\n  },\r\n];\r\n\r\n// 无序列表符号配置\r\nexport interface BulletStyle {\r\n  id: string;\r\n  text: string;\r\n  symbol: string;\r\n  iconCss: string;\r\n  description: string;\r\n}\r\n\r\nexport const BULLET_STYLES: BulletStyle[] = [\r\n  {\r\n    id: \"disc\",\r\n    text: \"● 实心圆点\",\r\n    symbol: \"●\",\r\n    iconCss: \"e-icons e-bullet-disc\",\r\n    description: \"标准实心圆点\",\r\n  },\r\n  {\r\n    id: \"circle\",\r\n    text: \"○ 空心圆点\",\r\n    symbol: \"○\",\r\n    iconCss: \"e-icons e-bullet-circle\",\r\n    description: \"空心圆点\",\r\n  },\r\n  {\r\n    id: \"square\",\r\n    text: \"■ 实心方块\",\r\n    symbol: \"■\",\r\n    iconCss: \"e-icons e-bullet-square\",\r\n    description: \"实心方块\",\r\n  },\r\n  {\r\n    id: \"diamond\",\r\n    text: \"◆ 实心菱形\",\r\n    symbol: \"◆\",\r\n    iconCss: \"e-icons e-bullet-diamond\",\r\n    description: \"实心菱形\",\r\n  },\r\n  {\r\n    id: \"triangle\",\r\n    text: \"► 实心三角\",\r\n    symbol: \"►\",\r\n    iconCss: \"e-icons e-bullet-triangle\",\r\n    description: \"实心三角形\",\r\n  },\r\n  {\r\n    id: \"arrow\",\r\n    text: \"➤ 箭头\",\r\n    symbol: \"➤\",\r\n    iconCss: \"e-icons e-bullet-arrow\",\r\n    description: \"箭头符号\",\r\n  },\r\n  {\r\n    id: \"star\",\r\n    text: \"★ 星形\",\r\n    symbol: \"★\",\r\n    iconCss: \"e-icons e-bullet-star\",\r\n    description: \"星形符号\",\r\n  },\r\n  {\r\n    id: \"check\",\r\n    text: \"✓ 对勾\",\r\n    symbol: \"✓\",\r\n    iconCss: \"e-icons e-bullet-check\",\r\n    description: \"对勾符号\",\r\n  },\r\n  {\r\n    id: \"heart\",\r\n    text: \"♥ 心形\",\r\n    symbol: \"♥\",\r\n    iconCss: \"e-icons e-bullet-heart\",\r\n    description: \"心形符号\",\r\n  },\r\n  {\r\n    id: \"bullet\",\r\n    text: \"• 小圆点\",\r\n    symbol: \"•\",\r\n    iconCss: \"e-icons e-bullet-bullet\",\r\n    description: \"小圆点\",\r\n  },\r\n];\r\n\r\n// 获取符号样式\r\nexport function getBulletStyle(id: string): BulletStyle | undefined {\r\n  return BULLET_STYLES.find((style) => style.id === id);\r\n}\r\n\r\n// 获取所有符号样式\r\nexport function getAllBulletStyles(): BulletStyle[] {\r\n  return BULLET_STYLES;\r\n}\r\n\r\n// 应用符号样式到列表\r\nexport function applyBulletStyle(ul: HTMLElement, style: BulletStyle): void {\r\n  if (style.id === \"disc\" || style.id === \"circle\" || style.id === \"square\") {\r\n    // 使用CSS list-style-type\r\n    ul.style.listStyleType = style.id;\r\n    // 移除自定义符号\r\n    ul.querySelectorAll(\".custom-bullet\").forEach((bullet) => bullet.remove());\r\n  } else {\r\n    // 使用自定义符号\r\n    ul.style.listStyleType = \"none\";\r\n    ul.setAttribute(\"data-bullet-style\", style.id);\r\n\r\n    const listItems = ul.querySelectorAll(\"li\");\r\n    listItems.forEach((li) => {\r\n      // 移除现有的自定义符号\r\n      const existingBullet = li.querySelector(\".custom-bullet\");\r\n      if (existingBullet) {\r\n        existingBullet.remove();\r\n      }\r\n\r\n      // 添加新的自定义符号\r\n      const bullet = document.createElement(\"span\");\r\n      bullet.className = \"custom-bullet\";\r\n      bullet.textContent = style.symbol;\r\n      bullet.style.marginRight = \"8px\";\r\n      bullet.style.color = \"#666\";\r\n\r\n      // 将符号插入到列表项的开头\r\n      li.insertBefore(bullet, li.firstChild);\r\n    });\r\n  }\r\n}\r\n"]}