Near-Reality:Lua/Helper modules: Difference between revisions
| No edit summary Tag: Reverted | No edit summary Tag: Reverted | ||
| Line 3: | Line 3: | ||
| <dpl> | <dpl> | ||
| namespace = Module | namespace = Module | ||
| uses = Template: | uses = Template:Helper module | ||
| titlematch = %/doc | titlematch = %/doc | ||
| nottitlematch = Helper_module/doc | nottitlematch = Helper_module/doc | ||
Revision as of 21:00, 3 October 2022
This is a table of modules and functions that were created specifically for facilitating the creation of other modules. Documentation for modules here is done in the source code with Template:Helper module.
| Module | Function | Type | Use | 
|---|---|---|---|
| Addcommas | _add(arg) | Number | Formats the number arg with commas | 
| _strip(arg) | Number | Removes all commas from arg | |
| Coins | _amount(coins) | Number | Returns a formatted string with a coins icon and the amount of coins. See Template:Coins for examples. | 
| DPLlua | ask( ... ) | tables | asktakes a series of tables each containing the settings for a DPL query; it will return the same number of result tables as input tables. All formatting settings are stripped from the config. If the config does not containsinclude, the result will be a simple list of page names.{
	<pagename#1>,
	<pagename#2>,
	<pagename#3>,
}
A query with an  {
	['include'] = {
		['template#1'] = {
			[1] = val#1,
			[2] = val#2,
			['param1'] = val#3,
			['param2'] = val#4,
		},
		['template#2'] = {
			[3] = val#5,
			['param1'] = val#6,
		},
		['%0'] = val#7
	},
	['title'] = <pagename>
}
You can also do  If the config value  The output contains a  If the DPL throws an error it will be available in the  Differences with normal DPL: 
 |notcategory = val#1 |notcategory = val#2Note of warning, if you include content containing §symbols the result may be unreliable. If you include a whole template (e.g.include = '{some template}'), content inside strip markers (not nowiki) can't be cleaned up inside lua so pipe characters (|) will be replaced with§characters and the{and}characters are replaced by❴(U+2774) and❵(U+2775). Useinclude = '{some template}, {some template}:1:2:3'instead for the problem parameters. | 
