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 d824867..515f4b6 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 0000000..992dab3 --- /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 f53286d..4cbab9a 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 6864056..cba802d 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 4ea135f..20e2eca 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 b1d6021..0ccd51a 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 20e2eca..abb46ab 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 171ec39..ded7b8a 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 4cbab9a..e397d58 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 abb46ab..6374bc2 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 121e68a..d688f64 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 e397d58..e5978e2 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 6374bc2..968bce7 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 e0e4c78..7c7ca4b 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; +}