mirror of
https://github.com/showdownjs/showdown.git
synced 2024-03-22 13:30:55 +08:00
feat(getFlavor): add getFlavor method to showdown and Converter
With this new method, you can check what type of base flavor showdown is currently set to run as.
This commit is contained in:
parent
a58674e597
commit
0eaf1050c7
|
@ -292,7 +292,10 @@ var defaultOptions = showdown.getDefaultOptions();
|
||||||
|
|
||||||
* **requireSpaceBeforeHeadingText**: (boolean) [default false] Makes adding a space between `#` and the header text mandatory (since v1.5.3)
|
* **requireSpaceBeforeHeadingText**: (boolean) [default false] Makes adding a space between `#` and the header text mandatory (since v1.5.3)
|
||||||
|
|
||||||
* **ghMentions**: (boolean) [default false] Enables github @mentions, which link to the username mentioned (since v1.5.6)
|
* **ghMentions**: (boolean) [default false] Enables github @mentions, which link to the username mentioned (since v1.6.0)
|
||||||
|
|
||||||
|
|
||||||
|
**NOTE**: Please note that until version 1.6.0, all of these options are ***DISABLED*** by default in the cli tool.
|
||||||
|
|
||||||
## Flavors
|
## Flavors
|
||||||
|
|
||||||
|
|
BIN
dist/showdown.js
vendored
BIN
dist/showdown.js
vendored
Binary file not shown.
BIN
dist/showdown.js.map
vendored
BIN
dist/showdown.js.map
vendored
Binary file not shown.
BIN
dist/showdown.min.js
vendored
BIN
dist/showdown.min.js
vendored
Binary file not shown.
BIN
dist/showdown.min.js.map
vendored
BIN
dist/showdown.min.js.map
vendored
Binary file not shown.
|
@ -38,7 +38,12 @@ showdown.Converter = function (converterOptions) {
|
||||||
* @private
|
* @private
|
||||||
* @type {{}}
|
* @type {{}}
|
||||||
*/
|
*/
|
||||||
listeners = {};
|
listeners = {},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The flavor set in this converter
|
||||||
|
*/
|
||||||
|
setConvFlavor = setFlavor;
|
||||||
|
|
||||||
_constructor();
|
_constructor();
|
||||||
|
|
||||||
|
@ -362,14 +367,24 @@ showdown.Converter = function (converterOptions) {
|
||||||
* @param {string} name
|
* @param {string} name
|
||||||
*/
|
*/
|
||||||
this.setFlavor = function (name) {
|
this.setFlavor = function (name) {
|
||||||
if (flavor.hasOwnProperty(name)) {
|
if (!flavor.hasOwnProperty(name)) {
|
||||||
|
throw Error(name + ' flavor was not found');
|
||||||
|
}
|
||||||
var preset = flavor[name];
|
var preset = flavor[name];
|
||||||
|
setConvFlavor = name;
|
||||||
for (var option in preset) {
|
for (var option in preset) {
|
||||||
if (preset.hasOwnProperty(option)) {
|
if (preset.hasOwnProperty(option)) {
|
||||||
options[option] = preset[option];
|
options[option] = preset[option];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the currently set flavor of this converter
|
||||||
|
* @returns {string}
|
||||||
|
*/
|
||||||
|
this.getFlavor = function () {
|
||||||
|
return setConvFlavor;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -7,6 +7,7 @@ var showdown = {},
|
||||||
parsers = {},
|
parsers = {},
|
||||||
extensions = {},
|
extensions = {},
|
||||||
globalOptions = getDefaultOpts(true),
|
globalOptions = getDefaultOpts(true),
|
||||||
|
setFlavor = 'vanilla',
|
||||||
flavor = {
|
flavor = {
|
||||||
github: {
|
github: {
|
||||||
omitExtraWLInCodeBlocks: true,
|
omitExtraWLInCodeBlocks: true,
|
||||||
|
@ -90,13 +91,36 @@ showdown.resetOptions = function () {
|
||||||
*/
|
*/
|
||||||
showdown.setFlavor = function (name) {
|
showdown.setFlavor = function (name) {
|
||||||
'use strict';
|
'use strict';
|
||||||
if (flavor.hasOwnProperty(name)) {
|
if (!flavor.hasOwnProperty(name)) {
|
||||||
|
throw Error(name + ' flavor was not found');
|
||||||
|
}
|
||||||
var preset = flavor[name];
|
var preset = flavor[name];
|
||||||
|
setFlavor = name;
|
||||||
for (var option in preset) {
|
for (var option in preset) {
|
||||||
if (preset.hasOwnProperty(option)) {
|
if (preset.hasOwnProperty(option)) {
|
||||||
globalOptions[option] = preset[option];
|
globalOptions[option] = preset[option];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the currently set flavor
|
||||||
|
* @returns {string}
|
||||||
|
*/
|
||||||
|
showdown.getFlavor = function () {
|
||||||
|
'use strict';
|
||||||
|
return setFlavor;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the options of a specified flavor. Returns undefined if the flavor was not found
|
||||||
|
* @param {string} name Name of the flavor
|
||||||
|
* @returns {{}|undefined}
|
||||||
|
*/
|
||||||
|
showdown.getFlavorOptions = function (name) {
|
||||||
|
'use strict';
|
||||||
|
if (flavor.hasOwnProperty(name)) {
|
||||||
|
return flavor[name];
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -27,24 +27,14 @@ describe('showdown.Converter', function () {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('setFlavor method', function () {
|
describe('converter.setFlavor()', function () {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test setFlavor('github')
|
* Test setFlavor('github')
|
||||||
*/
|
*/
|
||||||
describe('github', function () {
|
describe('github', function () {
|
||||||
var converter = new showdown.Converter(),
|
var converter = new showdown.Converter(),
|
||||||
ghOpts = {
|
ghOpts = showdown.getFlavorOptions('github');
|
||||||
omitExtraWLInCodeBlocks: true,
|
|
||||||
prefixHeaderId: 'user-content-',
|
|
||||||
simplifiedAutoLink: true,
|
|
||||||
literalMidWordUnderscores: true,
|
|
||||||
strikethrough: true,
|
|
||||||
tables: true,
|
|
||||||
tablesHeaderId: true,
|
|
||||||
ghCodeBlocks: true,
|
|
||||||
tasklists: true
|
|
||||||
};
|
|
||||||
|
|
||||||
converter.setFlavor('github');
|
converter.setFlavor('github');
|
||||||
|
|
||||||
|
@ -61,6 +51,33 @@ describe('showdown.Converter', function () {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('getFlavor method', function () {
|
||||||
|
|
||||||
|
// reset showdown
|
||||||
|
showdown.setFlavor('vanilla');
|
||||||
|
|
||||||
|
describe('flavor', function () {
|
||||||
|
it('should be vanilla by default', function () {
|
||||||
|
var converter = new showdown.Converter();
|
||||||
|
converter.getFlavor().should.equal('vanilla');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be changed if global option is changed', function () {
|
||||||
|
showdown.setFlavor('github');
|
||||||
|
var converter = new showdown.Converter();
|
||||||
|
converter.getFlavor().should.equal('github');
|
||||||
|
showdown.setFlavor('vanilla');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not be changed if converter is initialized before global change', function () {
|
||||||
|
var converter = new showdown.Converter();
|
||||||
|
showdown.setFlavor('github');
|
||||||
|
converter.getFlavor().should.equal('vanilla');
|
||||||
|
showdown.setFlavor('vanilla');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('extension methods', function () {
|
describe('extension methods', function () {
|
||||||
var extObjMock = {
|
var extObjMock = {
|
||||||
type: 'lang',
|
type: 'lang',
|
||||||
|
|
|
@ -109,3 +109,25 @@ describe('showdown.getAllExtensions()', function () {
|
||||||
showdown.getAllExtensions().should.eql({bar: [extObjMock]});
|
showdown.getAllExtensions().should.eql({bar: [extObjMock]});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('showdown.setFlavor()', function () {
|
||||||
|
'use strict';
|
||||||
|
it('should set flavor to github', function () {
|
||||||
|
showdown.setFlavor('github');
|
||||||
|
showdown.getFlavor().should.equal('github');
|
||||||
|
showdown.setFlavor('vanilla');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should set options correctly', function () {
|
||||||
|
showdown.setFlavor('github');
|
||||||
|
var ghOpts = showdown.getFlavorOptions('github'),
|
||||||
|
shOpts = showdown.getOptions();
|
||||||
|
for (var opt in ghOpts) {
|
||||||
|
if (ghOpts.hasOwnProperty(opt)) {
|
||||||
|
shOpts.should.have.property(opt);
|
||||||
|
shOpts[opt].should.equal(ghOpts[opt]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
showdown.setFlavor('vanilla');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
Loading…
Reference in New Issue
Block a user