From f0588140405453ca09fd9dd5a04970863390842d Mon Sep 17 00:00:00 2001 From: Scott Tolksdorf Date: Sun, 5 Jun 2016 12:49:55 -0400 Subject: [PATCH 1/5] Adding in a new classTable block --- client/homebrew/navbar/navbar.jsx | 2 +- client/homebrew/phbStyle/phb.depricated.less | 31 ++++++++++++ client/homebrew/phbStyle/phb.style.less | 53 +++++++++----------- package.json | 2 +- 4 files changed, 58 insertions(+), 30 deletions(-) create mode 100644 client/homebrew/phbStyle/phb.depricated.less diff --git a/client/homebrew/navbar/navbar.jsx b/client/homebrew/navbar/navbar.jsx index d82486749..515f4b6b5 100644 --- a/client/homebrew/navbar/navbar.jsx +++ b/client/homebrew/navbar/navbar.jsx @@ -11,7 +11,7 @@ var Navbar = React.createClass({
The Homebrewery
- v2.2.0 + v2.2.1 {this.props.children} diff --git a/client/homebrew/phbStyle/phb.depricated.less b/client/homebrew/phbStyle/phb.depricated.less new file mode 100644 index 000000000..992dab35b --- /dev/null +++ b/client/homebrew/phbStyle/phb.depricated.less @@ -0,0 +1,31 @@ +.phb{ + //Double hr for full width elements + hr+hr+blockquote{ + column-span : all; + -webkit-column-span : all; + -moz-column-span : all; + } + + //***************************** + // * CLASS TABLE + // *****************************/ + hr+table{ + margin-top : -5px; + margin-bottom : 50px; + padding-top : 10px; + border-collapse : separate; + background-color : white; + border : initial; + border-style : solid; + border-image-outset : 37px 17px; + border-image-repeat : round; + border-image-slice : 150 200 150 200; + border-image-source : @frameBorderImage; + border-image-width : 47px; + } + h5+hr+table{ + column-span : all; + -webkit-column-span : all; + -moz-column-span : all; + } +} \ No newline at end of file diff --git a/client/homebrew/phbStyle/phb.style.less b/client/homebrew/phbStyle/phb.style.less index f53286d7b..4cbab9a7f 100644 --- a/client/homebrew/phbStyle/phb.style.less +++ b/client/homebrew/phbStyle/phb.style.less @@ -2,6 +2,7 @@ @import (less) 'shared/naturalcrit/styles/reset.less'; @import (less) './client/homebrew/phbStyle/phb.fonts.css'; @import (less) './client/homebrew/phbStyle/phb.assets.less'; +@import (less) './client/homebrew/phbStyle/phb.depricated.less'; //Colors @background : #EEE5CE; @noteGreen : #e0e5c1; @@ -256,28 +257,7 @@ hr+hr+blockquote{ .useColumns(0.96); } - //***************************** - // * CLASS TABLE - // *****************************/ - hr+table{ - margin-top : -5px; - margin-bottom : 50px; - padding-top : 10px; - border-collapse : separate; - background-color : white; - border : initial; - border-style : solid; - border-image-outset : 37px 17px; - border-image-repeat : round; - border-image-slice : 150 200 150 200; - border-image-source : @frameBorderImage; - border-image-width : 47px; - } - h5+hr+table{ - column-span : all; - -webkit-column-span : all; - -moz-column-span : all; - } + //***************************** // * FOOTER // *****************************/ @@ -335,12 +315,7 @@ text-indent : -1em; list-style-type : none; } - //Double hr for full width elements - hr+hr+blockquote{ - column-span : all; - -webkit-column-span : all; - -moz-column-span : all; - } + //Column Break pre, code{ visibility : hidden; @@ -411,4 +386,26 @@ column-span : all; -webkit-column-span : all; -moz-column-span : all; +} + + +//***************************** +// * CLASS TABLE +// *****************************/ + +.phb .classTable{ + margin-top : 25px; + margin-bottom : 40px; + border-collapse : separate; + background-color : white; + border : initial; + border-style : solid; + border-image-outset : 25px 17px; + border-image-repeat : round; + border-image-slice : 150 200 150 200; + border-image-source : @frameBorderImage; + border-image-width : 47px; + h5{ + margin-bottom: 10px; + } } \ No newline at end of file diff --git a/package.json b/package.json index 686405621..cba802d80 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "homebrewery", "description": "Create authentic looking D&D homebrews using only markdown", - "version": "2.2.0", + "version": "2.2.1", "scripts": { "postinstall": "gulp prod", "start": "node server.js" From 5969e45087aff9288fe0baef180837d1c9197bd6 Mon Sep 17 00:00:00 2001 From: Scott Tolksdorf Date: Sun, 5 Jun 2016 12:55:29 -0400 Subject: [PATCH 2/5] Updated the class tbale snippets --- changelog.md | 9 +++++++++ client/homebrew/editor/snippets/classtable.gen.js | 10 ++++------ 2 files changed, 13 insertions(+), 6 deletions(-) diff --git a/changelog.md b/changelog.md index 4ea135f88..20e2eca92 100644 --- a/changelog.md +++ b/changelog.md @@ -1,5 +1,14 @@ # changelog +### Sunday, 05/06/2016 - v2.2.1 +- Adding in a new Class table div block. The old Class table block used weird stacking of HTML elements, resulting is difficult to control behaviour and poor interactiosn with the rest of the page. This new block is much easier to style and work with. +- Added in a new auto-incremeting page number snippet + + +### Saturday, 04/06/2016 - v2.2.0 +- MIgrating The Homebrewery over to hombrewery.naturalcrit.com. It know runs on it's own server, with it's own repo separate from the other tools I'm working on. Makes updating and deploying much easier. + + ### Sunday, 29/05/2016 - v2.1.0 - Finally added a syntax for doing spell lists. A bit in-depth about why this took so long. Essentially I'm running out of syntax to use in stardard Markdown. There are too many unique elements in the PHB-style to be mapped. I solved this earlier by stacking certain elements together (eg. an `
` before a `blockquote` turns it into moster state block), but those are getting unweildly. I would like to simply wrap these in `div`s with classes, but unfortunately Markdown stops processing when within HTML blocks. To get around this I wrote my own override to the Markdown parser and lexer to process Markdown within a simple div class wrapper. This should open the door for more unique syntaxes in the future. Big step! - Override Ctrl+P (and cmd+P) to launch to the print page. Many people try to just print either the editing or share page to get a PDF. While this dones;t make much sense, I do get a ton of issues about it. So now if you try to do this, it'll just bring you imediately to the print page. Everybody wins! diff --git a/client/homebrew/editor/snippets/classtable.gen.js b/client/homebrew/editor/snippets/classtable.gen.js index b1d6021f5..0ccd51a23 100644 --- a/client/homebrew/editor/snippets/classtable.gen.js +++ b/client/homebrew/editor/snippets/classtable.gen.js @@ -70,8 +70,7 @@ module.exports = { var cantrips = 3; var spells = 1; var slots = 2; - return "##### The " + classname + "\n" + - "___\n" + + return "
\n##### The " + classname + "\n" + "| Level | Proficiency Bonus | Features | Cantrips Known | Spells Known | 1st | 2nd | 3rd | 4th | 5th | 6th | 7th | 8th | 9th |\n"+ "|:---:|:---:|:---|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|\n" + _.map(levels, function(levelName, level){ @@ -89,15 +88,14 @@ module.exports = { slots += _.random(0,2); return "| " + res + " |"; - }).join('\n') +'\n\n'; + }).join('\n') +'\n
\n\n'; }, half : function(classname){ classname = classname || _.sample(classnames) var featureScore = 1 - return "##### The " + classname + "\n" + - "___\n" + "___\n" + + return "
\n##### The " + classname + "\n" + "| Level | Proficiency Bonus | Features | " + _.sample(features) + "|\n" + "|:---:|:---:|:---|:---:|\n" + _.map(levels, function(levelName, level){ @@ -111,6 +109,6 @@ module.exports = { featureScore += _.random(0,1); return "| " + res + " |"; - }).join('\n') +'\n\n'; + }).join('\n') +'\n
\n\n'; } }; \ No newline at end of file From 0d25a972ba70efb4942fa9818b75273c5f363aaf Mon Sep 17 00:00:00 2001 From: Scott Tolksdorf Date: Sun, 5 Jun 2016 13:09:37 -0400 Subject: [PATCH 3/5] Added in new auto-incrementing snippet --- changelog.md | 1 + client/homebrew/editor/snippets/snippets.js | 24 +++++++++++++++++++++ client/homebrew/phbStyle/phb.style.less | 8 +++++++ 3 files changed, 33 insertions(+) diff --git a/changelog.md b/changelog.md index 20e2eca92..abb46ab52 100644 --- a/changelog.md +++ b/changelog.md @@ -2,6 +2,7 @@ ### Sunday, 05/06/2016 - v2.2.1 - Adding in a new Class table div block. The old Class table block used weird stacking of HTML elements, resulting is difficult to control behaviour and poor interactiosn with the rest of the page. This new block is much easier to style and work with. +- Added in a new wide table snippet - Added in a new auto-incremeting page number snippet diff --git a/client/homebrew/editor/snippets/snippets.js b/client/homebrew/editor/snippets/snippets.js index 171ec39fe..ded7b8ac6 100644 --- a/client/homebrew/editor/snippets/snippets.js +++ b/client/homebrew/editor/snippets/snippets.js @@ -57,6 +57,12 @@ module.exports = [ gen : "
1
\n
PART 1 | FANCINESS
\n\n" }, + { + name : "Auto-incrementing Page Number", + icon : 'fa-sort-numeric-asc', + gen : "
\n" + }, + ] }, @@ -141,6 +147,24 @@ module.exports = [ "| 17th | 4 or lower |\n\n", ].join('\n'); }, + }, + { + name : 'Wide Table', + icon : 'fa-list', + gen : function(){ + return [ + "
", + "##### Cookie Tastiness", + "| Tastiness | Cookie Type |", + "|:----:|:-------------|", + "| -5 | Raisin |", + "| 8th | Chocolate Chip |", + "| 11th | 2 or lower |", + "| 14th | 3 or lower |", + "| 17th | 4 or lower |", + "
\n\n" + ].join('\n'); + }, } ] }, diff --git a/client/homebrew/phbStyle/phb.style.less b/client/homebrew/phbStyle/phb.style.less index 4cbab9a7f..e397d5877 100644 --- a/client/homebrew/phbStyle/phb.style.less +++ b/client/homebrew/phbStyle/phb.style.less @@ -11,6 +11,9 @@ @headerText : #58180D; @monsterStatBackground : #FDF1DC; @page { margin: 0; } +body { + counter-reset: phb-page-numbers; +} .useSansSerif(){ font-family : ScalySans; em{ @@ -291,6 +294,11 @@ font-size : 0.9em; color : #c9ad6a; text-align : center; + + &.auto::after { + counter-increment: phb-page-numbers; + content: counter(phb-page-numbers); + } } .footnote{ position : absolute; From 3e796501e2b85a1862c5808a53f8dd0ecb923390 Mon Sep 17 00:00:00 2001 From: Scott Tolksdorf Date: Sun, 5 Jun 2016 13:47:59 -0400 Subject: [PATCH 4/5] Fied lists in stat blocks --- changelog.md | 1 + client/homebrew/brewRenderer/brewRenderer.jsx | 2 +- client/homebrew/phbStyle/phb.style.less | 6 +++--- 3 files changed, 5 insertions(+), 4 deletions(-) diff --git a/changelog.md b/changelog.md index abb46ab52..6374bc2db 100644 --- a/changelog.md +++ b/changelog.md @@ -4,6 +4,7 @@ - Adding in a new Class table div block. The old Class table block used weird stacking of HTML elements, resulting is difficult to control behaviour and poor interactiosn with the rest of the page. This new block is much easier to style and work with. - Added in a new wide table snippet - Added in a new auto-incremeting page number snippet +- Lists in monster stat blocks should be fixed now ### Saturday, 04/06/2016 - v2.2.0 diff --git a/client/homebrew/brewRenderer/brewRenderer.jsx b/client/homebrew/brewRenderer/brewRenderer.jsx index 121e68ad5..d688f6469 100644 --- a/client/homebrew/brewRenderer/brewRenderer.jsx +++ b/client/homebrew/brewRenderer/brewRenderer.jsx @@ -7,7 +7,7 @@ var renderer = new Markdown.Renderer(); //Processes the markdown within an HTML block if it's just a class-wrapper renderer.html = function (html) { - if(_.startsWith(html, '
')){ + if(_.startsWith(_.trim(html), '
')){ var openTag = html.substring(0, html.indexOf('>')+1); html = html.substring(html.indexOf('>')+1); html = html.substring(0, html.lastIndexOf('
')); diff --git a/client/homebrew/phbStyle/phb.style.less b/client/homebrew/phbStyle/phb.style.less index e397d5877..e5978e28a 100644 --- a/client/homebrew/phbStyle/phb.style.less +++ b/client/homebrew/phbStyle/phb.style.less @@ -216,13 +216,13 @@ body { font-weight : 400; border-bottom : 1px solid @headerText; } + hr+ul{ + color : @headerText; + } ul{ .useSansSerif(); padding-left : 1em; font-size : 0.352cm; - color : @headerText; - text-indent : -1em; - list-style-type : none; } // Monster Ability table hr+table{ From 235664ec881f2a51bf6350bf9b03d76d49e7f37c Mon Sep 17 00:00:00 2001 From: Scott Tolksdorf Date: Sun, 5 Jun 2016 13:49:21 -0400 Subject: [PATCH 5/5] updating the standalone css file --- changelog.md | 3 +- phb.standalone.css | 77 ++++++++++++++++++++++++++++++---------------- 2 files changed, 52 insertions(+), 28 deletions(-) diff --git a/changelog.md b/changelog.md index 6374bc2db..968bce736 100644 --- a/changelog.md +++ b/changelog.md @@ -3,13 +3,14 @@ ### Sunday, 05/06/2016 - v2.2.1 - Adding in a new Class table div block. The old Class table block used weird stacking of HTML elements, resulting is difficult to control behaviour and poor interactiosn with the rest of the page. This new block is much easier to style and work with. - Added in a new wide table snippet -- Added in a new auto-incremeting page number snippet +- Added in a new auto-incremeting page number snippet (thakns u/Ryrok!) - Lists in monster stat blocks should be fixed now ### Saturday, 04/06/2016 - v2.2.0 - MIgrating The Homebrewery over to hombrewery.naturalcrit.com. It know runs on it's own server, with it's own repo separate from the other tools I'm working on. Makes updating and deploying much easier. +\page ### Sunday, 29/05/2016 - v2.1.0 - Finally added a syntax for doing spell lists. A bit in-depth about why this took so long. Essentially I'm running out of syntax to use in stardard Markdown. There are too many unique elements in the PHB-style to be mapped. I solved this earlier by stacking certain elements together (eg. an `
` before a `blockquote` turns it into moster state block), but those are getting unweildly. I would like to simply wrap these in `div`s with classes, but unfortunately Markdown stops processing when within HTML blocks. To get around this I wrote my own override to the Markdown parser and lexer to process Markdown within a simple div class wrapper. This should open the door for more unique syntaxes in the future. Big step! diff --git a/phb.standalone.css b/phb.standalone.css index e0e4c7864..7c7ca4b46 100644 --- a/phb.standalone.css +++ b/phb.standalone.css @@ -172,9 +172,36 @@ table { font-weight: normal; font-style: normal; } +.phb hr + hr + blockquote { + column-span: all; + -webkit-column-span: all; + -moz-column-span: all; +} +.phb hr + table { + margin-top: -5px; + margin-bottom: 50px; + padding-top: 10px; + border-collapse: separate; + background-color: white; + border: initial; + border-style: solid; + border-image-outset: 37px 17px; + border-image-repeat: round; + border-image-slice: 150 200 150 200; + border-image-source: url(); + border-image-width: 47px; +} +.phb h5 + hr + table { + column-span: all; + -webkit-column-span: all; + -moz-column-span: all; +} @page { margin: 0; } +body { + counter-reset: phb-page-numbers; +} .phb { column-count: 2; column-fill: auto; @@ -367,13 +394,13 @@ table { font-weight: 400; border-bottom: 1px solid #58180D; } +.phb hr + blockquote hr + ul { + color: #58180D; +} .phb hr + blockquote ul { font-family: ScalySans; padding-left: 1em; font-size: 0.352cm; - color: #58180D; - text-indent: -1em; - list-style-type: none; } .phb hr + blockquote ul em { font-family: ScalySans; @@ -424,25 +451,6 @@ table { -webkit-column-gap: 1cm; -moz-column-gap: 1cm; } -.phb hr + table { - margin-top: -5px; - margin-bottom: 50px; - padding-top: 10px; - border-collapse: separate; - background-color: white; - border: initial; - border-style: solid; - border-image-outset: 37px 17px; - border-image-repeat: round; - border-image-slice: 150 200 150 200; - border-image-source: url(); - border-image-width: 47px; -} -.phb h5 + hr + table { - column-span: all; - -webkit-column-span: all; - -moz-column-span: all; -} .phb:after { content: ""; position: absolute; @@ -472,6 +480,10 @@ table { color: #c9ad6a; text-align: center; } +.phb .pageNumber.auto::after { + counter-increment: phb-page-numbers; + content: counter(phb-page-numbers); +} .phb .footnote { position: absolute; right: 80px; @@ -491,11 +503,6 @@ table { text-indent: -1em; list-style-type: none; } -.phb hr + hr + blockquote { - column-span: all; - -webkit-column-span: all; - -moz-column-span: all; -} .phb pre, .phb code { visibility: hidden; @@ -566,3 +573,19 @@ table { -webkit-column-span: all; -moz-column-span: all; } +.phb .classTable { + margin-top: 25px; + margin-bottom: 40px; + border-collapse: separate; + background-color: white; + border: initial; + border-style: solid; + border-image-outset: 25px 17px; + border-image-repeat: round; + border-image-slice: 150 200 150 200; + border-image-source: url(); + border-image-width: 47px; +} +.phb .classTable h5 { + margin-bottom: 10px; +}