coalla-cms 0.4.4.3 → 0.5.1.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (121) hide show
  1. checksums.yaml +5 -13
  2. data/Gemfile.lock +91 -84
  3. data/Rakefile +2 -2
  4. data/app/assets/javascripts/admin/admin.js +45 -117
  5. data/app/assets/javascripts/admin/photo_uploader.js +1 -10
  6. data/app/assets/javascripts/admin/vendor/jquery-ui-timepicker-addon-ru.js +39 -37
  7. data/app/assets/stylesheets/admin/admin.scss +5 -1
  8. data/app/controllers/admin/image_upload_controller.rb +1 -1
  9. data/app/controllers/admin/lookups_controller.rb +9 -4
  10. data/app/controllers/admin/notifier_controller.rb +7 -0
  11. data/app/controllers/admin/site_meta_tags_controller.rb +43 -0
  12. data/app/controllers/concerns/page_meta_tags.rb +71 -0
  13. data/app/helpers/admin/lookup_helper.rb +23 -0
  14. data/app/helpers/common_helper.rb +6 -0
  15. data/app/helpers/lookup_helper.rb +41 -14
  16. data/app/helpers/twitter_builder_helper.rb +7 -7
  17. data/app/helpers/twitter_form_builder.rb +9 -3
  18. data/app/models/lookup.rb +22 -0
  19. data/app/models/site_meta_tags.rb +16 -0
  20. data/app/uploaders/meta_tags_image_uploader.rb +5 -0
  21. data/app/utils/admin_structure.rb +17 -2
  22. data/app/views/admin/base/_sort.haml +3 -3
  23. data/app/views/admin/common/_file_upload_template.haml +8 -4
  24. data/app/views/admin/common/_header.html.haml +5 -4
  25. data/app/views/admin/common/_image_upload_template.html.haml +1 -1
  26. data/app/views/admin/common/_slides.html.haml +1 -1
  27. data/app/views/admin/home/dashboard.html.haml +1 -1
  28. data/app/views/admin/lookups/_form.html.haml +2 -8
  29. data/app/views/admin/lookups/edit.html.haml +1 -1
  30. data/app/views/admin/lookups/index.html.haml +2 -2
  31. data/app/views/admin/lookups/types/_boolean.haml +1 -0
  32. data/app/views/admin/lookups/types/_enum.haml +1 -0
  33. data/app/views/admin/lookups/types/_file.haml +3 -0
  34. data/app/views/admin/lookups/types/_float.haml +1 -0
  35. data/app/views/admin/lookups/types/_integer.haml +1 -0
  36. data/app/views/admin/lookups/types/_memo.haml +1 -0
  37. data/app/views/admin/lookups/types/_string.haml +1 -0
  38. data/app/views/admin/lookups/types/_wysiwyg.haml +1 -0
  39. data/app/views/admin/site_meta_tags/_form.html.haml +22 -0
  40. data/app/views/admin/site_meta_tags/edit.html.haml +5 -0
  41. data/app/views/admin/site_meta_tags/index.html.haml +5 -0
  42. data/app/views/layouts/admin.html.haml +10 -4
  43. data/app/views/structure/_section.haml +2 -1
  44. data/coalla-cms.gemspec +2 -0
  45. data/lib/coalla/cms/version.rb +1 -1
  46. data/lib/coalla/orm/page_slider.rb +3 -1
  47. data/lib/coalla/orm/relation.rb +7 -4
  48. data/lib/generators/coalla/cms/create_admin_administrators_generator.rb +29 -0
  49. data/lib/generators/coalla/cms/create_markup_generator.rb +30 -0
  50. data/lib/generators/coalla/cms/init_generator.rb +33 -37
  51. data/lib/generators/coalla/cms/lookups/install_generator.rb +17 -6
  52. data/lib/generators/coalla/cms/lookups/templates/migration.rb +4 -0
  53. data/lib/generators/coalla/cms/market/templates/controllers/products_controller.rb +1 -1
  54. data/lib/generators/coalla/cms/market/templates/controllers/properties_controller.rb +1 -1
  55. data/lib/generators/coalla/cms/meta_tags/install_generator.rb +58 -0
  56. data/lib/generators/coalla/cms/meta_tags/templates/migration.rb +23 -0
  57. data/lib/generators/coalla/cms/news/templates/views/new.haml.erb +1 -1
  58. data/lib/generators/coalla/cms/setup_admin_generator.rb +10 -7
  59. data/lib/generators/coalla/cms/setup_routes_generator.rb +1 -0
  60. data/lib/generators/coalla/cms/templates/assets.rb +2 -4
  61. data/lib/generators/coalla/cms/templates/controllers/admin/administrators_controller.rb +55 -0
  62. data/lib/generators/coalla/cms/templates/controllers/admin/base_controller.rb.erb +2 -2
  63. data/lib/generators/coalla/cms/templates/controllers/markup_controller.rb.erb +2 -0
  64. data/lib/generators/coalla/cms/templates/initializers/carrierwave.rb +47 -0
  65. data/lib/generators/coalla/cms/templates/locales/activerecord.en.yml +16 -0
  66. data/lib/generators/coalla/cms/templates/locales/activerecord.ru.yml +29 -0
  67. data/lib/generators/coalla/cms/templates/locales/admin.en.yml +27 -0
  68. data/lib/generators/coalla/cms/templates/locales/admin.ru.yml +27 -0
  69. data/lib/generators/coalla/cms/templates/views/admin/administrators/_form.html.haml +9 -0
  70. data/lib/generators/coalla/cms/templates/views/admin/administrators/edit.html.haml +5 -0
  71. data/lib/generators/coalla/cms/templates/views/admin/administrators/index.html.haml +15 -0
  72. data/lib/generators/coalla/cms/templates/views/admin/administrators/new.html.haml +4 -0
  73. data/lib/generators/coalla/cms/templates/views/admin/scaffold_template/edit.html.haml.erb +1 -1
  74. data/lib/generators/coalla/cms/templates/views/admin/scaffold_template/new.html.haml.erb +1 -1
  75. data/lib/generators/coalla/cms/templates/views/administrators/sessions/new.html.haml +3 -3
  76. metadata +102 -87
  77. data/lib/generators/coalla/cms/templates/activerecord.ru.yml +0 -13
  78. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/lbl-blockquote.png +0 -0
  79. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/lbl-h1.png +0 -0
  80. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/lbl-h2.png +0 -0
  81. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/lbl-h3.png +0 -0
  82. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/lbl-h4.png +0 -0
  83. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/lbl-h5.png +0 -0
  84. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/lbl-h6.png +0 -0
  85. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/lbl-p.png +0 -0
  86. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/lbl-pre.png +0 -0
  87. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/wymiframe.css +0 -276
  88. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/iframe/default/wymiframe.html +0 -26
  89. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/jquery.wymeditor.js +0 -4819
  90. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/lang/en.js +0 -45
  91. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/lang/ru.js +0 -55
  92. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/plugins/imageupload/icons.png +0 -0
  93. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/plugins/imageupload/jquery.wymeditor.imageupload.js +0 -150
  94. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/plugins/resizable/jquery.wymeditor.resizable.js +0 -91
  95. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/plugins/resizable/readme.txt +0 -124
  96. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/compact/icons.png +0 -0
  97. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/compact/skin.css +0 -134
  98. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/compact/skin.js +0 -35
  99. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/default/icons.png +0 -0
  100. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/default/skin.css +0 -341
  101. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/default/skin.js +0 -40
  102. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/minimal/images/bg.header.gif +0 -0
  103. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/minimal/images/bg.selector.silver.gif +0 -0
  104. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/minimal/images/bg.wymeditor.png +0 -0
  105. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/minimal/images/icons.silver.gif +0 -0
  106. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/minimal/skin.css +0 -131
  107. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/minimal/skin.js +0 -30
  108. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/silver/COPYING +0 -674
  109. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/silver/README +0 -27
  110. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/silver/images/bg.header.gif +0 -0
  111. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/silver/images/bg.selector.silver.gif +0 -0
  112. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/silver/images/bg.wymeditor.png +0 -0
  113. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/silver/images/icons.silver.gif +0 -0
  114. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/silver/skin.css +0 -297
  115. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/silver/skin.js +0 -61
  116. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/twopanels/icons.png +0 -0
  117. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/twopanels/skin.css +0 -134
  118. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/twopanels/skin.js +0 -39
  119. data/lib/generators/coalla/cms/wysiwyg/templates/wymeditor/skins/wymeditor_icon.png +0 -0
  120. data/lib/generators/coalla/cms/wysiwyg/wymeditor_generator.rb +0 -17
  121. /data/lib/generators/coalla/cms/templates/{devise.ru.yml → locales/devise.ru.yml} +0 -0
