ux.form.field.KindEditor 所見所得編輯器

注意須要引入KindEditor相關資源html

  1 //所見所得編輯器
  2 Ext.define('ux.form.field.KindEditor', {
  3     extend: 'Ext.form.field.TextArea',
  4     alias: 'widget.kindEditor',
  5     xtype: 'kindEditor',
  6     //最大文本長度
  7     maxLength:5000,
  8     //配置
  9     editorConfig: {
 10         //選項功能
 11         items: [
 12             'source', '|', 'undo', 'redo', '|', 'preview', 'cut', 'copy', 'paste', 'plainpaste', 'wordpaste', '|', 'justifyleft', 'justifycenter', 'justifyright', 'justifyfull', 'insertorderedlist', 'insertunorderedlist', 'indent', 'outdent', 'subscript', 'superscript', 'clearhtml', 'quickformat', 'selectall', '|', 'fullscreen', '/',
 13 
 14             'formatblock', 'fontname', 'fontsize', '|', 'forecolor', 'hilitecolor', 'bold', 'italic', 'underline', 'strikethrough', 'lineheight', 'removeformat', '|', 'image', 'table', 'hr', 'emoticons', 'pagebreak', 'anchor', 'link', 'unlink', '|', 'about'
 15         ],
 16         minHeight: 200
 17     },
 18     afterRender: function () {
 19         var me = this;
 20         me.callParent(arguments);
 21         //延遲輸入驗證
 22         me.task = Ext.create('Ext.util.DelayedTask',
 23         function (t) {
 24             me.isValid();
 25         },
 26         me);
 27         if (!me.editor) {
 28             //建立富文本插件
 29             me.editor = KindEditor.create("#" + me.getInputId(), Ext.apply(me.editorConfig, {
 30                 //編輯器建立成功
 31                 afterCreate: function () {
 32                     //標識完成
 33                     me.KindEditorIsReady = true;
 34                 },
 35                 //內容發生改變時
 36                 afterChange: function () {
 37                     //編輯器初始化完成才執行
 38                     if (me.KindEditorIsReady) {
 39                         //延遲輸入驗證
 40                         me.task.delay(100);
 41                     }
 42                 },
 43                 //失去焦點
 44                 afterBlur: function () {
 45                     //輸入驗證
 46                     me.isValid();
 47                 }
 48             }));
 49         } else {
 50             me.editor.html(me.getValue());
 51         }
 52     },
 53     setValue: function (value) {
 54         //console.log('setValue');
 55         var me = this;
 56         if (!me.editor) {
 57             me.setRawValue(me.valueToRaw(value));
 58         } else {
 59             if(value){
 60                 me.editor.html(value.toString());
 61             }else{
 62                 
 63             }
 64         }
 65         me.callParent(arguments);
 66         return me.mixins.field.setValue.call(me, value);
 67     },
 68     getRawValue: function () {
 69         //console.log('getRawValue');
 70         var me = this;
 71         if (me.KindEditorIsReady) {
 72             //自動同步值
 73             me.editor.sync();
 74         }
 75         v = me.inputEl ? me.inputEl.getValue() : '';
 76         me.rawValue = v;
 77         return v;
 78     },
 79     //重置
 80     reset: function () {
 81         if (this.editor) {
 82             this.editor.html('');
 83         }
 84         this.callParent();
 85     },
 86     //銷燬富文本控件
 87     destroyEditor: function () {
 88         var me = this;
 89         if (me.rendered) {
 90             try {
 91                 me.editor.remove();
 92                 me.editor = null;
 93             } catch (e) { }
 94         }
 95     },
 96     //銷燬
 97     onDestroy: function () {
 98         var me = this;
 99         me.destroyEditor();
100         me.callParent(arguments);
101     }
102 });
相關文章
相關標籤/搜索