"parent": "",
"title": "",
"path": "/home/edward/gitlive/Pman.Core/Pman.Dialog.CoreEmail.bjs",
- "items": false,
+ "items": [
+ {
+ "listeners": {
+ "show": "function (_self)\n{\n \n _self.layout.getRegion('center').showPanel(0);\n var w = Roo.lib.Dom.getViewWidth();\r\n var h = Roo.lib.Dom.getViewHeight(); \r this.resizeTo(w-50, h-50);\r\n this.center();\r \n var ew = Math.max(250, w-320);\r\n var eh = Math.max(250, h-350) ;\r\n var e = _this.dialog.layout.getRegion('east');\n if (e.visible) {\n e.hide();\n }\n \n var el = _self.getEl();\n var elw = el.dom.clientWidth;\n \n var bdtext = _this.form.findField('bodytext');\n var ptext = _this.form.findField('plaintext');\n if(bdtext.resizeEl){\n bdtext.width = elw-100;\n bdtext.resizeEl.resizeTo.defer(110, bdtext.resizeEl,[ bdtext.width, bdtext.height ] );\n ptext.setSize(bdtext.width , bdtext.height);\n }\n \n}"
+ },
+ "closable": true,
+ "collapsible": false,
+ "height": 500,
+ "modal": true,
+ "resizable": true,
+ "title": "Edit / Create Message",
+ "width": 800,
+ "xtype": "LayoutDialog",
+ "|xns": "Roo",
+ "items": [
+ {
+ "*prop": "center",
+ "tabPosition": "top",
+ "xtype": "LayoutRegion",
+ "|xns": "Roo"
+ },
+ {
+ "*prop": "east",
+ "hidden": true,
+ "split": true,
+ "title": "Images / Attachments",
+ "titlebar": true,
+ "width": 500,
+ "xtype": "LayoutRegion",
+ "|xns": "Roo"
+ },
+ {
+ "autoScroll": false,
+ "fitContainer": true,
+ "fitToFrame": true,
+ "region": "center",
+ "xtype": "NestedLayoutPanel",
+ "|xns": "Roo",
+ "items": [
+ {
+ "|xns": "Roo",
+ "xtype": "Toolbar",
+ "*prop": "toolbar",
+ "items": [
+ {
+ "text": "Import",
+ "xtype": "Button",
+ "|xns": "Roo.Toolbar",
+ "items": [
+ {
+ "|xns": "Roo.menu",
+ "xtype": "Menu",
+ "*prop": "menu",
+ "items": [
+ {
+ "listeners": {
+ "click": "function (_self, e)\n{\n Pman.Dialog.CoreImportUrl.show({\n target : '/Core/ImportMailMessage.php'\n }, function(data) {\n if (data) {\n // Roo.log(data);\n _this.form.findField('bodytext').setValue(data);\n }\n });\n}"
+ },
+ "text": "URL",
+ "xtype": "Item",
+ "|xns": "Roo.menu"
+ },
+ {
+ "listeners": {
+ "click": "function (_self, e)\n{\n Pman.Dialog.Image.show({\n _url : baseURL + '/Core/ImportMailMessage.php'\n }, function(data) {\n if (data) {\n _this.form.findField('bodytext').setValue(data);\n }\n });\n}"
+ },
+ "text": "Html File",
+ "xtype": "Item",
+ "|xns": "Roo.menu"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "text": "Use template",
+ "xtype": "Button",
+ "|xns": "Roo.Toolbar",
+ "items": [
+ {
+ "|xns": "Roo.menu",
+ "xtype": "Menu",
+ "*prop": "menu",
+ "items": [
+ {
+ "listeners": {
+ "click": "function (_self, e)\n{\n\n var l = document.location;\n new Pman.Request({\n\n url : baseURL + '/Core/ImportMailMessage.php',\n\n method: 'POST',\n mask : \"Loading\",\n params : {\n importUrl : l.protocol +'//' + l.host + rootURL + '/Pman/Crm/mail_templates/responsive1.html',\n },\n success : function (res) {\n\n _this.form.findField('bodytext').setValue(res.data);\n }\n \n });\n}"
+ },
+ "text": "Responsive Email (1)",
+ "xtype": "Item",
+ "|xns": "Roo.menu"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "listeners": {
+ "select": "function (combo, record, index)\n{\n \n/*\n (function() { \n combo.setValue('');\n }).defer(100);\n*/ \n if(!record){\n return;\n }\n _this.form.findField('bodytext').setValue(record.data.content);\n\n}"
+ },
+ "allowBlank": true,
+ "alwaysQuery": true,
+ "displayField": "file",
+ "editable": false,
+ "emptyText": "Select Template",
+ "fieldLabel": "Template",
+ "forceSelection": true,
+ "hiddenName": "template",
+ "listWidth": 400,
+ "loadingText": "Searching...",
+ "minChars": 2,
+ "name": "template",
+ "pageSize": 20,
+ "qtip": "Select Template",
+ "selectOnFocus": true,
+ "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{file}</b> </div>",
+ "triggerAction": "all",
+ "typeAhead": true,
+ "valueField": "file",
+ "width": 200,
+ "xtype": "ComboBox",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "listeners": {
+ "|beforeload": "function (_self, o){\n o.params = o.params || {};\n // set more here\n \n}\n"
+ },
+ "*prop": "store",
+ "remoteSort": true,
+ "xtype": "Store",
+ "|sortInfo": "{ direction : 'DESC', field: 'file' }",
+ "|xns": "Roo.data",
+ "items": [
+ {
+ "*prop": "proxy",
+ "method": "GET",
+ "xtype": "HttpProxy",
+ "|url": "baseURL + '/Core/MailTemplateList.php'",
+ "|xns": "Roo.data"
+ },
+ {
+ "*prop": "reader",
+ "id": "name",
+ "root": "data",
+ "totalProperty": "total",
+ "xtype": "JsonReader",
+ "|fields": "[{\"name\":\"file\",\"type\":\"string\"},{\"name\":\"content\",\"type\":\"string\"}]",
+ "|xns": "Roo.data"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "|xns": "Roo.Toolbar",
+ "xtype": "Fill"
+ },
+ {
+ "listeners": {
+ "click": "function (_self, e)\n{\n var el = _this.dialog.layout.getRegion('east');\n if (el.visible) {\n el.hide();\n } else {\n el.show();\n el.showPanel(0);\n }\n \n}"
+ },
+ "text": "Images / Attachments >>",
+ "xtype": "Button",
+ "|xns": "Roo.Toolbar"
+ }
+ ]
+ },
+ {
+ "|xns": "Roo",
+ "xtype": "BorderLayout",
+ "*prop": "layout",
+ "items": [
+ {
+ "*prop": "center",
+ "autoScroll": true,
+ "xtype": "LayoutRegion",
+ "|xns": "Roo"
+ },
+ {
+ "listeners": {
+ "render": "function (_self, width, height)\n{\n \n Roo.log(\"RESIZE, \" + width + ',' + height);\n \n var ew = Math.max(250, width-50);\n var eh = Math.max(250,height-50) ;\n \n \n\n}",
+ "resize": "function (_self, width, height)\r\n{\r\n var ew = Math.max(250, width-50);\r\n var eh = Math.max(250,height-50) ;\n \n if (!_this.form) {\r\n return;\r\n }\r\n var bdtext = _this.form.findField('bodytext');\r\n var ptext = _this.form.findField('plaintext');\r\n if(bdtext.resizeEl){\r\n bdtext.width = ew-50;\r\n bdtext.resizeEl.resizeTo.defer(110, bdtext.resizeEl,[ bdtext.width, bdtext.height ] );\r\n ptext.setSize(bdtext.width , bdtext.height);\r\n }\r\r\n\r\n}"
+ },
+ "autoScroll": false,
+ "background": false,
+ "fitContainer": true,
+ "fitToFrame": true,
+ "region": "center",
+ "title": "Message",
+ "xtype": "ContentPanel",
+ "|xns": "Roo",
+ "items": [
+ {
+ "listeners": {
+ "|actioncomplete": "function(_self,action)\n{\n \n if (action.type == 'setdata') {\n \n _this.data.module = _this.data.module || 'crm';\n \n _this.form.url = baseURL + '/Roo/' + _this.data.module + '_mailing_list_message.php';\n \n _this.html_preview.hide();\n _this.preview_btn.hide();\n \n if(_this.data.id*1 > 0){\n _this.dialog.el.mask(\"Loading\");\n this.load({ method: 'GET', params: { '_id' : _this.data.id }});\n if(_this.data.module == 'crm'){\n _this.html_preview.show();\n }\n _this.preview_btn.show();\n \n } else {\n _this.form.setValues({\n 'from_name' : Pman.Login.authUser.name,\n 'from_email' : Pman.Login.authUser.email\n });\n }\n return;\n }\n if (action.type == 'load') {\n _this.dialog.el.unmask();\n return;\n }\n if (action.type =='submit') {\n \n _this.dialog.el.unmask();\n _this.dialog.hide();\n \n if (_this.callback) {\n _this.callback.call(_this, action.result.data);\n }\n _this.form.reset();\n return;\n }\n}\n",
+ "|rendered": "function (form)\n{\n _this.form= form;\n}\n"
+ },
+ "labelAlign": "right",
+ "labelWidth": 120,
+ "method": "POST",
+ "style": "margin:10px",
+ "xtype": "Form",
+ "|preValidate": "function(done_callback) {\n \n Roo.MessageBox.progress(\"Uploading Images\", \"Uploading\");\n var html = _this.form.findField('bodytext').getValue();\n \n var s = Roo.get(_this.form.findField('bodytext').doc.documentElement);\n \n var ontable = (_this.data.module) ? _this.data.module + '_mailing_list_message' : 'crm_mailing_list_message';\n \n var nodes = [];\n s.select('img[src]').each(function(i) {\n nodes.push(i.dom);\n });\n var total = nodes.length;\n var mkimg = function() {\n \n if (!nodes.length) {\n Roo.MessageBox.hide();\n _this.form.findField('bodytext').syncValue();\n done_callback(true);\n // _this.form.doAction(\"submit\");\n return;\n }\n var i = nodes.pop(); \n var n = i.getAttribute('src').match(/^http(.*)/);\n if(!n ){\n mkimg();\n return;\n }\n \n new Pman.Request({\n url : baseURL + '/Roo/Images.php',\n method : 'POST',\n params : {\n onid : _this.form.findField('id').getValue(),\n ontable : ontable ,\n _remote_upload : i.src\n },\n success : function(res){\n if(res.success == true){ \n i.setAttribute('src', res.data);\n Roo.MessageBox.updateProgress( (total - nodes.length) / total , \"Done \" + (total - nodes.length) + '/' + total);\n }\n mkimg();\n }\n });\n \n }\n mkimg();\n}\n",
+ "|url": "baseURL + '/Roo/Core_mailing_list_message.php'",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "xtype": "Row",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "allowBlank": false,
+ "fieldLabel": "Mailout Name",
+ "name": "name",
+ "width": 400,
+ "xtype": "TextField",
+ "|xns": "Roo.form"
+ }
+ ]
+ },
+ {
+ "xtype": "Row",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "allowBlank": false,
+ "fieldLabel": "From",
+ "name": "from_name",
+ "width": 300,
+ "xtype": "TextField",
+ "|xns": "Roo.form"
+ },
+ {
+ "allowBlank": false,
+ "fieldLabel": "Email address",
+ "name": "from_email",
+ "width": 300,
+ "xtype": "TextField",
+ "|xns": "Roo.form"
+ }
+ ]
+ },
+ {
+ "allowBlank": false,
+ "fieldLabel": "Subject",
+ "name": "subject",
+ "width": 600,
+ "xtype": "TextField",
+ "|xns": "Roo.form"
+ },
+ {
+ "hideLabels": true,
+ "xtype": "Row",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "hideLabels": true,
+ "legend": "Html Editor",
+ "style": "text-align:center;",
+ "xtype": "FieldSet",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "height": 250,
+ "name": "bodytext",
+ "resizable": "s",
+ "xtype": "HtmlEditor",
+ "|cwhite": "[ \n 'margin',\n 'padding',\n 'text-align',\n 'background',\n 'height',\n 'width',\n 'background-color',\n 'font-size',\n 'line-height',\n 'color',\n 'outline',\n 'text-decoration',\n 'position',\n 'clear',\n 'overflow',\n 'margin-top',\n 'border-bottom',\n 'top',\n 'list-style',\n 'margin-left',\n 'border',\n 'float' ,\n 'margin-right',\n 'padding-top',\n 'min-height',\n 'left',\n 'padding-left',\n 'font-weight',\n 'font-family',\n 'display',\n 'margin-bottom',\n 'padding-bottom',\n 'vertical-align',\n 'cursor',\n 'z-index',\n 'right',\n ]",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "|xns": "Roo.form.HtmlEditor",
+ "xtype": "ToolbarContext",
+ "*prop": "toolbars[]"
+ },
+ {
+ "*prop": "toolbars[]",
+ "xtype": "ToolbarStandard",
+ "|xns": "Roo.form.HtmlEditor",
+ "items": [
+ {
+ "listeners": {
+ "render": "function (_self)\n{\n _this.extendimgselect = _self;\n}",
+ "select": "function (combo, record, index)\n{\n Roo.log(record);\n (function() { \n combo.setValue('');\n }).defer(100);\n var editor = _this.form.findField('bodytext');\n editor.insertAtCursor(\n String.format('<img src=\"{0}/Images/{1}/{2}#image-{1}\">',\n baseURL, record.data.id, record.data.filename\n )\n );\n\n \n }",
+ "beforequery": "function (combo, query, forceAll, cancel, e)\n{\n var id = _this.form.findField('id').getValue() * 1; \n if (!id) {\n Roo.MessageBox.alert(\"Error\", \"Save message first\");\n return false;\n }\n}"
+ },
+ "*prop": "btns[]",
+ "alwaysQuery": true,
+ "displayField": "name",
+ "editable": false,
+ "emptyText": "Add Image",
+ "fieldLabel": "Images",
+ "forceSelection": true,
+ "listWidth": 400,
+ "loadingText": "Searching...",
+ "minChars": 2,
+ "pageSize": 20,
+ "qtip": "Select Images",
+ "selectOnFocus": true,
+ "tpl": "<div class=\"x-grid-cell-text x-btn button\"><img src=\"{public_baseURL}/Core/Images/Thumb/150x150/{id}.jpg\" height=\"150\" width=\"150\"><b>{filename}</b> </div>",
+ "triggerAction": "all",
+ "typeAhead": true,
+ "valueField": "id",
+ "width": 100,
+ "xtype": "ComboBox",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "listeners": {
+ "|beforeload": "function (_self, o){\n o.params = o.params || {};\n\n var id = _this.form.findField('id').getValue() * 1; \n if (!id) {\n Roo.MessageBox.alert(\"Error\", \"Save email template first\");\n return false;\n }\n o.params.onid = id\n o.params.ontable = 'core_mailing_list_message';\n \n // o.params.imgtype = 'PressRelease';\n //o.params['query[imagesize]'] = '150x150';\n // set more here\n}\n"
+ },
+ "*prop": "store",
+ "remoteSort": true,
+ "xtype": "Store",
+ "|sortInfo": "{ direction : 'ASC', field: 'id' }",
+ "|xns": "Roo.data",
+ "items": [
+ {
+ "*prop": "proxy",
+ "xtype": "HttpProxy",
+ "method": "GET",
+ "|xns": "Roo.data",
+ "|url": "baseURL + '/Roo/Images.php'"
+ },
+ {
+ "*prop": "reader",
+ "id": "id",
+ "root": "data",
+ "totalProperty": "total",
+ "xtype": "JsonReader",
+ "|fields": "[{\"name\":\"id\",\"type\":\"int\"},{\"name\":\"filename\",\"type\":\"string\"},{\"name\":\"url_thumb\",\"type\":\"string\"}]",
+ "|xns": "Roo.data"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "listeners": {
+ "render": "function (_self)\n{\n _this.unsubscribeselect = _self;\n}",
+ "select": "function (combo, record, index)\n{\n Roo.log(record);\n (function() { \n combo.setValue('');\n }).defer(100);\n var editor = _this.form.findField('bodytext');\n \n if(record.data.name == 'Unsubscribe'){\n editor.insertAtCursor(\n String.format('<a href=\"{0}\">{1}</a>',\n record.data.type, record.data.name\n )\n );\n return; \n }\n \n editor.insertAtCursor(\n String.format('{0}',\n record.data.type\n )\n );\n \n }"
+ },
+ "*prop": "btns[]",
+ "alwaysQuery": true,
+ "displayField": "name",
+ "editable": false,
+ "emptyText": "Insert Field",
+ "fieldLabel": "Field",
+ "forceSelection": true,
+ "listWidth": 400,
+ "loadingText": "Searching...",
+ "minChars": 2,
+ "pageSize": 20,
+ "qtip": "Insert Field",
+ "selectOnFocus": true,
+ "tpl": "<div class=\"x-grid-cell-text x-btn button\"><b>{name}</b> </div>",
+ "triggerAction": "all",
+ "typeAhead": true,
+ "valueField": "type",
+ "width": 100,
+ "xtype": "ComboBox",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "*prop": "store",
+ "xtype": "SimpleStore",
+ "|data": "[ \n [ '{person.firstname}', \"First Name\"],\n [ '{person.lastname}' , \"Last Name\"],\n [ '{person.name}', \"Full Name\"],\n [ '#unsubscribe', \"Unsubscribe\"]\n]\n",
+ "|fields": "[ 'type', 'name']",
+ "|xns": "Roo.data"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "hideLabels": true,
+ "xtype": "Row",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "listeners": {
+ "click": "function (_self, e)\n{\n var h = _this.form.findField('bodytext').getValue();\n var p = _this.form.findField('plaintext');\n \n new Pman.Request({\r\n url : baseURL + '/Core/ImportMailMessage.php',\r\n method : 'POST',\r\n params : {\n bodytext : h,\r\n _convertToPlain : true,\n _check_unsubscribe : true\r\n }, \r\n success : function(res) {\r\n if(res.success == true){\n p.setValue(res.data);\n }\r\n }\r\n }); \n \n}"
+ },
+ "text": "Convert Html to Text",
+ "xtype": "Button",
+ "|xns": "Roo"
+ }
+ ]
+ },
+ {
+ "hideLabels": true,
+ "xtype": "Row",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "hideLabels": true,
+ "legend": "Plain Text",
+ "style": "text-align:center;",
+ "xtype": "FieldSet",
+ "|xns": "Roo.form",
+ "items": [
+ {
+ "height": 50,
+ "name": "plaintext",
+ "xtype": "TextArea",
+ "|xns": "Roo.form"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "name": "id",
+ "|xns": "Roo.form",
+ "xtype": "Hidden"
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "listeners": {
+ "|activate": "function() {\n _this.ipanel = this;\n if (_this.igrid) {\n _this.igrid.ds.load({});\n }\n}"
+ },
+ "autoScroll": false,
+ "background": false,
+ "fitContainer": true,
+ "fitToframe": true,
+ "region": "east",
+ "tableName": "Images",
+ "title": "Images / Attachments",
+ "xtype": "GridPanel",
+ "|xns": "Roo",
+ "items": [
+ {
+ "listeners": {
+ "|render": "function() \n{\n _this.igrid = this; \n //_this.dialog = Pman.Dialog.FILL_IN\n if (_this.ipanel.active) {\n // _this.igrid.ds.load({});\n }\n}"
+ },
+ "*prop": "grid",
+ "autoExpandColumn": "filename",
+ "loadMask": true,
+ "xtype": "Grid",
+ "|xns": "Roo.grid",
+ "items": [
+ {
+ "listeners": {
+ "beforeload": "function (_self, options)\n{\n options.params = options.params || {};\n if (typeof(_this.data) == 'undefined') {\n return false;\n }\n if(_this.data.id * 1 >= 0)\n {\n options.params.onid = _this.data.id;\n\n options.params.ontable = (_this.data.module) ? _this.data.module + '_mailing_list_message' : 'crm_mailing_list_message';\n }\n}"
+ },
+ "*prop": "dataSource",
+ "remoteSort": true,
+ "xtype": "Store",
+ "|sortInfo": "{ field : 'filename', direction: 'ASC' }",
+ "|xns": "Roo.data",
+ "items": [
+ {
+ "*prop": "proxy",
+ "xtype": "HttpProxy",
+ "method": "GET",
+ "|url": "baseURL + '/Roo/Images.php'",
+ "|xns": "Roo.data"
+ },
+ {
+ "*prop": "reader",
+ "id": "id",
+ "root": "data",
+ "totalProperty": "total",
+ "xtype": "JsonReader",
+ "|fields": "[\n {\n 'name': 'id',\n 'type': 'int'\n },\n {\n 'name': 'filename',\n 'type': 'string'\n },\n {\n 'name': 'ontable',\n 'type': 'string'\n },\n {\n 'name': 'onid',\n 'type': 'int'\n },\n {\n 'name': 'mimetype',\n 'type': 'string'\n },\n {\n 'name': 'width',\n 'type': 'int'\n },\n {\n 'name': 'height',\n 'type': 'int'\n },\n {\n 'name': 'filesize',\n 'type': 'int'\n },\n {\n 'name': 'displayorder',\n 'type': 'int'\n },\n {\n 'name': 'language',\n 'type': 'string'\n },\n {\n 'name': 'parent_image_id',\n 'type': 'int'\n },\n {\n 'name': 'created',\n 'type': 'date',\n 'dateFormat': 'Y-m-d'\n },\n {\n 'name': 'imgtype',\n 'type': 'string'\n },\n {\n 'name': 'linkurl',\n 'type': 'string'\n },\n {\n 'name': 'descript',\n 'type': 'string'\n },\n {\n 'name': 'title',\n 'type': 'string'\n },\n {\n 'name': 'parent_image_id_id',\n 'type': 'int'\n },\n {\n 'name': 'parent_image_id_filename',\n 'type': 'string'\n },\n {\n 'name': 'parent_image_id_ontable',\n 'type': 'string'\n },\n {\n 'name': 'parent_image_id_onid',\n 'type': 'int'\n },\n {\n 'name': 'parent_image_id_mimetype',\n 'type': 'string'\n },\n {\n 'name': 'parent_image_id_width',\n 'type': 'int'\n },\n {\n 'name': 'parent_image_id_height',\n 'type': 'int'\n },\n {\n 'name': 'parent_image_id_filesize',\n 'type': 'int'\n },\n {\n 'name': 'parent_image_id_displayorder',\n 'type': 'int'\n },\n {\n 'name': 'parent_image_id_language',\n 'type': 'string'\n },\n {\n 'name': 'parent_image_id_parent_image_id',\n 'type': 'int'\n },\n {\n 'name': 'parent_image_id_created',\n 'type': 'date'\n },\n {\n 'name': 'parent_image_id_imgtype',\n 'type': 'string'\n },\n {\n 'name': 'parent_image_id_linkurl',\n 'type': 'string'\n },\n {\n 'name': 'parent_image_id_descript',\n 'type': 'string'\n },\n {\n 'name': 'parent_image_id_title',\n 'type': 'string'\n }\n]",
+ "|xns": "Roo.data"
+ }
+ ]
+ },
+ {
+ "*prop": "toolbar",
+ "xtype": "Toolbar",
+ "|xns": "Roo",
+ "items": [
+ {
+ "listeners": {
+ "|click": "function()\n{\n var id = _this.form.findField('id').getValue();\n \n if(id*1 < 1){\n Roo.MessageBox.alert('Error', 'Please save the email template first');\n return;\n }\n \n var ontable = (_this.data.module) ? _this.data.module + '_mailing_list_message' : 'crm_mailing_list_message';\n \n Pman.Dialog.Image.show( { id : 0, onid: id, ontable: ontable }, function() {\n _this.igrid.getDataSource().load({});\n }); \n}\n"
+ },
+ "cls": "x-btn-text-icon",
+ "text": "Add",
+ "xtype": "Button",
+ "|icon": "Roo.rootURL + 'images/default/dd/drop-add.gif'",
+ "|xns": "Roo.Toolbar"
+ },
+ {
+ "listeners": {
+ "|click": "function()\n{\n var s = _this.igrid.getSelectionModel().getSelected();\n if (!s || isNaN(s.id *1)) {\n Roo.MessageBox.alert(\"Error\", \"Select a image\"); \n return;\n }\n Roo.MessageBox.confirm(\"Confirm\", \"Are sure you want to delete this image?\", function (v){\n if (v != 'yes') {\n return;\n }\n \n new Pman.Request({\n url : baseURL + '/Roo/Images.php',\n method: 'POST',\n params : {\n _delete : s.id\n },\n success : function()\n {\n Roo.log('Got Success!!');\n _this.igrid.ds.load({});\n }\n });\n });\n}\n "
+ },
+ "cls": "x-btn-text-icon",
+ "text": "Delete",
+ "xtype": "Button",
+ "|icon": "rootURL + '/Pman/templates/images/trash.gif'",
+ "|xns": "Roo.Toolbar"
+ }
+ ]
+ },
+ {
+ "*prop": "colModel[]",
+ "dataIndex": "filename",
+ "header": "Filename",
+ "width": 300,
+ "xtype": "ColumnModel",
+ "|renderer": "function(v,x,r)\n{\n return '<img src=\"' + baseURL + '/Images/' + r.data.id + '/' + r.data.filename + '\" width=\"' + r.data.width + '\" height=\"' + r.data.height + '\" />';\n}",
+ "|xns": "Roo.grid"
+ },
+ {
+ "xtype": "ColumnModel",
+ "header": "Displayorder",
+ "width": 75,
+ "dataIndex": "displayorder",
+ "|renderer": "function(v) { return String.format('{0}', v); }",
+ "|xns": "Roo.grid",
+ "*prop": "colModel[]"
+ },
+ {
+ "*prop": "colModel[]",
+ "dataIndex": "title",
+ "header": "Title",
+ "width": 75,
+ "xtype": "ColumnModel",
+ "|renderer": "function(v) { return String.format('{0}', v); }",
+ "|xns": "Roo.grid"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "listeners": {
+ "click": "function (_self, e)\n{\n //_this.dialog.hide();\n Roo.log(_this.data.module);\n Pman.Dialog.CoreMailingListMessagePreview.show({ id : _this.form.findField('id').getValue(), module : _this.data.module });\n}",
+ "render": "function (_self)\n{\n _this.preview_btn = _self;\n}"
+ },
+ "*prop": "buttons[]",
+ "text": "Preview",
+ "xtype": "Button",
+ "|xns": "Roo"
+ },
+ {
+ "listeners": {
+ "click": "function (_self, e)\n{\n //_this.dialog.hide();\n \n var id = _this.form.findField('id').getValue();\n \n if(id*1 < 1){\n Roo.MessageBox.alert('Error', 'Please save the message frist!');\n return;\n }\n \n new Pman.Request({\n url : baseURL + '/Crm/MessagePreview',\n method : 'POST',\n mask: 'Sending',\n params : {\n _id : id\n }, \n success : function(res) { \n if(res.data == 'SUCCESS'){\n Roo.MessageBox.alert(\"Email Sent\", 'The report was sent to your email (HTML format).');\n }\n }\n });\n}",
+ "render": "function (_self)\n{\n _this.html_preview = _self;\n}"
+ },
+ "*prop": "buttons[]",
+ "text": "Send me a test copy",
+ "xtype": "Button",
+ "|xns": "Roo"
+ },
+ {
+ "listeners": {
+ "click": "function (_self, e)\n{\n _this.dialog.hide();\n}"
+ },
+ "*prop": "buttons[]",
+ "text": "Cancel",
+ "xtype": "Button",
+ "|xns": "Roo"
+ },
+ {
+ "listeners": {
+ "click": "function (_self, e)\n{\n // do some checks?\n _this.form.preValidate(function(res) {\n if (!res) {\n return; //failed.\n }\n _this.form.doAction(\"submit\");\n });\n\n}"
+ },
+ "*prop": "buttons[]",
+ "text": "Save",
+ "xtype": "Button",
+ "|xns": "Roo"
+ }
+ ]
+ }
+ ],
"permname": "",
"modOrder": "001"
}
\ No newline at end of file
-0
\ No newline at end of file
+//<script type="text/javascript">
+
+// Auto generated file - created by app.Builder.js- do not edit directly (at present!)
+
+Pman.Dialog.CoreEmail = {
+
+ dialog : false,
+ callback: false,
+
+ show : function(data, cb)
+ {
+ if (!this.dialog) {
+ this.create();
+ }
+
+ this.callback = cb;
+ this.data = data;
+ this.dialog.show(this.data._el);
+ if (this.form) {
+ this.form.reset();
+ this.form.setValues(data);
+ this.form.fireEvent('actioncomplete', this.form, { type: 'setdata', data: data });
+ }
+
+ },
+
+ create : function()
+ {
+ var _this = this;
+ this.dialog = Roo.factory({
+ xtype: 'LayoutDialog',
+ xns: Roo,
+ listeners : {
+ show : function (_self)
+ {
+
+ _self.layout.getRegion('center').showPanel(0);
+ var w = Roo.lib.Dom.getViewWidth();\r
+ var h = Roo.lib.Dom.getViewHeight(); \r this.resizeTo(w-50, h-50);\r
+ this.center();\r
+ var ew = Math.max(250, w-320);\r
+ var eh = Math.max(250, h-350) ;\r
+ var e = _this.dialog.layout.getRegion('east');
+ if (e.visible) {
+ e.hide();
+ }
+
+ var el = _self.getEl();
+ var elw = el.dom.clientWidth;
+
+ var bdtext = _this.form.findField('bodytext');
+ var ptext = _this.form.findField('plaintext');
+ if(bdtext.resizeEl){
+ bdtext.width = elw-100;
+ bdtext.resizeEl.resizeTo.defer(110, bdtext.resizeEl,[ bdtext.width, bdtext.height ] );
+ ptext.setSize(bdtext.width , bdtext.height);
+ }
+
+ }
+ },
+ closable : true,
+ collapsible : false,
+ height : 500,
+ modal : true,
+ resizable : true,
+ title : "Edit / Create Message",
+ width : 800,
+ items : [
+ {
+ xtype: 'NestedLayoutPanel',
+ xns: Roo,
+ autoScroll : false,
+ fitContainer : true,
+ fitToFrame : true,
+ region : 'center',
+ toolbar : {
+ xtype: 'Toolbar',
+ xns: Roo,
+ items : [
+ {
+ xtype: 'Button',
+ xns: Roo.Toolbar,
+ text : "Import",
+ menu : {
+ xtype: 'Menu',
+ xns: Roo.menu,
+ items : [
+ {
+ xtype: 'Item',
+ xns: Roo.menu,
+ listeners : {
+ click : function (_self, e)
+ {
+ Pman.Dialog.CoreImportUrl.show({
+ target : '/Core/ImportMailMessage.php'
+ }, function(data) {
+ if (data) {
+ // Roo.log(data);
+ _this.form.findField('bodytext').setValue(data);
+ }
+ });
+ }
+ },
+ text : "URL"
+ },
+ {
+ xtype: 'Item',
+ xns: Roo.menu,
+ listeners : {
+ click : function (_self, e)
+ {
+ Pman.Dialog.Image.show({
+ _url : baseURL + '/Core/ImportMailMessage.php'
+ }, function(data) {
+ if (data) {
+ _this.form.findField('bodytext').setValue(data);
+ }
+ });
+ }
+ },
+ text : "Html File"
+ }
+ ]
+ }
+ },
+ {
+ xtype: 'Button',
+ xns: Roo.Toolbar,
+ text : "Use template",
+ menu : {
+ xtype: 'Menu',
+ xns: Roo.menu,
+ items : [
+ {
+ xtype: 'Item',
+ xns: Roo.menu,
+ listeners : {
+ click : function (_self, e)
+ {
+
+ var l = document.location;
+ new Pman.Request({
+
+ url : baseURL + '/Core/ImportMailMessage.php',
+
+ method: 'POST',
+ mask : "Loading",
+ params : {
+ importUrl : l.protocol +'//' + l.host + rootURL + '/Pman/Crm/mail_templates/responsive1.html',
+ },
+ success : function (res) {
+
+ _this.form.findField('bodytext').setValue(res.data);
+ }
+
+ });
+ }
+ },
+ text : "Responsive Email (1)"
+ }
+ ]
+ }
+ },
+ {
+ xtype: 'ComboBox',
+ xns: Roo.form,
+ listeners : {
+ select : function (combo, record, index)
+ {
+
+ /*
+ (function() {
+ combo.setValue('');
+ }).defer(100);
+ */
+ if(!record){
+ return;
+ }
+ _this.form.findField('bodytext').setValue(record.data.content);
+
+ }
+ },
+ allowBlank : true,
+ alwaysQuery : true,
+ displayField : 'file',
+ editable : false,
+ emptyText : "Select Template",
+ fieldLabel : 'Template',
+ forceSelection : true,
+ hiddenName : 'template',
+ listWidth : 400,
+ loadingText : "Searching...",
+ minChars : 2,
+ name : 'template',
+ pageSize : 20,
+ qtip : "Select Template",
+ selectOnFocus : true,
+ tpl : '<div class="x-grid-cell-text x-btn button"><b>{file}</b> </div>',
+ triggerAction : 'all',
+ typeAhead : true,
+ valueField : 'file',
+ width : 200,
+ store : {
+ xtype: 'Store',
+ xns: Roo.data,
+ listeners : {
+ beforeload : function (_self, o){
+ o.params = o.params || {};
+ // set more here
+
+ }
+ },
+ remoteSort : true,
+ sortInfo : { direction : 'DESC', field: 'file' },
+ proxy : {
+ xtype: 'HttpProxy',
+ xns: Roo.data,
+ method : 'GET',
+ url : baseURL + '/Core/MailTemplateList.php'
+ },
+ reader : {
+ xtype: 'JsonReader',
+ xns: Roo.data,
+ id : 'name',
+ root : 'data',
+ totalProperty : 'total',
+ fields : [{"name":"file","type":"string"},{"name":"content","type":"string"}]
+ }
+ }
+ },
+ {
+ xtype: 'Fill',
+ xns: Roo.Toolbar
+ },
+ {
+ xtype: 'Button',
+ xns: Roo.Toolbar,
+ listeners : {
+ click : function (_self, e)
+ {
+ var el = _this.dialog.layout.getRegion('east');
+ if (el.visible) {
+ el.hide();
+ } else {
+ el.show();
+ el.showPanel(0);
+ }
+
+ }
+ },
+ text : "Images / Attachments >>"
+ }
+ ]
+ },
+ layout : {
+ xtype: 'BorderLayout',
+ xns: Roo,
+ items : [
+ {
+ xtype: 'ContentPanel',
+ xns: Roo,
+ listeners : {
+ render : function (_self, width, height)
+ {
+
+ Roo.log("RESIZE, " + width + ',' + height);
+
+ var ew = Math.max(250, width-50);
+ var eh = Math.max(250,height-50) ;
+
+
+
+ },
+ resize : function (_self, width, height)\r
+ {\r
+ var ew = Math.max(250, width-50);\r
+ var eh = Math.max(250,height-50) ;
+
+ if (!_this.form) {\r
+ return;\r
+ }\r
+ var bdtext = _this.form.findField('bodytext');\r
+ var ptext = _this.form.findField('plaintext');\r
+ if(bdtext.resizeEl){\r
+ bdtext.width = ew-50;\r
+ bdtext.resizeEl.resizeTo.defer(110, bdtext.resizeEl,[ bdtext.width, bdtext.height ] );\r
+ ptext.setSize(bdtext.width , bdtext.height);\r
+ }\r\r
+ \r
+ }
+ },
+ autoScroll : false,
+ background : false,
+ fitContainer : true,
+ fitToFrame : true,
+ region : 'center',
+ title : "Message",
+ items : [
+ {
+ xtype: 'Form',
+ xns: Roo.form,
+ listeners : {
+ actioncomplete : function(_self,action)
+ {
+
+ if (action.type == 'setdata') {
+
+ _this.data.module = _this.data.module || 'crm';
+
+ _this.form.url = baseURL + '/Roo/' + _this.data.module + '_mailing_list_message.php';
+
+ _this.html_preview.hide();
+ _this.preview_btn.hide();
+
+ if(_this.data.id*1 > 0){
+ _this.dialog.el.mask("Loading");
+ this.load({ method: 'GET', params: { '_id' : _this.data.id }});
+ if(_this.data.module == 'crm'){
+ _this.html_preview.show();
+ }
+ _this.preview_btn.show();
+
+ } else {
+ _this.form.setValues({
+ 'from_name' : Pman.Login.authUser.name,
+ 'from_email' : Pman.Login.authUser.email
+ });
+ }
+ return;
+ }
+ if (action.type == 'load') {
+ _this.dialog.el.unmask();
+ return;
+ }
+ if (action.type =='submit') {
+
+ _this.dialog.el.unmask();
+ _this.dialog.hide();
+
+ if (_this.callback) {
+ _this.callback.call(_this, action.result.data);
+ }
+ _this.form.reset();
+ return;
+ }
+ },
+ rendered : function (form)
+ {
+ _this.form= form;
+ }
+ },
+ labelAlign : 'right',
+ labelWidth : 120,
+ method : 'POST',
+ style : 'margin:10px',
+ preValidate : function(done_callback) {
+
+ Roo.MessageBox.progress("Uploading Images", "Uploading");
+ var html = _this.form.findField('bodytext').getValue();
+
+ var s = Roo.get(_this.form.findField('bodytext').doc.documentElement);
+
+ var ontable = (_this.data.module) ? _this.data.module + '_mailing_list_message' : 'crm_mailing_list_message';
+
+ var nodes = [];
+ s.select('img[src]').each(function(i) {
+ nodes.push(i.dom);
+ });
+ var total = nodes.length;
+ var mkimg = function() {
+
+ if (!nodes.length) {
+ Roo.MessageBox.hide();
+ _this.form.findField('bodytext').syncValue();
+ done_callback(true);
+ // _this.form.doAction("submit");
+ return;
+ }
+ var i = nodes.pop();
+ var n = i.getAttribute('src').match(/^http(.*)/);
+ if(!n ){
+ mkimg();
+ return;
+ }
+
+ new Pman.Request({
+ url : baseURL + '/Roo/Images.php',
+ method : 'POST',
+ params : {
+ onid : _this.form.findField('id').getValue(),
+ ontable : ontable ,
+ _remote_upload : i.src
+ },
+ success : function(res){
+ if(res.success == true){
+ i.setAttribute('src', res.data);
+ Roo.MessageBox.updateProgress( (total - nodes.length) / total , "Done " + (total - nodes.length) + '/' + total);
+ }
+ mkimg();
+ }
+ });
+
+ }
+ mkimg();
+ },
+ url : baseURL + '/Roo/Core_mailing_list_message.php',
+ items : [
+ {
+ xtype: 'Row',
+ xns: Roo.form,
+ items : [
+ {
+ xtype: 'TextField',
+ xns: Roo.form,
+ allowBlank : false,
+ fieldLabel : 'Mailout Name',
+ name : 'name',
+ width : 400
+ }
+ ]
+ },
+ {
+ xtype: 'Row',
+ xns: Roo.form,
+ items : [
+ {
+ xtype: 'TextField',
+ xns: Roo.form,
+ allowBlank : false,
+ fieldLabel : 'From',
+ name : 'from_name',
+ width : 300
+ },
+ {
+ xtype: 'TextField',
+ xns: Roo.form,
+ allowBlank : false,
+ fieldLabel : 'Email address',
+ name : 'from_email',
+ width : 300
+ }
+ ]
+ },
+ {
+ xtype: 'TextField',
+ xns: Roo.form,
+ allowBlank : false,
+ fieldLabel : 'Subject',
+ name : 'subject',
+ width : 600
+ },
+ {
+ xtype: 'Row',
+ xns: Roo.form,
+ hideLabels : true,
+ items : [
+ {
+ xtype: 'FieldSet',
+ xns: Roo.form,
+ hideLabels : true,
+ legend : "Html Editor",
+ style : 'text-align:center;',
+ items : [
+ {
+ xtype: 'HtmlEditor',
+ xns: Roo.form,
+ height : 250,
+ name : 'bodytext',
+ resizable : 's',
+ cwhite : [
+ 'margin',
+ 'padding',
+ 'text-align',
+ 'background',
+ 'height',
+ 'width',
+ 'background-color',
+ 'font-size',
+ 'line-height',
+ 'color',
+ 'outline',
+ 'text-decoration',
+ 'position',
+ 'clear',
+ 'overflow',
+ 'margin-top',
+ 'border-bottom',
+ 'top',
+ 'list-style',
+ 'margin-left',
+ 'border',
+ 'float' ,
+ 'margin-right',
+ 'padding-top',
+ 'min-height',
+ 'left',
+ 'padding-left',
+ 'font-weight',
+ 'font-family',
+ 'display',
+ 'margin-bottom',
+ 'padding-bottom',
+ 'vertical-align',
+ 'cursor',
+ 'z-index',
+ 'right',
+ ],
+ toolbars : [
+ {
+ xtype: 'ToolbarContext',
+ xns: Roo.form.HtmlEditor
+ },
+ {
+ xtype: 'ToolbarStandard',
+ xns: Roo.form.HtmlEditor,
+ btns : [
+ {
+ xtype: 'ComboBox',
+ xns: Roo.form,
+ listeners : {
+ render : function (_self)
+ {
+ _this.extendimgselect = _self;
+ },
+ select : function (combo, record, index)
+ {
+ Roo.log(record);
+ (function() {
+ combo.setValue('');
+ }).defer(100);
+ var editor = _this.form.findField('bodytext');
+ editor.insertAtCursor(
+ String.format('<img src="{0}/Images/{1}/{2}#image-{1}">',
+ baseURL, record.data.id, record.data.filename
+ )
+ );
+
+
+ },
+ beforequery : function (combo, query, forceAll, cancel, e)
+ {
+ var id = _this.form.findField('id').getValue() * 1;
+ if (!id) {
+ Roo.MessageBox.alert("Error", "Save message first");
+ return false;
+ }
+ }
+ },
+ alwaysQuery : true,
+ displayField : 'name',
+ editable : false,
+ emptyText : "Add Image",
+ fieldLabel : 'Images',
+ forceSelection : true,
+ listWidth : 400,
+ loadingText : "Searching...",
+ minChars : 2,
+ pageSize : 20,
+ qtip : "Select Images",
+ selectOnFocus : true,
+ tpl : '<div class="x-grid-cell-text x-btn button"><img src="{public_baseURL}/Core/Images/Thumb/150x150/{id}.jpg" height="150" width="150"><b>{filename}</b> </div>',
+ triggerAction : 'all',
+ typeAhead : true,
+ valueField : 'id',
+ width : 100,
+ store : {
+ xtype: 'Store',
+ xns: Roo.data,
+ listeners : {
+ beforeload : function (_self, o){
+ o.params = o.params || {};
+
+ var id = _this.form.findField('id').getValue() * 1;
+ if (!id) {
+ Roo.MessageBox.alert("Error", "Save email template first");
+ return false;
+ }
+ o.params.onid = id
+ o.params.ontable = 'core_mailing_list_message';
+
+ // o.params.imgtype = 'PressRelease';
+ //o.params['query[imagesize]'] = '150x150';
+ // set more here
+ }
+ },
+ remoteSort : true,
+ sortInfo : { direction : 'ASC', field: 'id' },
+ proxy : {
+ xtype: 'HttpProxy',
+ xns: Roo.data,
+ method : 'GET',
+ url : baseURL + '/Roo/Images.php'
+ },
+ reader : {
+ xtype: 'JsonReader',
+ xns: Roo.data,
+ id : 'id',
+ root : 'data',
+ totalProperty : 'total',
+ fields : [{"name":"id","type":"int"},{"name":"filename","type":"string"},{"name":"url_thumb","type":"string"}]
+ }
+ }
+ },
+ {
+ xtype: 'ComboBox',
+ xns: Roo.form,
+ listeners : {
+ render : function (_self)
+ {
+ _this.unsubscribeselect = _self;
+ },
+ select : function (combo, record, index)
+ {
+ Roo.log(record);
+ (function() {
+ combo.setValue('');
+ }).defer(100);
+ var editor = _this.form.findField('bodytext');
+
+ if(record.data.name == 'Unsubscribe'){
+ editor.insertAtCursor(
+ String.format('<a href="{0}">{1}</a>',
+ record.data.type, record.data.name
+ )
+ );
+ return;
+ }
+
+ editor.insertAtCursor(
+ String.format('{0}',
+ record.data.type
+ )
+ );
+
+ }
+ },
+ alwaysQuery : true,
+ displayField : 'name',
+ editable : false,
+ emptyText : "Insert Field",
+ fieldLabel : 'Field',
+ forceSelection : true,
+ listWidth : 400,
+ loadingText : "Searching...",
+ minChars : 2,
+ pageSize : 20,
+ qtip : "Insert Field",
+ selectOnFocus : true,
+ tpl : '<div class="x-grid-cell-text x-btn button"><b>{name}</b> </div>',
+ triggerAction : 'all',
+ typeAhead : true,
+ valueField : 'type',
+ width : 100,
+ store : {
+ xtype: 'SimpleStore',
+ xns: Roo.data,
+ data : [
+ [ '{person.firstname}', "First Name"],
+ [ '{person.lastname}' , "Last Name"],
+ [ '{person.name}', "Full Name"],
+ [ '#unsubscribe', "Unsubscribe"]
+ ],
+ fields : [ 'type', 'name']
+ }
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ }
+ ]
+ },
+ {
+ xtype: 'Row',
+ xns: Roo.form,
+ hideLabels : true,
+ items : [
+ {
+ xtype: 'Button',
+ xns: Roo,
+ listeners : {
+ click : function (_self, e)
+ {
+ var h = _this.form.findField('bodytext').getValue();
+ var p = _this.form.findField('plaintext');
+
+ new Pman.Request({\r
+ url : baseURL + '/Core/ImportMailMessage.php',\r
+ method : 'POST',\r
+ params : {
+ bodytext : h,\r
+ _convertToPlain : true,
+ _check_unsubscribe : true\r
+ }, \r
+ success : function(res) {\r
+ if(res.success == true){
+ p.setValue(res.data);
+ }\r
+ }\r
+ });
+
+ }
+ },
+ text : "Convert Html to Text"
+ }
+ ]
+ },
+ {
+ xtype: 'Row',
+ xns: Roo.form,
+ hideLabels : true,
+ items : [
+ {
+ xtype: 'FieldSet',
+ xns: Roo.form,
+ hideLabels : true,
+ legend : "Plain Text",
+ style : 'text-align:center;',
+ items : [
+ {
+ xtype: 'TextArea',
+ xns: Roo.form,
+ height : 50,
+ name : 'plaintext'
+ }
+ ]
+ }
+ ]
+ },
+ {
+ xtype: 'Hidden',
+ xns: Roo.form,
+ name : 'id'
+ }
+ ]
+ }
+ ]
+ }
+ ],
+ center : {
+ xtype: 'LayoutRegion',
+ xns: Roo,
+ autoScroll : true
+ }
+ }
+ },
+ {
+ xtype: 'GridPanel',
+ xns: Roo,
+ listeners : {
+ activate : function() {
+ _this.ipanel = this;
+ if (_this.igrid) {
+ _this.igrid.ds.load({});
+ }
+ }
+ },
+ autoScroll : false,
+ background : false,
+ fitContainer : true,
+ fitToframe : true,
+ region : 'east',
+ tableName : 'Images',
+ title : "Images / Attachments",
+ grid : {
+ xtype: 'Grid',
+ xns: Roo.grid,
+ listeners : {
+ render : function()
+ {
+ _this.igrid = this;
+ //_this.dialog = Pman.Dialog.FILL_IN
+ if (_this.ipanel.active) {
+ // _this.igrid.ds.load({});
+ }
+ }
+ },
+ autoExpandColumn : 'filename',
+ loadMask : true,
+ dataSource : {
+ xtype: 'Store',
+ xns: Roo.data,
+ listeners : {
+ beforeload : function (_self, options)
+ {
+ options.params = options.params || {};
+ if (typeof(_this.data) == 'undefined') {
+ return false;
+ }
+ if(_this.data.id * 1 >= 0)
+ {
+ options.params.onid = _this.data.id;
+
+ options.params.ontable = (_this.data.module) ? _this.data.module + '_mailing_list_message' : 'crm_mailing_list_message';
+ }
+ }
+ },
+ remoteSort : true,
+ sortInfo : { field : 'filename', direction: 'ASC' },
+ proxy : {
+ xtype: 'HttpProxy',
+ xns: Roo.data,
+ method : 'GET',
+ url : baseURL + '/Roo/Images.php'
+ },
+ reader : {
+ xtype: 'JsonReader',
+ xns: Roo.data,
+ id : 'id',
+ root : 'data',
+ totalProperty : 'total',
+ fields : [
+ {
+ 'name': 'id',
+ 'type': 'int'
+ },
+ {
+ 'name': 'filename',
+ 'type': 'string'
+ },
+ {
+ 'name': 'ontable',
+ 'type': 'string'
+ },
+ {
+ 'name': 'onid',
+ 'type': 'int'
+ },
+ {
+ 'name': 'mimetype',
+ 'type': 'string'
+ },
+ {
+ 'name': 'width',
+ 'type': 'int'
+ },
+ {
+ 'name': 'height',
+ 'type': 'int'
+ },
+ {
+ 'name': 'filesize',
+ 'type': 'int'
+ },
+ {
+ 'name': 'displayorder',
+ 'type': 'int'
+ },
+ {
+ 'name': 'language',
+ 'type': 'string'
+ },
+ {
+ 'name': 'parent_image_id',
+ 'type': 'int'
+ },
+ {
+ 'name': 'created',
+ 'type': 'date',
+ 'dateFormat': 'Y-m-d'
+ },
+ {
+ 'name': 'imgtype',
+ 'type': 'string'
+ },
+ {
+ 'name': 'linkurl',
+ 'type': 'string'
+ },
+ {
+ 'name': 'descript',
+ 'type': 'string'
+ },
+ {
+ 'name': 'title',
+ 'type': 'string'
+ },
+ {
+ 'name': 'parent_image_id_id',
+ 'type': 'int'
+ },
+ {
+ 'name': 'parent_image_id_filename',
+ 'type': 'string'
+ },
+ {
+ 'name': 'parent_image_id_ontable',
+ 'type': 'string'
+ },
+ {
+ 'name': 'parent_image_id_onid',
+ 'type': 'int'
+ },
+ {
+ 'name': 'parent_image_id_mimetype',
+ 'type': 'string'
+ },
+ {
+ 'name': 'parent_image_id_width',
+ 'type': 'int'
+ },
+ {
+ 'name': 'parent_image_id_height',
+ 'type': 'int'
+ },
+ {
+ 'name': 'parent_image_id_filesize',
+ 'type': 'int'
+ },
+ {
+ 'name': 'parent_image_id_displayorder',
+ 'type': 'int'
+ },
+ {
+ 'name': 'parent_image_id_language',
+ 'type': 'string'
+ },
+ {
+ 'name': 'parent_image_id_parent_image_id',
+ 'type': 'int'
+ },
+ {
+ 'name': 'parent_image_id_created',
+ 'type': 'date'
+ },
+ {
+ 'name': 'parent_image_id_imgtype',
+ 'type': 'string'
+ },
+ {
+ 'name': 'parent_image_id_linkurl',
+ 'type': 'string'
+ },
+ {
+ 'name': 'parent_image_id_descript',
+ 'type': 'string'
+ },
+ {
+ 'name': 'parent_image_id_title',
+ 'type': 'string'
+ }
+ ]
+ }
+ },
+ toolbar : {
+ xtype: 'Toolbar',
+ xns: Roo,
+ items : [
+ {
+ xtype: 'Button',
+ xns: Roo.Toolbar,
+ listeners : {
+ click : function()
+ {
+ var id = _this.form.findField('id').getValue();
+
+ if(id*1 < 1){
+ Roo.MessageBox.alert('Error', 'Please save the email template first');
+ return;
+ }
+
+ var ontable = (_this.data.module) ? _this.data.module + '_mailing_list_message' : 'crm_mailing_list_message';
+
+ Pman.Dialog.Image.show( { id : 0, onid: id, ontable: ontable }, function() {
+ _this.igrid.getDataSource().load({});
+ });
+ }
+ },
+ cls : 'x-btn-text-icon',
+ text : "Add",
+ icon : Roo.rootURL + 'images/default/dd/drop-add.gif'
+ },
+ {
+ xtype: 'Button',
+ xns: Roo.Toolbar,
+ listeners : {
+ click : function()
+ {
+ var s = _this.igrid.getSelectionModel().getSelected();
+ if (!s || isNaN(s.id *1)) {
+ Roo.MessageBox.alert("Error", "Select a image");
+ return;
+ }
+ Roo.MessageBox.confirm("Confirm", "Are sure you want to delete this image?", function (v){
+ if (v != 'yes') {
+ return;
+ }
+
+ new Pman.Request({
+ url : baseURL + '/Roo/Images.php',
+ method: 'POST',
+ params : {
+ _delete : s.id
+ },
+ success : function()
+ {
+ Roo.log('Got Success!!');
+ _this.igrid.ds.load({});
+ }
+ });
+ });
+ }
+ },
+ cls : 'x-btn-text-icon',
+ text : "Delete",
+ icon : rootURL + '/Pman/templates/images/trash.gif'
+ }
+ ]
+ },
+ colModel : [
+ {
+ xtype: 'ColumnModel',
+ xns: Roo.grid,
+ dataIndex : 'filename',
+ header : 'Filename',
+ width : 300,
+ renderer : function(v,x,r)
+ {
+ return '<img src="' + baseURL + '/Images/' + r.data.id + '/' + r.data.filename + '" width="' + r.data.width + '" height="' + r.data.height + '" />';
+ }
+ },
+ {
+ xtype: 'ColumnModel',
+ xns: Roo.grid,
+ header : 'Displayorder',
+ width : 75,
+ dataIndex : 'displayorder',
+ renderer : function(v) { return String.format('{0}', v); }
+ },
+ {
+ xtype: 'ColumnModel',
+ xns: Roo.grid,
+ dataIndex : 'title',
+ header : 'Title',
+ width : 75,
+ renderer : function(v) { return String.format('{0}', v); }
+ }
+ ]
+ }
+ }
+ ],
+ center : {
+ xtype: 'LayoutRegion',
+ xns: Roo,
+ tabPosition : 'top'
+ },
+ east : {
+ xtype: 'LayoutRegion',
+ xns: Roo,
+ hidden : true,
+ split : true,
+ title : "Images / Attachments",
+ titlebar : true,
+ width : 500
+ },
+ buttons : [
+ {
+ xtype: 'Button',
+ xns: Roo,
+ listeners : {
+ click : function (_self, e)
+ {
+ //_this.dialog.hide();
+ Roo.log(_this.data.module);
+ Pman.Dialog.CoreMailingListMessagePreview.show({ id : _this.form.findField('id').getValue(), module : _this.data.module });
+ },
+ render : function (_self)
+ {
+ _this.preview_btn = _self;
+ }
+ },
+ text : "Preview"
+ },
+ {
+ xtype: 'Button',
+ xns: Roo,
+ listeners : {
+ click : function (_self, e)
+ {
+ //_this.dialog.hide();
+
+ var id = _this.form.findField('id').getValue();
+
+ if(id*1 < 1){
+ Roo.MessageBox.alert('Error', 'Please save the message frist!');
+ return;
+ }
+
+ new Pman.Request({
+ url : baseURL + '/Crm/MessagePreview',
+ method : 'POST',
+ mask: 'Sending',
+ params : {
+ _id : id
+ },
+ success : function(res) {
+ if(res.data == 'SUCCESS'){
+ Roo.MessageBox.alert("Email Sent", 'The report was sent to your email (HTML format).');
+ }
+ }
+ });
+ },
+ render : function (_self)
+ {
+ _this.html_preview = _self;
+ }
+ },
+ text : "Send me a test copy"
+ },
+ {
+ xtype: 'Button',
+ xns: Roo,
+ listeners : {
+ click : function (_self, e)
+ {
+ _this.dialog.hide();
+ }
+ },
+ text : "Cancel"
+ },
+ {
+ xtype: 'Button',
+ xns: Roo,
+ listeners : {
+ click : function (_self, e)
+ {
+ // do some checks?
+ _this.form.preValidate(function(res) {
+ if (!res) {
+ return; //failed.
+ }
+ _this.form.doAction("submit");
+ });
+
+ }
+ },
+ text : "Save"
+ }
+ ]
+ });
+ }
+};