@@ -1,45 +0,0 @@
1
- WYMeditor.STRINGS['en'] = {
2
- Strong: 'Strong',
3
- Emphasis: 'Emphasis',
4
- Superscript: 'Superscript',
5
- Subscript: 'Subscript',
6
- Ordered_List: 'Ordered List',
7
- Unordered_List: 'Unordered List',
8
- Indent: 'Indent',
9
- Outdent: 'Outdent',
10
- Undo: 'Undo',
11
- Redo: 'Redo',
12
- Link: 'Link',
13
- Unlink: 'Unlink',
14
- Image: 'Image',
15
- Table: 'Table',
16
- HTML: 'HTML',
17
- Paragraph: 'Paragraph',
18
- Heading_1: 'Heading 1',
19
- Heading_2: 'Heading 2',
20
- Heading_3: 'Heading 3',
21
- Heading_4: 'Heading 4',
22
- Heading_5: 'Heading 5',
23
- Heading_6: 'Heading 6',
24
- Preformatted: 'Preformatted',
25
- Blockquote: 'Blockquote',
26
- Table_Header: 'Table Header',
27
- URL: 'URL',
28
- Title: 'Title',
29
- Alternative_Text: 'Alternative text',
30
- Caption: 'Caption',
31
- Summary: 'Summary',
32
- Number_Of_Rows: 'Number of rows',
33
- Number_Of_Cols: 'Number of cols',
34
- Submit: 'Submit',
35
- Cancel: 'Cancel',
36
- Choose: 'Choose',
37
- Preview: 'Preview',
38
- Paste_From_Word: 'Paste from Word',
39
- Tools: 'Tools',
40
- Containers: 'Containers',
41
- Classes: 'Classes',
42
- Status: 'Status',
43
- Source_Code: 'Source code'
44
- };
45
-
@@ -1,55 +0,0 @@
1
- WYMeditor.STRINGS['ru'] = {
2
- Strong: 'Жирный',
3
- Emphasis: 'Наклонный',
4
- Superscript: 'Надстрочный',
5
- Subscript: 'Подстрочный',
6
- Ordered_List: 'Нумерованый список',
7
- Unordered_List: 'Ненумерованый список',
8
- Indent: 'Увеличить отступ',
9
- Outdent: 'Уменьшить отступ',
10
- Undo: 'Отменить',
11
- Redo: 'Повторить',
12
- Link: 'Ссылка',
13
- Unlink: 'Удалить ссылку',
14
- Image: 'Изображение',
15
- Table: 'Таблица',
16
- HTML: 'Править HTML',
17
- Paragraph: 'Параграф',
18
- Heading_1: 'Заголовок 1',
19
- Heading_2: 'Заголовок 2',
20
- Heading_3: 'Заголовок 3',
21
- Heading_4: 'Заголовок 4',
22
- Heading_5: 'Заголовок 5',
23
- Heading_6: 'Заголовок 6',
24
- Preformatted: 'Preformatted',
25
- Blockquote: 'Цитата',
26
- Table_Header: 'Заголовок таблицы',
27
- URL: 'Укажите ссылку',
28
- Upload: 'Загрузить',
29
- Upload_Image: 'Вставить изображение',
30
- Align: 'Разместить',
31
- Align_Left: 'По левому краю',
32
- Align_Right: 'По правому краю',
33
- Title: 'Заголовок',
34
- Alternative_Text: 'Альтернативный текст',
35
- Caption: 'Надпись',
36
- Summary: 'Summary',
37
- Number_Of_Rows: 'Кол-во строк',
38
- Number_Of_Cols: 'Кол-во столбцов',
39
- Submit: 'Отправить',
40
- Cancel: 'Отмена',
41
- Choose: 'Выбор',
42
- Preview: 'Просмотр',
43
- Paste_From_Word: 'Вставить',
44
- InsertBlockquote: 'Управление цитатами',
45
- Tools: 'Инструменты',
46
- Containers: 'Контейнеры',
47
- Classes: 'Классы',
48
- Status: 'Статус',
49
- Source_Code: 'Исходный код',
50
- Insert_video: 'Видео',
51
- Paste: 'Вставить',
52
- Description: 'Описание',
53
- New_Window: 'В новом окне'
54
- };
55
-
@@ -1,150 +0,0 @@
1
- /*
2
- To make this plugin work, you must:
3
- 1) include <script type="text/javascript" src="plugins/imageupload/jquery.wymeditor.imageupload.js"></script>
4
- 2) in postInit(), call: wym.imageupload_init('/path/to/your/upload/script.php', 'uploadedimage');
5
- (the uploaded file will then be available to your script.php in $_FILES['uploadedimage'])
6
- 3) make an upload script (not necessarily PHP), which should:
7
- 1) validate (extensions, size,...), resize, watermark, save the image
8
- 2) return this HTML:
9
- <html>
10
- <head><title></title></head>
11
- <body>
12
- <script language="JavaScript" type="text/javascript">
13
- <!-- <![CDATA[
14
-
15
- var wym_instance=0; // get it from $_REQUEST['wymindex']!
16
- var url='http://www.example.org/path/to/newly/uploaded/image.png';
17
-
18
- window.opener.WYMeditor.INSTANCES[wym_instance].imageinsert(url);
19
- window.close();
20
- // ]]> -->
21
- </script>
22
- </body>
23
- </html>
24
- (if the upload has failed for some reason you could put a link to some error image in "url" variable)
25
-
26
- 4) include these CSS rules in the page where you want to display the entered html:
27
- div.wym p:after, div.wym h1:after, div.wym h2:after, div.wym h3:after { content: "."; display: block; height: 0; clear: both; visibility: hidden;}
28
- div.wym p, div.wym h1, div.wym h2, div.wym h3 { clear: both; margin-bottom: 10px; margin-top: 0px;}
29
- div.wym img.floatleft { float: left; margin: 3px 10px 5px 0px; }
30
- div.wym img.floatright { float: right !important; margin: 3px 0px 5px 10px; }
31
-
32
- (assumption is that all the text is included inside <div class="wym">...</div> - make them fit your needs!)
33
-
34
- These CSS rules make sure that:
35
- - images are floated to the left/right (note: every image has 'floatleft' CSS class, but only those that have 'floatright' too are floated to the right)
36
- - text in block containers that follow the images doesn't flow around them
37
-
38
-
39
-
40
- */
41
-
42
-
43
- window.jQuery && (function ($) {
44
-
45
- $.extend(WYMeditor.editor.prototype, {
46
- // Function to be called for initialisation in the skin init, or in postInit
47
- imageupload_init:function (imageUploadUrl, imageFormName) {
48
-
49
- var html = '<body class="wym_dialog wym_dialog_image"><div class="wym_dialog_not">'
50
-
51
- + '<div style="padding: 0 15px;">'
52
- + '<div class="page-header">'
53
- + '<h3>{Upload_Image}</h3>'
54
- + '</div>'
55
-
56
- + '<form class="form-horizontal" action="' + imageUploadUrl + '" method="post" enctype="multipart/form-data" accept-charset="UTF-8">'
57
- + '<fieldset style="padding: 0 15px;">'
58
-
59
- + '<input type="hidden" name="wymindex" value="' + WYMeditor.INDEX + '"/>'
60
-
61
- + '<div class="form-group">'
62
- + '<input type="file" class="type-file" name="' + imageFormName + '"/>'
63
- + '</div>'
64
-
65
- + '<div class="form-group">'
66
- + "<label>{Description}</label>"
67
- + '<textarea class="form-control input-xlarge wym_text" rows="3" name="description"></textarea>'
68
- + '</div>'
69
-
70
- + '</fieldset>'
71
-
72
- + "<div class='well'>"
73
- + "<input class='btn btn-success wym_submit wymupdate' type='submit' value='{Submit}'>"
74
- + "&nbsp;"
75
- + "<a href='#' class='btn btn-danger wym_cancel' onClick='window.close();'>{Cancel}</a>"
76
- + "</div>"
77
-
78
- + '</form>'
79
-
80
- + '</div></div></body>';
81
-
82
- var dialog = (function (wym) {
83
- return function () {
84
- wym.dialog('Upload_Image', '', html);
85
- return false;
86
- };
87
- })(this);
88
-
89
- // Insert a button for uploading images:
90
- jQuery(this._box).find('.wym_tools ul')
91
- .append(jQuery("<li class='wym_tools_imageupload'><a name='Image' title='Вставить изображение' href='#'></a></li>").click(dialog)
92
- );
93
- // // Insert the buttons for aligning images left and right:
94
- // var alignImageLeft = (function (wym) {
95
- // return function () {
96
- // if (wym._selected_image) {
97
- // var container = wym._selected_image;
98
- // // css class 'floatleft' is always set. We just toggle 'floatright'
99
- // jQuery(container).removeClass('f-right').addClass('f-left');
100
- // }
101
- // return false;
102
- // }
103
- // })(this);
104
- // var alignImageRight = (function (wym) {
105
- // return function () {
106
- // if (wym._selected_image) {
107
- // var container = wym._selected_image;
108
- // // css class 'floatleft' is always set. We just toggle 'floatright'
109
- // jQuery(container).removeClass('f-left').addClass('f-right');
110
- // }
111
- // return false;
112
- // }
113
- // })(this);
114
-
115
- // jQuery(this._box).find('.wym_tools ul').append(
116
- // jQuery("<li class='wym_tools_imagealign align_image_left'><a name='ImageLeft' title='По левому краю' href='#'></a></li>")
117
- // .click(alignImageLeft)
118
- // ).append(
119
- // jQuery("<li class='wym_tools_imagealign align_image_right'><a name='ImageLeft' title='По правому краю' href='#'></a></li>")
120
- // .click(function (ev) {
121
- // ev.preventDefault();
122
- // alignImageRight();
123
- // })
124
- // );
125
-
126
- // now take care of all the CSS styles we need:
127
- var css = // clear floats in modern browsers:
128
- 'p:after, h1:after, h2:after, h3:after { content: "."; display: block; height: 0; clear: both; visibility: hidden;}\n' +
129
- // clear floats in IE too:
130
- 'p, h1, h2, h3 { clear: both; }\n' +
131
- // every image should float to left by default:
132
- 'img { float: left; width: auto !important; height: auto !important;}\n' +
133
- // .floatright should float to right:
134
- 'img.f-right { float: right !important; width: auto !important; height: auto !important; }';
135
- $(this._doc).find('head').append($("<style type='text/css'> " + css + " </style>"));
136
- },
137
- imageinsert:function (content) {
138
- var container = this.selected();
139
- var sData = content;
140
- if (container && container.tagName.toLowerCase() != WYMeditor.BODY) {
141
- // inside <p>:
142
- jQuery(container).before('<p>' + sData + '</p>');
143
- // jQuery(container).prepend('<p>' + sData + '</p>');
144
- } else {
145
- jQuery(this._doc.body).append('<p>' + sData + '</p>');
146
- }
147
- }
148
-
149
- });
150
- })(window.jQuery);
@@ -1,91 +0,0 @@
1
- /*
2
- * WYMeditor : what you see is What You Mean web-based editor
3
- * Copyright (c) 2005 - 2009 Jean-Francois Hovinne, http://www.wymeditor.org/
4
- * Dual licensed under the MIT (MIT-license.txt)
5
- * and GPL (GPL-license.txt) licenses.
6
- *
7
- * For further information visit:
8
- * http://www.wymeditor.org/
9
- *
10
- * File Name:
11
- * jquery.wymeditor.resizable.js
12
- * resize plugin for WYMeditor
13
- *
14
- * File Authors:
15
- * Peter Eschler (peschler _at_ gmail.com)
16
- * Jean-Francois Hovinne - http://www.hovinne.com/
17
- *
18
- * Version:
19
- * 0.4
20
- *
21
- * Changelog:
22
- *
23
- * 0.4
24
- * - Removed UI and UI.resizable scripts loading - see #167 (jfh).
25
- *
26
- * 0.3
27
- * - Added 'iframeOriginalSize' and removed 'ui.instance' calls (jfh).
28
- *
29
- * 0.2
30
- * - Added full support for all jQueryUI resizable plugin options.
31
- * - Refactored and documented code.
32
- * 0.1
33
- * - Initial release.
34
- */
35
-
36
- /**
37
- * The resizable plugin makes the wymeditor box vertically resizable.
38
- * It it based on the ui.resizable.js plugin of the jQuery UI library.
39
- *
40
- * The WYMeditor resizable plugin supports all parameters of the jQueryUI
41
- * resizable plugin. The parameters are passed like this:
42
- *
43
- * wym.resizable({ handles: "s,e",
44
- * maxHeight: 600 });
45
- *
46
- * DEPENDENCIES: jQuery UI, jQuery UI resizable
47
- *
48
- * @param options options for the plugin
49
- */
50
- WYMeditor.editor.prototype.resizable = function(options) {
51
-
52
- var wym = this;
53
- var iframe = jQuery(wym._box).find('iframe');
54
- var iframeOriginalSize = {};
55
-
56
- // Define some default options
57
- var default_options = {
58
- start: function(e, ui) {
59
- iframeOriginalSize = {
60
- width: jQuery(iframe).width(),
61
- height: jQuery(iframe).height()
62
- }
63
- },
64
-
65
- // resize is called by the jQuery resizable plugin whenever the
66
- // client area was resized.
67
- resize: function(e, ui) {
68
- var diff = ui.size.height - ui.originalSize.height;
69
- jQuery(iframe).height( iframeOriginalSize.height + diff );
70
-
71
- // If the plugin has horizontal resizing disabled we need to
72
- // adjust the "width" attribute of the area css, because the
73
- // resizing will set a fixed width (which breaks liquid layout
74
- // of the wymeditor area).
75
- if( !ui.options.handles['w'] && !ui.options.handles['e'] ) {
76
- ui.size.width = "inherit";
77
- }
78
- },
79
- handles: "s,e,se",
80
- minHeight: 250,
81
- maxHeight: 600
82
- };
83
-
84
- // Merge given options with default options. Given options override
85
- // default ones.
86
- var final_options = jQuery.extend(default_options, options);
87
-
88
- if(jQuery.isFunction( jQuery.fn.resizable )) jQuery(wym._box).resizable(final_options);
89
- else WYMeditor.console.error('Oops, jQuery UI.resizable unavailable.');
90
-
91
- };
@@ -1,124 +0,0 @@
1
-
2
-
3
- resizable plugin for WYMeditor
4
- ##############################
5
-
6
- The ``resizable`` plugin for WYMeditor_ enables vertical resizing of the
7
- editor area. The plugin is based on the jQuery UI library.
8
-
9
- Requirements
10
- ============
11
- The following packages are required for using the WYMeditor ``resizable``
12
- plugin:
13
-
14
- * jQuery (tested with jQuery ``jquery-1.2.4a.js`` from ``jquery.ui`` package)
15
- * WYMeditor SVN trunk (Revision: 482)
16
- * jQuery-UI (tested with ``jquery.ui-1.5b2``)
17
-
18
- It should be possible to use this plugin with ``WYMeditor-0.4`` but I have not
19
- tried.
20
-
21
- Download
22
- ========
23
- You can download the WYMeditor ``resizable`` plugin here:
24
-
25
- * wymeditor-resizable-plugin-0.2.tgz_
26
- * wymeditor-resizable-plugin-0.1.tgz_
27
-
28
- See the Changelog_ for more infos about the releases.
29
-
30
- .. _wymeditor-resizable-plugin-0.2.tgz: http://pyjax.net/download/wymeditor-resizable-plugin-0.2.tgz
31
- .. _wymeditor-resizable-plugin-0.1.tgz: http://pyjax.net/download/wymeditor-resizable-plugin-0.1.tgz
32
-
33
- Installation
34
- ============
35
- Just extract the downloaded archive into your WYMeditor's ``plugin``
36
- directory.
37
-
38
- Usage
39
- =====
40
- For general instructions on WYMeditor plugins please refer to the `WYMeditor
41
- plugin page`_.
42
-
43
- To use the ``resizable`` plugin simply include the plugin's JavaScript file in
44
- your code. You **do not** need to include the jQuery UI files - this is done
45
- automatically by the plugin (see `Internals`_)::
46
-
47
- <script type="text/javascript"
48
- src="/js/wymeditor/plugins/resizable/jquery.wymeditor.resizable.js">
49
- </script>
50
-
51
- Make sure to adjust the ``src`` attribute to your needs, then initialize the
52
- plugin in WYMeditor's ``postInit`` function::
53
-
54
- wymeditor({postInit: function(wym) {
55
- wym.hovertools(); // other plugins...
56
- wym.resizable({handles: "s,e",
57
- maxHeight: 600});
58
- }
59
- })
60
-
61
- The ``resizable`` plugin takes exactly one parameter, which is an object literal
62
- containing the options of the plugin. The WYMeditor ``resizable`` plugin
63
- supports all options of the jQuery UI ``resizable`` plugin. These are the
64
- default values used by the plugin::
65
-
66
- handles: "s,e,se",
67
- minHeight: 250,
68
- maxHeight: 600
69
-
70
- See the `jQuery UI resizable plugin docs`_ for a list of all options.
71
-
72
- That's it! You are now able to resize the WYMeditor vertically, horizontally or
73
- both, depending on your options.
74
-
75
- .. _jQuery UI resizable plugin docs: http://docs.jquery.com/UI/Resizables
76
-
77
- Internals
78
- =========
79
- The plugin takes care of loading the necessary jQuery UI files (``base`` and
80
- ``resizable``) from the same path the jQuery library was loaded. Here's how
81
- it's done::
82
-
83
- // Get the jQuery path from the editor, stripping away the jQuery file.
84
- // see http://www.oreilly.com/catalog/regex/chapter/ch04.html
85
- // The match result array contains the path and the filename.
86
- var jQueryPath = wym.computeJqueryPath().match(/^(.*)\/(.*)$/)[1];
87
-
88
- // Make an array of the external JavaScript files required by the plugin.
89
- var jQueryPlugins = [jQueryPath + '/ui.base.js',
90
- jQueryPath + '/ui.resizable.js'];
91
-
92
- // First get the jQuery UI base file
93
- $.getScript(jQueryPlugins[0]);
94
-
95
- // Get the jQuery UI resizeable plugin and then init the wymeditor resizable
96
- // plugin. It is import to do the initialisation after loading the
97
- // necessary jQuery UI files has finished, otherwise the "resizable" method
98
- // would not be available.
99
- $.getScript(jQueryPlugins[1], function() {
100
- jQuery(wym._box).resizable(final_options);
101
- });
102
-
103
- An alternative approach would be to use an AJAX queue when getting the script
104
- files to ensure that all jQuery files are loaded before the initialisation code
105
- of the plugin is executed. There is an `jQuery AJAX queue plugin`_ which does
106
- that.
107
-
108
- .. _jQuery AJAX queue plugin: http://plugins.jquery.com/project/ajaxqueue
109
-
110
- Changelog
111
- =========
112
-
113
- 0.2
114
- ---
115
- - Added full support for all jQuery UI resizable plugin options.
116
- - Refactored and documented code.
117
- - Now contains a packed version (775 bytes).
118
-
119
- 0.1
120
- ---
121
- - Initial release.
122
-
123
- .. _WYMeditor: http://www.wymeditor.org/
124
- .. _WYMeditor plugin page: http://trac.wymeditor.org/trac/wiki/0.4/Plugins
@@ -1,134 +0,0 @@
1
- /*
2
- * WYMeditor : what you see is What You Mean web-based editor
3
- * Copyright (c) 2005 - 2009 Jean-Francois Hovinne, http://www.wymeditor.org/
4
- * Dual licensed under the MIT (MIT-license.txt)
5
- * and GPL (GPL-license.txt) licenses.
6
- *
7
- * For further information visit:
8
- * http://www.wymeditor.org/
9
- *
10
- * File Name:
11
- * screen.css
12
- * main stylesheet for the WYMeditor skin
13
- * See the documentation for more info.
14
- *
15
- * File Authors:
16
- * Daniel Reszka (d.reszka a-t wymeditor dotorg)
17
- * Jean-Francois Hovinne (jf.hovinne a-t wymeditor dotorg)
18
- */
19
-
20
- /*TRYING TO RESET STYLES THAT MAY INTERFERE WITH WYMEDITOR*/
21
- .wym_skin_compact p, .wym_skin_compact h2, .wym_skin_compact h3,
22
- .wym_skin_compact ul, .wym_skin_compact li { background: transparent url(); margin: 0; padding: 0; border-width:0; list-style: none; }
23
-
24
-
25
- /*HIDDEN BY DEFAULT*/
26
- .wym_skin_compact .wym_area_left { display: none; }
27
- .wym_skin_compact .wym_area_right { display: none; }
28
-
29
-
30
- /*TYPO*/
31
- .wym_skin_compact { font-size: 10px; font-family: Verdana, Arial, sans-serif; }
32
- .wym_skin_compact h2 { font-size: 110%; /* = 11px */}
33
- .wym_skin_compact h3 { font-size: 100%; /* = 10px */}
34
- .wym_skin_compact li { font-size: 100%; /* = 10px */}
35
-
36
-
37
- /*WYM_BOX*/
38
- .wym_skin_compact { border: 1px solid gray; padding: 5px}
39
-
40
- /*auto-clear the wym_box*/
41
- .wym_skin_compact:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; }
42
- * html .wym_skin_compact { height: 1%;}
43
-
44
-
45
- /*WYM_HTML*/
46
- .wym_skin_compact .wym_html { width: 98%;}
47
- .wym_skin_compact .wym_html textarea { font-size: 120%; width: 100%; height: 200px; border: 1px solid gray; background: white; }
48
-
49
-
50
- /*WYM_IFRAME*/
51
- .wym_skin_compact .wym_iframe { width: 98%;}
52
- .wym_skin_compact .wym_iframe iframe { width: 100%; height: 200px; border: 1px solid gray; background: white }
53
-
54
-
55
- /*AREAS*/
56
- .wym_skin_compact .wym_area_left { width: 100px; float: left;}
57
- .wym_skin_compact .wym_area_right { width: 150px; float: right;}
58
- .wym_skin_compact .wym_area_bottom { height: 1%; clear: both;}
59
- * html .wym_skin_compact .wym_area_main { height: 1%;}
60
- * html .wym_skin_compact .wym_area_top { height: 1%;}
61
- *+html .wym_skin_compact .wym_area_top { height: 1%;}
62
-
63
- /*SECTIONS SYSTEM*/
64
-
65
- /*common defaults for all sections*/
66
- .wym_skin_compact .wym_section { margin-bottom: 5px; }
67
- .wym_skin_compact .wym_section h2,
68
- .wym_skin_compact .wym_section h3 { padding: 1px 3px; margin: 0; }
69
- .wym_skin_compact .wym_section a { padding: 0 3px; display: block; text-decoration: none; color: black; }
70
- .wym_skin_compact .wym_section a:hover { background-color: yellow; }
71
- /*hide section titles by default*/
72
- .wym_skin_compact .wym_section h2 { display: none; }
73
- /*disable any margin-collapse*/
74
- .wym_skin_compact .wym_section { padding-top: 1px; padding-bottom: 1px; }
75
- /*auto-clear sections*/
76
- .wym_skin_compact .wym_section ul:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; }
77
- * html .wym_skin_compact .wym_section ul { height: 1%;}
78
-
79
- /*option: add this class to a section to make it render as a panel*/
80
- .wym_skin_compact .wym_panel { }
81
- .wym_skin_compact .wym_panel h2 { display: block; }
82
-
83
- /*option: add this class to a section to make it render as a dropdown menu*/
84
- .wym_skin_compact .wym_dropdown h2 { display: block; }
85
- .wym_skin_compact .wym_dropdown ul { display: none; position: absolute; background: white; }
86
- .wym_skin_compact .wym_dropdown:hover ul,
87
- .wym_skin_compact .wym_dropdown.hover ul { display: block; }
88
-
89
- /*option: add this class to a section to make its elements render buttons (icons are only available for the wym_tools section for now)*/
90
- .wym_skin_compact .wym_buttons li { float:left;}
91
- .wym_skin_compact .wym_buttons a { width: 20px; height: 20px; overflow: hidden; padding: 2px }
92
- /*image replacements*/
93
- .wym_skin_compact .wym_buttons li a { background: url(icons.png) no-repeat; text-indent: -9999px;}
94
- .wym_skin_compact .wym_buttons li.wym_tools_strong a { background-position: 0 -382px;}
95
- .wym_skin_compact .wym_buttons li.wym_tools_emphasis a { background-position: 0 -22px;}
96
- .wym_skin_compact .wym_buttons li.wym_tools_superscript a { background-position: 0 -430px;}
97
- .wym_skin_compact .wym_buttons li.wym_tools_subscript a { background-position: 0 -454px;}
98
- .wym_skin_compact .wym_buttons li.wym_tools_ordered_list a { background-position: 0 -48px;}
99
- .wym_skin_compact .wym_buttons li.wym_tools_unordered_list a{ background-position: 0 -72px;}
100
- .wym_skin_compact .wym_buttons li.wym_tools_indent a { background-position: 0 -574px;}
101
- .wym_skin_compact .wym_buttons li.wym_tools_outdent a { background-position: 0 -598px;}
102
- .wym_skin_compact .wym_buttons li.wym_tools_undo a { background-position: 0 -502px;}
103
- .wym_skin_compact .wym_buttons li.wym_tools_redo a { background-position: 0 -526px;}
104
- .wym_skin_compact .wym_buttons li.wym_tools_link a { background-position: 0 -96px;}
105
- .wym_skin_compact .wym_buttons li.wym_tools_unlink a { background-position: 0 -168px;}
106
- .wym_skin_compact .wym_buttons li.wym_tools_image a { background-position: 0 -121px;}
107
- .wym_skin_compact .wym_buttons li.wym_tools_table a { background-position: 0 -144px;}
108
- .wym_skin_compact .wym_buttons li.wym_tools_paste a { background-position: 0 -552px;}
109
- .wym_skin_compact .wym_buttons li.wym_tools_html a { background-position: 0 -193px;}
110
- .wym_skin_compact .wym_buttons li.wym_tools_preview a { background-position: 0 -408px;}
111
-
112
- /*DECORATION*/
113
- .wym_skin_compact .wym_section h2 { background: #f0f0f0; border: solid gray; border-width: 0 0 1px;}
114
- .wym_skin_compact .wym_section h2 span { color: gray;}
115
- .wym_skin_compact .wym_panel { padding: 0; border: solid gray; border-width: 1px; background: white;}
116
- .wym_skin_compact .wym_panel ul { margin: 2px 0 5px; }
117
- .wym_skin_compact .wym_dropdown { padding: 0; border: solid gray; border-width: 1px 1px 0 1px; }
118
- .wym_skin_compact .wym_dropdown ul { border: solid gray; border-width: 0 1px 1px 1px; margin-left: -1px; padding: 5px 10px 5px 3px;}
119
-
120
- /*DIALOGS*/
121
- .wym_dialog div.row { margin-bottom: 5px;}
122
- .wym_dialog div.row input { margin-right: 5px;}
123
- .wym_dialog div.row label { float: left; width: 150px; display: block; text-align: right; margin-right: 10px; }
124
- .wym_dialog div.row-indent { padding-left: 160px; }
125
- /*autoclearing*/
126
- .wym_dialog div.row:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; }
127
- .wym_dialog div.row { display: inline-block; }
128
- /* Hides from IE-mac \*/
129
- * html .wym_dialog div.row { height: 1%; }
130
- .wym_dialog div.row { display: block; }
131
- /* End hide from IE-mac */
132
-
133
- /*WYMEDITOR_LINK*/
134
- a.wym_wymeditor_link { text-indent: -9999px; float: right; display: block; width: 50px; height: 15px; background: url(../wymeditor_icon.png); overflow: hidden; text-decoration: none; }
@@ -1,35 +0,0 @@
1
- WYMeditor.SKINS['compact'] = {
2
-
3
- init: function(wym) {
4
-
5
- //move the containers panel to the top area
6
- jQuery(wym._options.containersSelector + ', '
7
- + wym._options.classesSelector, wym._box)
8
- .appendTo( jQuery("div.wym_area_top", wym._box) )
9
- .addClass("wym_dropdown")
10
- .css({"margin-right": "10px", "width": "120px", "float": "left"});
11
-
12
- //render following sections as buttons
13
- jQuery(wym._options.toolsSelector, wym._box)
14
- .addClass("wym_buttons")
15
- .css({"margin-right": "10px", "float": "left"});
16
-
17
- //make hover work under IE < 7
18
- jQuery(".wym_section", wym._box).hover(function(){
19
- jQuery(this).addClass("hover");
20
- },function(){
21
- jQuery(this).removeClass("hover");
22
- });
23
-
24
- var postInit = wym._options.postInit;
25
- wym._options.postInit = function(wym) {
26
-
27
- if(postInit) postInit.call(wym, wym);
28
- var rule = {
29
- name: 'body',
30
- css: 'background-color: #f0f0f0;'
31
- };
32
- wym.addCssRule( wym._doc.styleSheets[0], rule);
33
- };
34
- }
35
- };