@ajaxjs/util 1.0.9 → 1.1.1

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 (88) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +11 -20
  3. package/dist/index.d.ts +34 -6
  4. package/dist/index.js +45 -8
  5. package/dist/index.js.map +1 -1
  6. package/dist/main.d.ts +1 -0
  7. package/dist/main.js +16 -0
  8. package/dist/main.js.map +1 -0
  9. package/dist/router/index.d.ts +3 -0
  10. package/dist/router/index.js +44 -0
  11. package/dist/router/index.js.map +1 -0
  12. package/dist/router.d.ts +3 -0
  13. package/dist/router.js +44 -0
  14. package/dist/router.js.map +1 -0
  15. package/dist/shims-vue.d.ts +4 -0
  16. package/dist/style/common-functions.less +294 -0
  17. package/dist/style/reset.less +19 -0
  18. package/dist/util/cookies.d.ts +18 -0
  19. package/dist/util/cookies.js +46 -0
  20. package/dist/util/cookies.js.map +1 -0
  21. package/dist/util/dom.d.ts +17 -0
  22. package/dist/util/dom.js +44 -0
  23. package/dist/util/dom.js.map +1 -0
  24. package/dist/util/utils.d.ts +51 -0
  25. package/dist/util/utils.js +174 -0
  26. package/dist/util/utils.js.map +1 -0
  27. package/dist/{xhr-config.js.map → util/xhr-config.js.map} +1 -1
  28. package/dist/{xhr.d.ts → util/xhr.d.ts} +16 -1
  29. package/dist/{xhr.js → util/xhr.js} +84 -36
  30. package/dist/util/xhr.js.map +1 -0
  31. package/dist/widget/AccordionMenu.vue +140 -0
  32. package/dist/widget/AdjustFontSize.vue +65 -0
  33. package/dist/widget/Article.vue +59 -0
  34. package/dist/widget/EmptyContent.d.ts +5 -0
  35. package/dist/widget/EmptyContent.js +7 -0
  36. package/dist/widget/EmptyContent.js.map +1 -0
  37. package/dist/widget/Expander.vue +65 -0
  38. package/dist/widget/FileUploader/FileUploader.d.ts +70 -0
  39. package/dist/widget/FileUploader/FileUploader.js +139 -0
  40. package/dist/widget/FileUploader/FileUploader.js.map +1 -0
  41. package/dist/widget/FileUploader/FileUploader.less +68 -0
  42. package/dist/widget/FileUploader/FileUploader.ts +156 -0
  43. package/dist/widget/FileUploader/FileUploader.vue +43 -0
  44. package/dist/widget/HtmlEditor/HtmlEditor.d.ts +70 -0
  45. package/dist/widget/HtmlEditor/HtmlEditor.js +287 -0
  46. package/dist/widget/HtmlEditor/HtmlEditor.js.map +1 -0
  47. package/dist/widget/HtmlEditor/HtmlEditor.less +345 -0
  48. package/dist/widget/HtmlEditor/HtmlEditor.ts +339 -0
  49. package/dist/widget/HtmlEditor/HtmlEditor.vue +70 -0
  50. package/dist/widget/HtmlEditor/html-editor-HtmlSanitizer.js +103 -0
  51. package/dist/widget/ImageEnlarger.vue +105 -0
  52. package/dist/widget/OpacityBanner.vue +125 -0
  53. package/dist/widget/ProcessLine.vue +133 -0
  54. package/dist/widget/Resize.d.ts +51 -0
  55. package/dist/widget/Resize.js +133 -0
  56. package/dist/widget/Resize.js.map +1 -0
  57. package/dist/widget/Resize.ts +152 -0
  58. package/dist/widget/Resize.vue +104 -0
  59. package/dist/widget/TreeSelector.vue +4 -0
  60. package/dist/widget/calendar/BetweenDate.vue +63 -0
  61. package/dist/widget/calendar/Calendar.d.ts +55 -0
  62. package/dist/widget/calendar/Calendar.js +145 -0
  63. package/dist/widget/calendar/Calendar.js.map +1 -0
  64. package/dist/widget/calendar/Calendar.less +210 -0
  65. package/dist/widget/calendar/Calendar.ts +167 -0
  66. package/dist/widget/calendar/Calendar.vue +52 -0
  67. package/dist/widget/calendar/CalendarInput.vue +71 -0
  68. package/dist/widget/form/validator.d.ts +70 -0
  69. package/dist/widget/form/validator.js +220 -0
  70. package/dist/widget/form/validator.js.map +1 -0
  71. package/dist/widget/form/validator.ts +289 -0
  72. package/dist/widget/play-ground/sku.vue +93 -0
  73. package/package.json +31 -15
  74. package/dist/base.d.ts +0 -42
  75. package/dist/base.js +0 -133
  76. package/dist/base.js.map +0 -1
  77. package/dist/entity.d.ts +0 -26
  78. package/dist/entity.js +0 -2
  79. package/dist/entity.js.map +0 -1
  80. package/dist/xhr.js.map +0 -1
  81. package/src/base.ts +0 -145
  82. package/src/entity.ts +0 -31
  83. package/src/index.ts +0 -13
  84. package/src/xhr-config.ts +0 -25
  85. package/src/xhr.ts +0 -233
  86. package/tsconfig.json +0 -73
  87. /package/dist/{xhr-config.d.ts → util/xhr-config.d.ts} +0 -0
  88. /package/dist/{xhr-config.js → util/xhr-config.js} +0 -0