| Edit button | (text) | string | Creates an edit button for the current page that the module is invoked on textdefaults to "edit" | 
| Enum | any(enum, [fn], [clone|false]) | table, function/nil, boolean/nil | Loops over the array part of enumand passes each element as the first argument tofn. Iffnreturnstruefor at least one element thenany()returnstrue, otherwisefalse. If no function is givenfunction(item) return item endis used. Ifcloneistruethe inputenumis deep copied usingmw.clone()before use. | 
| all(enum, [fn], [clone|false]) | table, function/nil, boolean/nil | Loops over the array part of enumand passes each element as the first argument tofn. Iffnreturnstruefor all elements thenall()returnstrue, otherwisefalse. If no function is givenfunction(item) return item endis used. | |
| each(enum, fn, [clone|false]) | table, function, boolean/nil | Loops over the array part of enumand passes each element as the first argument tofn. This function returns nothing. | |
| sum(enum, [clone|false]) | table, boolean/nil | Returns the sum of all array elements in enum. | |
| reduce(enum, fn, [accumulator|enum[1]], [clone|false]) | table, function, any, boolean/nil | Loops over the array part of enumand passes each element as the first argument andaccumulatoras the second tofn. The return value offnbecomes the newaccumulator. The final value ofaccumulatoris returned. If noaccumulatoris given then the first element inenumis used. | |
| scan(enum, fn, [accumulator|enum[1]], [clone|false]) | table, function, any, boolean/nil | Same as reduce()but each step is appended to a table. This table is then returned. | |
| find(enum, fn, [default|nil], [clone|false]) | table, function, any, boolean/nil | Loops over the array part of enumand passes each element as the first argument tofn. The first element wherefnreturnstrueis returned. If no elements passes the test,defaultis returned. | |
| find_index(enum, fn, [default|nil], [clone|false]) | table, function, any, boolean/nil | Loops over the array part of enumand passes each element as the first argument tofn. The index of the first element wherefnreturnstrueis returned. If no elements passes the test,defaultis returned. | |
| max_by(enum, fn, [clone|false]) | table, function, boolean/nil | Loops over the array part of enumand passes each element as the first argument tofn.max_by()returns two values, the first is the element wherefnreturned the largest value, the second is this largest value. The>operator is used for the comparisons. | |
| map(enum, fn, [clone|false]) | table, function, boolean/nil | Loops over the array part of enumand passes each element as the first argument tofn. The return value offnis appended to a new table. This new table is returned. | |
| filter(enum, [fn], [clone|false]) | table, function/nil, boolean/nil | Loops over the array part of enumand passes each element as the first argument tofn. Iffnreturnstruethe corresponding element is copied to a new table which is then returned. If no function is givenfunction(item) return item endis used. | |
| reject(enum, [fn], [clone|false]) | table, function, boolean/nil | The opposite of filter(). | |
| split(enum, count, [clone|false]) | table, number, boolean/nil | Returns two tables where the first is equivalent to slice(enum, 1, count)and the secondslice(enum, count+1, #enum). | |
| slice(enum, [start|1], [stop|#enum], [clone|false]) | table, number/nil, number/nil, boolean/nil | Returns a table containing all the elements of enumbetween thestartandstopindices. Thestartandstopindices are inclusive. | |
| take(enum, count, [clone|false]) | table, number, boolean/nil | Returns only the first table of split(enum, count). | |
| take_every(enum, n, [clone|false]) | table, number, boolean/nil | Returns a table containing every nth element of enum. | |
| unique(enum, [fn], [clone|false]) | table, function/nil, boolean/nil | Returns a new table where all duplicate values in enumare removed. In case a duplicate is present, the element with the lowest index will be kept and every subsequent duplicate element is removed.fncan be used to create a custom id for every element so that the result is a table with elements which all create a unique id. If no function is givenfunction(item) return item endis used. | |
| zip(enums, [clone|false]) | table, boolean/nil | Groups elements with the same indexes from different arrays together, i.e. zip{ {a1, a2, a3}, {b1, b2, b3}, {c1, c2} } -> {{a1, b1, c1}, {a2, b2, c2}, {a3, b3}} | |
| intersect(enum1, enum2, [clone|false]) | table, table, boolean/nil | Returns trueif both sets have at least one element with equal values. | |
| contains(enum, elem, [clone|false]) | table, any, boolean/nil | Returns trueifenumcontainselem, otherwise returns false. | |
| take_from(enum, index, count) | table, number, number | Returns countnumber of elements, starting atindex | |
| Exchange | _price(arg) | String | Gets the current GE price of item named arg | 
| _price(arg, multi, format, round, default) | String | Gets the current GE price of item named arg, multiplied by [multi] (default 1), rounded to [round] decimal places (default unrounded), and if [format] is true, formatted with thousands separators (default false). If the item does not exist, an error is thrown, unless [default] is set, in which case it will return the given [default] value. | |
| _value(arg) | String | Gets the value of item named arg | |
| _highalch(arg) | String | Gets the high alch value of item named arg, accounting for alch multipliers | |
| _lowalch(arg) | String | Gets the low alch value of item named arg, accounting for alch multipliers | |
| _alchable(arg) | String | Gets the alchablility (boolean) of item named arg | |
| _alchmultiplier(arg) | String | Gets the alchemy multiplier of item named arg (default 0.6) | |
| _limit(arg) | String | Gets the GE limit of item named arg | |
| _diff(arg, format) | String | Gets the difference of the current GE price and the previous GE price for item named arg. If format is true, formats the number with thousands separators | |
| _exists(arg) | String | Checks if the module for item named arg exists, returns a boolean | |
| Mainonly | _main(arg) | Any value | If the module is invoked in the content namespace, it will return arg, otherwise, it will return an empty string | 
| on_main() | N/A | Returns true if invoked in the content namespace, otherwise false | |
| Mw.html extension | addClassIf(cond, class) | boolean, string | If cond=trueit behaves the same as the normaladdClassfunction, otherwise it's a no-op. Ex.:mw.html.create('div'):addClassIf(true, 'align-left-1') | 
| attrIf(cond, name, value) | boolean, string/table, string/nil | Similar to addClassIf | |
| cssIf(cond, name, value) | boolean, string/table, string/nil | Similar to addClassIf | |
| doneIf(cond) | boolean | Similar to addClassIf | |
| tagIf(cond, tag) | boolean, string | Similar to addClassIf | |
| wikitextIf(cond, text) | boolean, string | Similar to addClassIf | |
| na() | N/A | Shortcut for :tag('td'):attr('data-sort-value', 0):attr('class','table-na'):wikitext('<small>N/A</small>'):done() | |
| naIf(cond) | boolean | Similar to addClassIf | |
| tr([settings]) | table/nil | Shortcut for :tag('tr')but also auto closes the previous 'tr', 'th' or 'td' tag (so you don't need to add :done() before it). settings is a table with keys:
 | |
| th([settings]) | string/table/nil | Shortcut for :tag('th'):wikitext(settings)if settings is a string. Also auto closes the previous 'th' or 'td' tag. settings can also be a table with keys:
 | |
| td([settings]) | string/table/nil | Same as :th(). Example:local tbl = mw.html.create('table')
tbl:tr{ class='sortable' }
        :th{'foo', attr={'data-sort-type', 'number'}}
        :th('bar')
    :tr()
        :td('buz')
            :attr('data-sort-value', 10)
        :td{'N/A', class='table-na'} | |
| IF(cond) | boolean | Allows for if-blocks without breaking the chain. If the condition is true it is a no-op, if false everything inside the balanced IF-END block will be ignored. Can be nested. Ex.: mw.html.create('div')
    :IF(true)
        :wikitext('Conditional text')
    :END()
    :...Note: This only prevents elements from being added to your html object, it does not protect against statements that throw errors. I.e mw.html.create('div')
    :IF(false)
        :wikitext(5 * nil) -- This will still throw an error
    :END() | |
| ELSEIF(cond) | boolean | Used together with IF(). | |
| ELSE() | N/A | Used together with IF(). | |
| END() | N/A | Used together with IF(). Make sure the IF-END tags are balanced, it wont throw an error if they are not. | |
| exec(func, ...) | function, any | Call a function without breaking the chain. See module docs for more info. | |
| addFunction(func, name) | function, string | Add a function to the mw.html class that can then be used on mw.html object. See module docs for more info. | |
| Number | _round(num, dp) | float, int | Rounds numto a precision given bydp, ifdpis not specified, it defaults to zero. Rounds half up. | 
| _short(str) | String | Convert numbers ending in k, m or b to the actual correct number. Example: 3.5k -> 3500 | |
| Paramtest | is_empty(arg) | String | Returns true if arg is not defined or contains only whitespace | 
| has_content(arg) | String | Returns true if arg exists and does not only contain whitespace | |
| default_to(arg1,arg2) | String, Any value | If arg1 exists and does not only contain whitespace, the function returns arg1, otherwise returns arg2 | |
| defaults{ {arg1,arg2},...} | {String, Any value}... | Does the same as default_to()run over every table passed; for technical reasons, allnilare replaced withfalse | |
| Top icons | _main(args) | String | Returns a string that adds top icons to the page. argsmust be a table of arguments. Numbered arguments must have values ofrs,rsc,metaorwp. To provide a specific pagename on the top icon link, specify named arguments with those same indices, with the value being the external pagename. | 
| Yesno | (arg) | Any value | Reads arg for yes/no and returns the appropriate boolean or nil | 
| (arg1,arg2) | Any value, Any value | Reads arg1 for yes/no and returns the appropriate boolean; returns arg2 if arg1 was not an applicable value |