@@ -0,0 +1,287 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.default = {
4
+ props: {
5
+ vModel: String,
6
+ uploadImageActionUrl: String,
7
+ isIonicons: Boolean // 是否使用 ionicons 图标
8
+ },
9
+ data() {
10
+ return {
11
+ isShowCode: false,
12
+ iframeEl: null,
13
+ sourceEditor: null,
14
+ };
15
+ },
16
+ mounted() {
17
+ this.iframeEl = this.$el.querySelector('iframe');
18
+ this.sourceEditor = this.$el.querySelector('textarea');
19
+ this.iframeEl.contentWindow.onload = (ev) => {
20
+ this.iframeDoc = this.iframeEl.contentWindow.document;
21
+ this.iframeDoc.designMode = 'on';
22
+ this.iframeDoc.addEventListener('paste', onImagePaste.bind(this)); // 直接剪切板粘贴上传图片
23
+ new MutationObserver((mutationsList, observer) => {
24
+ if (!this.isShowCode) {
25
+ this.sourceEditor.value = this.iframeDoc.body.innerHTML;
26
+ this.$emit('on-change', this.sourceEditor.value);
27
+ }
28
+ }).observe(this.iframeDoc.body, { attributes: true, childList: true, subtree: true, characterData: true });
29
+ this.vModel && this.setIframeBody(this.vModel);
30
+ // this.sourceEditor.value && this.setIframeBody(this.sourceEditor.value);// 有内容
31
+ };
32
+ this.sourceEditor.oninput = (ev) => {
33
+ if (this.isShowCode && this.sourceEditor.value) {
34
+ this.setIframeBody(this.sourceEditor.value);
35
+ this.$emit('on-change', this.sourceEditor.value);
36
+ }
37
+ };
38
+ // this.uploadImgMgr = this.$refs.uploadLayer;
39
+ },
40
+ methods: {
41
+ /**
42
+ * 输入 HTML 内容
43
+ *
44
+ * @param html
45
+ */
46
+ setIframeBody(html) {
47
+ if (this.iframeDoc && this.iframeDoc.body)
48
+ this.iframeDoc.body.innerHTML = html;
49
+ },
50
+ /**
51
+ * 获取内容的 HTML
52
+ *
53
+ * @param cleanWord 是否清理冗余标签
54
+ * @param encode 是否 URL 编码
55
+ */
56
+ getValue(cleanWord, encode) {
57
+ let result = this.iframeDoc.body.innerHTML;
58
+ if (cleanWord)
59
+ result = cleanPaste(result);
60
+ if (encode)
61
+ result = encodeURIComponent(result);
62
+ return result;
63
+ },
64
+ createLink() {
65
+ let result = prompt("请输入 URL 地址");
66
+ if (result)
67
+ this.format("createLink", result);
68
+ },
69
+ insertImage() {
70
+ // @ts-ignore
71
+ if (window.isCreate)
72
+ alert('请保存记录后再上传图片。');
73
+ else {
74
+ this.uploadImgMgr.show((json) => {
75
+ if (json && json.isOk)
76
+ this.format("insertImage", json.fullUrl);
77
+ });
78
+ }
79
+ },
80
+ /**
81
+ * 清理冗余 HTML
82
+ */
83
+ cleanHTML() {
84
+ // @ts-ignore
85
+ this.setIframeBody(HtmlSanitizer.SanitizeHtml(this.iframeDoc.body.innerHTML));
86
+ },
87
+ saveRemoteImage2Local() {
88
+ saveRemoteImage2Local.call(this);
89
+ },
90
+ /**
91
+ * 当工具条点击的时候触发
92
+ *
93
+ * @param ev
94
+ */
95
+ onCmdClk(ev) {
96
+ let el = ev.target, clsName = el.className.split(' ').shift();
97
+ this.format(clsName);
98
+ },
99
+ /**
100
+ * 通过 document.execCommand() 来操纵可编辑内容区域的元素
101
+ *
102
+ * @param type 命令的名称
103
+ * @param para 一些命令(例如 insertImage)需要额外的参数(insertImage 需要提供插入 image 的 url),默认为 null
104
+ */
105
+ format(type, para) {
106
+ if (para)
107
+ this.iframeDoc.execCommand(type, false, para);
108
+ else
109
+ this.iframeDoc.execCommand(type, false);
110
+ // (<Window>this.iframeEl.contentWindow).focus();
111
+ },
112
+ /**
113
+ * 选择字号大小
114
+ *
115
+ * @param ev
116
+ */
117
+ onFontsizeChoserClk(ev) {
118
+ let el = ev.target, els = ev.currentTarget.children;
119
+ let i, j;
120
+ for (i = 0, j = els.length; i < j; i++)
121
+ if (el == els[i])
122
+ break;
123
+ this.format('fontsize', i + "");
124
+ },
125
+ /**
126
+ * 选择字体
127
+ *
128
+ * @param ev
129
+ */
130
+ onFontfamilyChoserClk(ev) {
131
+ let el = ev.target;
132
+ this.format('fontname', el.innerHTML);
133
+ /* 如何解决点击之后马上隐藏面板?由于 js(单击事件) 没有控制 CSS 的 :hover 伪类的方法,故所以必须使用以下技巧:*/
134
+ let menuPanel = el.parentNode;
135
+ menuPanel.style.display = 'none';
136
+ setTimeout(() => menuPanel.style.display = '', 300);
137
+ },
138
+ /**
139
+ * 创建颜色选择器
140
+ */
141
+ createColorPickerHTML() {
142
+ let cl = ['00', '33', '66', '99', 'CC', 'FF'], b, d, e, f, h = ['<div class="colorhead"><span class="colortitle">颜色选择</span></div><div class="colorbody"><table cellspaci="0" cellpadding="0"><tr>'];
143
+ // 创建 body [6 x 6的色盘]
144
+ for (let i = 0; i < 6; ++i) {
145
+ h.push('<td><table class="colorpanel" cellspacing="0" cellpadding="0">');
146
+ for (let j = 0, a = cl[i]; j < 6; ++j) {
147
+ h.push('<tr>');
148
+ for (let k = 0, c = cl[j]; k < 6; ++k) {
149
+ b = cl[k];
150
+ e = (k == 5 && i != 2 && i != 5) ? ';border-right:none;' : '';
151
+ f = (j == 5 && i < 3) ? ';border-bottom:none' : '';
152
+ d = '#' + a + b + c;
153
+ // T = document.all ? '&nbsp;' : '';
154
+ h.push('<td unselectable="on" style="background-color: ' + d + e + f + '" title="' + d + '"></td>');
155
+ }
156
+ h.push('</tr>');
157
+ }
158
+ h.push('</table></td>');
159
+ if (cl[i] == '66')
160
+ h.push('</tr><tr>');
161
+ }
162
+ h.push('</tr></table></div>');
163
+ return h.join('');
164
+ }
165
+ },
166
+ watch: {
167
+ vModel(newHtml, oldHtml) {
168
+ // if (!html)
169
+ // html = '';
170
+ if (!oldHtml) // 当没有值的时候输入,就是在初始化的时候(第一次)
171
+ this.setIframeBody(newHtml);
172
+ },
173
+ /**
174
+ * 切換 HTML 編輯 or 可視化編輯
175
+ *
176
+ * @param n
177
+ */
178
+ isShowCode(n) {
179
+ if (n) {
180
+ this.iframeEl.classList.add('hide');
181
+ this.sourceEditor.classList.add('show');
182
+ grayImg.call(this, true);
183
+ }
184
+ else {
185
+ this.iframeEl.classList.remove('hide');
186
+ this.sourceEditor.classList.remove('show');
187
+ grayImg.call(this, false);
188
+ }
189
+ },
190
+ }
191
+ };
192
+ /**
193
+ * 粘贴图片
194
+ *
195
+ * @param this
196
+ * @param ev
197
+ */
198
+ function onImagePaste(ev) {
199
+ if (!this.uploadImageActionUrl) {
200
+ alert('未提供图片上传地址');
201
+ return;
202
+ }
203
+ let items = ev.clipboardData && ev.clipboardData.items, file = null; // file 就是剪切板中的图片文件
204
+ if (items && items.length) { // 检索剪切板 items
205
+ for (let i = 0; i < items.length; i++) {
206
+ const item = items[i];
207
+ if (item.type.indexOf('image') !== -1) {
208
+ // @ts-ignore
209
+ if (window.isCreate) { // 有图片
210
+ alert('请保存记录后再上传图片。');
211
+ return;
212
+ }
213
+ file = item.getAsFile();
214
+ break;
215
+ }
216
+ }
217
+ }
218
+ if (file) {
219
+ // ev.preventDefault();
220
+ // img.changeBlobImageQuality(file, (newBlob: Blob): void => {
221
+ // // 复用上传的方法
222
+ // Vue.options.components["aj-xhr-upload"].extendOptions.methods.doUpload.call({
223
+ // action: this.uploadImageActionUrl,
224
+ // progress: 0,
225
+ // uploadOk_callback(j: ImgUploadRepsonseResult) {
226
+ // if (j.isOk)
227
+ // this.format("insertImage", this.ajResources.imgPerfix + j.imgUrl);
228
+ // },
229
+ // $blob: newBlob,
230
+ // $fileName: 'foo.jpg' // 文件名不重要,反正上传到云空间会重命名
231
+ // });
232
+ // });
233
+ }
234
+ }
235
+ /**
236
+ * 一键存图
237
+ *
238
+ * @param this
239
+ */
240
+ function saveRemoteImage2Local() {
241
+ const arr = this.iframeDoc.querySelectorAll('img'), remotePicArr = new Array(), srcs = [];
242
+ for (let i = 0, j = arr.length; i < j; i++) {
243
+ const imgEl = arr[i], src = imgEl.getAttribute('src');
244
+ if (/^http/.test(src)) {
245
+ remotePicArr.push(imgEl);
246
+ srcs.push(src);
247
+ }
248
+ }
249
+ if (srcs.length) {
250
+ // xhr.post('../downAllPics/', (json: any) => {
251
+ // const _arr: string[] = json.pics;
252
+ // for (let i = 0, j = _arr.length; i < j; i++)
253
+ // remotePicArr[i].src = "images/" + _arr[i]; // 改变 DOM 的旧图片地址为新的
254
+ // alert('所有图片下载完成。');
255
+ // }, { pics: srcs.join('|') });
256
+ }
257
+ else
258
+ alert('未发现有远程图片');
259
+ }
260
+ /**
261
+ * 使图标变灰色
262
+ *
263
+ * @param this
264
+ * @param isGray
265
+ */
266
+ function grayImg(isGray) {
267
+ this.$el.querySelectorAll('.toolbar i').forEach((item) => {
268
+ if (item.className.indexOf('switchMode') != -1) // 这个按钮永远可按,不受影响
269
+ return;
270
+ item.style.color = isGray ? 'lightgray' : '';
271
+ });
272
+ }
273
+ /**
274
+ * Remove additional MS Word content
275
+ * MSWordHtmlCleaners.js https://gist.github.com/ronanguilloux/2915995
276
+ *
277
+ * @param html
278
+ */
279
+ function cleanPaste(html) {
280
+ html = html.replace(/<(\/)*(\\?xml:|meta|link|span|font|del|ins|st1:|[ovwxp]:)((.|\s)*?)>/gi, ''); // Unwanted tags
281
+ html = html.replace(/(class|style|type|start)=("(.*?)"|(\w*))/gi, ''); // Unwanted sttributes
282
+ html = html.replace(/<style(.*?)style>/gi, ''); // Style tags
283
+ html = html.replace(/<script(.*?)script>/gi, ''); // Script tags
284
+ html = html.replace(/<!--(.*?)-->/gi, ''); // HTML comments
285
+ return html;
286
+ }
287
+ //# sourceMappingURL=HtmlEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HtmlEditor.js","sourceRoot":"","sources":["../../../src/widget/HtmlEditor/HtmlEditor.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,345 @@
1
+ .aj-form-html-editor {
2
+ ul.toolbar {
3
+ border : 1px solid #C5C5C5;
4
+ border-radius : 4px 4px 0 0;
5
+ border-bottom : 0;
6
+ background-color: #E8E7E4;
7
+ width : 100%;
8
+ min-height : 30px;
9
+ margin : 0;
10
+ box-sizing : border-box;
11
+ padding : 3px 4px;
12
+
13
+ &>li {
14
+ list-style: none;
15
+ float : left;
16
+ cursor : pointer;
17
+
18
+ &>i {
19
+ border : 1px solid transparent;
20
+ min-width : 25px;
21
+ height : 20px;
22
+ line-height: 20px;
23
+ text-align : center;
24
+ display : block;
25
+
26
+ &.text-icon{
27
+ font-family:Times New Roman;font-weight: bold;font-style: normal;
28
+ }
29
+
30
+ &.fontAwesome{
31
+ padding-top: 2px;
32
+ font : normal normal normal 18px/1 FontAwesome;
33
+ }
34
+
35
+ &:hover {
36
+ border-right-color : #aaa;
37
+ border-bottom-color: #aaa;
38
+ border-top-color : #fff;
39
+ border-left-color : #fff;
40
+ }
41
+
42
+ &:active {
43
+ border-right-color : #f3f8fc;
44
+ border-bottom-color: #f3f8fc;
45
+ border-top-color : #ccc;
46
+ border-left-color : #ccc;
47
+ }
48
+ }
49
+
50
+ ul li {
51
+ padding: 3px;
52
+ cursor : pointer;
53
+
54
+ &:hover {
55
+ background-color: lightgray;
56
+ }
57
+ }
58
+
59
+ .cleanHTML {
60
+ background-size: 16px 16px;
61
+ }
62
+
63
+ .noBg {
64
+ background-image: none;
65
+ }
66
+ }
67
+ }
68
+
69
+ .editorBody {
70
+ iframe,
71
+ textarea {
72
+ border : 1px solid #C5C5C5;
73
+ border-radius : 0 0 4px 4px;
74
+ border-top-width: 0;
75
+ box-sizing : border-box;
76
+ background-color: white;
77
+ min-height : 300px;
78
+ width : 100%;
79
+ }
80
+
81
+ iframe.hide{
82
+ display: none;
83
+ }
84
+ textarea {
85
+ resize: none;
86
+ display: none;
87
+ &.show{
88
+ display: block;
89
+ }
90
+ }
91
+ }
92
+
93
+ .colorPicker {
94
+ width : 210px;
95
+ border : 1px solid #D3D3D3;
96
+ position: absolute;
97
+
98
+ table {
99
+ border-collapse: collapse;
100
+ }
101
+
102
+ .colorhead {
103
+ height : 23px;
104
+ line-height: 23px;
105
+ font-weight: bold;
106
+ width : 100%;
107
+ }
108
+
109
+ .colortitle {
110
+ margin-left: 6px;
111
+ font-size : 12px;
112
+ }
113
+
114
+ .colorpanel td {
115
+ border : 1px solid #000;
116
+ height : 10px;
117
+ width : 10px;
118
+ overflow : hidden;
119
+ font-size: 1px;
120
+ cursor : pointer;
121
+ }
122
+ }
123
+
124
+ // 字体演示
125
+ .fontfamilyChoser,
126
+ .fontsizeChoser {
127
+ a {
128
+ padding-right : 2px;
129
+ display : block;
130
+ padding-left : 2px;
131
+ padding-bottom : 2px;
132
+ color : #000;
133
+ line-height : 120%;
134
+ padding-top : 2px;
135
+ text-decoration: none;
136
+
137
+ &:hover {
138
+ background: #e5e5e5
139
+ }
140
+ }
141
+ }
142
+
143
+ // 登录面板 和忘记密码
144
+ .dorpdown {
145
+ position: relative;
146
+
147
+ &:hover .fontfamilyChoser,
148
+ .fontfamilyChoser:hover,
149
+ &:hover .fontsizeChoser,
150
+ .fontsizeChoser:hover,
151
+ &:hover .colorPicker,
152
+ .colorPicker:hover {
153
+ display: block;
154
+ }
155
+
156
+ &>div {
157
+ display : none;
158
+ position : absolute;
159
+ top : 22px;
160
+ left : 0;
161
+ background-color: #f5f5f5;
162
+ border : 1px solid lightgray;
163
+ border-top : 0;
164
+ padding : 5px;
165
+ width : 230px;
166
+ }
167
+
168
+ .fontsizeChoser {
169
+ top : inherit;
170
+ right: 0;
171
+ }
172
+ }
173
+ }.aj-form-html-editor {
174
+ ul.toolbar {
175
+ border : 1px solid #C5C5C5;
176
+ border-radius : 4px 4px 0 0;
177
+ border-bottom : 0;
178
+ background-color: #E8E7E4;
179
+ width : 100%;
180
+ min-height : 30px;
181
+ margin : 0;
182
+ box-sizing : border-box;
183
+ padding : 3px 4px;
184
+
185
+ &>li {
186
+ list-style: none;
187
+ float : left;
188
+ cursor : pointer;
189
+
190
+ &>i {
191
+ border : 1px solid transparent;
192
+ min-width : 25px;
193
+ height : 20px;
194
+ line-height: 20px;
195
+ text-align : center;
196
+ display : block;
197
+
198
+ &.text-icon{
199
+ font-family:Times New Roman;font-weight: bold;font-style: normal;
200
+ }
201
+
202
+ &.fontAwesome{
203
+ padding-top: 2px;
204
+ font : normal normal normal 18px/1 FontAwesome;
205
+ }
206
+
207
+ &:hover {
208
+ border-right-color : #aaa;
209
+ border-bottom-color: #aaa;
210
+ border-top-color : #fff;
211
+ border-left-color : #fff;
212
+ }
213
+
214
+ &:active {
215
+ border-right-color : #f3f8fc;
216
+ border-bottom-color: #f3f8fc;
217
+ border-top-color : #ccc;
218
+ border-left-color : #ccc;
219
+ }
220
+ }
221
+
222
+ ul li {
223
+ padding: 3px;
224
+ cursor : pointer;
225
+
226
+ &:hover {
227
+ background-color: lightgray;
228
+ }
229
+ }
230
+
231
+ .cleanHTML {
232
+ background-size: 16px 16px;
233
+ }
234
+
235
+ .noBg {
236
+ background-image: none;
237
+ }
238
+ }
239
+ }
240
+
241
+ .editorBody {
242
+ iframe,
243
+ textarea {
244
+ border : 1px solid #C5C5C5;
245
+ border-radius : 0 0 4px 4px;
246
+ border-top-width: 0;
247
+ box-sizing : border-box;
248
+ background-color: white;
249
+ min-height : 300px;
250
+ width : 100%;
251
+ }
252
+
253
+ iframe.hide{
254
+ display: none;
255
+ }
256
+ textarea {
257
+ resize: none;
258
+ display: none;
259
+ &.show{
260
+ display: block;
261
+ }
262
+ }
263
+ }
264
+
265
+ .colorPicker {
266
+ width : 210px;
267
+ border : 1px solid #D3D3D3;
268
+ position: absolute;
269
+
270
+ table {
271
+ border-collapse: collapse;
272
+ }
273
+
274
+ .colorhead {
275
+ height : 23px;
276
+ line-height: 23px;
277
+ font-weight: bold;
278
+ width : 100%;
279
+ }
280
+
281
+ .colortitle {
282
+ margin-left: 6px;
283
+ font-size : 12px;
284
+ }
285
+
286
+ .colorpanel td {
287
+ border : 1px solid #000;
288
+ height : 10px;
289
+ width : 10px;
290
+ overflow : hidden;
291
+ font-size: 1px;
292
+ cursor : pointer;
293
+ }
294
+ }
295
+
296
+ // 字体演示
297
+ .fontfamilyChoser,
298
+ .fontsizeChoser {
299
+ a {
300
+ padding-right : 2px;
301
+ display : block;
302
+ padding-left : 2px;
303
+ padding-bottom : 2px;
304
+ color : #000;
305
+ line-height : 120%;
306
+ padding-top : 2px;
307
+ text-decoration: none;
308
+
309
+ &:hover {
310
+ background: #e5e5e5
311
+ }
312
+ }
313
+ }
314
+
315
+ // 登录面板 和忘记密码
316
+ .dorpdown {
317
+ position: relative;
318
+
319
+ &:hover .fontfamilyChoser,
320
+ .fontfamilyChoser:hover,
321
+ &:hover .fontsizeChoser,
322
+ .fontsizeChoser:hover,
323
+ &:hover .colorPicker,
324
+ .colorPicker:hover {
325
+ display: block;
326
+ }
327
+
328
+ &>div {
329
+ display : none;
330
+ position : absolute;
331
+ top : 22px;
332
+ left : 0;
333
+ background-color: #f5f5f5;
334
+ border : 1px solid lightgray;
335
+ border-top : 0;
336
+ padding : 5px;
337
+ width : 230px;
338
+ }
339
+
340
+ .fontsizeChoser {
341
+ top : inherit;
342
+ right: 0;
343
+ }
344
+ }
345
+ }