npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@concepto/interface

v2.2.734

Published

Concepto DSL - visually create and maintain modern node.js based apps (@interface)

Downloads

40

Readme

Description

Language Class Interface for creating DSL parsers for Concepto DSL

API Reference

Concepto DSL Base Class: A base class (to be extended) for defining new languages for Concepto to be compiled to.

concepto.init()

Initializes/starts the class

Kind: instance method of concepto

concepto.autocompleteContentTemplate(record, render) ⇒ string

Renders an HTML template for displaying an autocomplete item within the IDE Should return the rendered HTML

Kind: instance method of concepto
Returns: string - - HTML template

| Param | Type | Description | | --- | --- | --- | | record | AutocompleteItem | autocomplete item record | | render | Object | render object with default methods for rendering autocomplete items | | render.placeholders | function | internal function to escape {icon}:x placeholders; returns modified string with rendered icons | | render.icon | function | internal function to call to render any given icon into an img tag; you can either call this or use your own method within the code | | render.attrs | function | internal function to call to render the item attributes as an html table |

concepto.addAutocompleteDefinition([extends_], [parentsAll], [parents], [childrenTypes], [id], [text], [type], [icons], [level], [hint], [attributes]) ⇒ Object

Adds the given definition for the generation of autocomplete files recods

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | [extends_] | String | extends autocomplete record; | | [parentsAll] | Array | required node parents of this definition; empty means any; * means item must match all parents listed | | [parents] | Array | posible node parents of this definition; empty means any; * means item must be partof | | [childrenTypes] | Array | posible children type nodes; empty means no restrictions | | [id] | String | Unique AC node identifier (usually the 'text') | | [text] | String | Node text (ex. 'consultar modelo "x",') to be shown to used within list | | [type] | String | Node type (ex. 'view') to be shown to used within list; empty by default | | [icons] | Array | Array of icons (in order) for autocomplete node detection | | [level] | Array | Array of levels of node definition to be detected (1=root, 2=child, 3=grandchild, etc) | | [hint] | String | Hint to show user for command completion | | [attributes] | Object | Possible node command attributes (ex. { 'id':{ required:true, type:'number', values:'1,2,3', hint:'id of datamodel' } }) |

concepto.reply_template([init]) ⇒ Object

Sets the default reply Object for commands

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | [init] | Object | Merges given object keys with default defined template |

concepto.onInit()

Gets automatically executed after init method finishes. You should place any parser preparation steps here (ex. load commands)

Kind: instance method of concepto

concepto.onAfterProcess(processedNode) ⇒ Object

Gets automatically executed after parsing all nodes level 2 of the given dsl (before onCompleteCodeTemplate)

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | processedNode | Object | reply content of process method per processed level2 node (keys of reply_template method) |

concepto.onDefineTitle(node) ⇒ String

Gets automatically executed within writer method for setting the title for a node level 2.

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | node | NodeDSL | node to process |

concepto.onDefineFilename(node) ⇒ String

Gets automatically executed for naming filename of class/page by testing node (you could use a slud method here).

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | node | NodeDSL | node to process |

concepto.onDefineNodeName(node) ⇒ String

Gets automatically called for naming the class/page by testing node (similar to a filename, but for objects reference).

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | node | NodeDSL | node to process |

concepto.onCompleteCodeTemplate(processedNode) ⇒ Object

Defines template for code given the processedNodes of writer(). Useful to prepend/append code before writting code to disk.

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | processedNode | Object | reply content of process method per processed level2 node (keys of reply_template method) |

concepto.onPrepare()

Defines preparation steps before processing nodes.

Kind: instance method of concepto

concepto.onErrors(errors)

Gets automatically called after errors have being found while processing nodes (with the defined commands)

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | errors | Array.<string> | array of errors messages |

concepto.onCreateFiles(processedNodes)

Gets automatically called after all processing on nodes has being done. You usually create the files here using the received processedNodes array.

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | processedNodes | Array.<Object> | array of nodes already processed (keys of reply_template method) ready to be written to disk |

concepto.onEnd()

Gets automatically called after all processes have finished. Useful for cleaning the enviroment.

Kind: instance method of concepto

concepto.addCommands(command_func)

Add commands for processing nodes with the current class

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | command_func | function | async function returning an object with commands objects (Command) where each key is the command id, and its value a Command object. |

concepto.cacheCommands()

Detects which x_commands changed their code since last persistant cache usage. To be called before process().

Kind: instance method of concepto

concepto.findCommand(node, [justone]) ⇒ Command | Array.<Command>

Finds one or more commands defined that matches the specs of the given node.

Kind: instance method of concepto

| Param | Type | Default | Description | | --- | --- | --- | --- | | node | NodeDSL | | node for which to find commands that match | | [justone] | boolean | true | indicates if you want just the first match (true), or all commands that match the given node (false) |

concepto.abortProcessing() ⇒ Command | boolean

Signals an abort event for the processing methods.

Kind: instance method of concepto

concepto.findValidCommand(node, [object]) ⇒ Command | boolean

Finds the valid/best command match for the given node. Also tests the command for its 'valid' attribute, in case the command func specified aditional conditions. If no command is found, returns false.

Kind: instance method of concepto

| Param | Type | Default | Description | | --- | --- | --- | --- | | node | NodeDSL | | node for which to find the command | | [object] | boolean | false | if false returns the command reference, true returns the command execution answer |

concepto.process() ⇒ Object

This method traverses the dsl parsed tree, finds/execute x_commands and generated code as files.

Kind: instance method of concepto

concepto.array_intersect(arr1, arr2) ⇒ Array.<string> | Array.<Object> | Array.<boolean>

Helper method for obtaining the common values (which can be anything) between two arrays.

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | arr1 | Array.<string> | Array.<Object> | Array.<boolean> | first array | | arr2 | Array.<string> | Array.<Object> | Array.<boolean> | second array |

concepto.array_substract(arr1, arr2) ⇒ Array.<string> | Array.<Object> | Array.<boolean>

Helper method for obtaining the first array items minus the second array items (which can be anything).

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | arr1 | Array.<string> | Array.<Object> | Array.<boolean> | first array from which to substract | | arr2 | Array.<string> | Array.<Object> | Array.<boolean> | second array with items to substract from arr1 |

concepto.array_difference(arr1, arr2) ⇒ Array.<string> | Array.<Object> | Array.<boolean>

Helper method for obtaining the unique values (which can be anything) between two arrays.

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | arr1 | Array.<string> | Array.<Object> | Array.<boolean> | first array | | arr2 | Array.<string> | Array.<Object> | Array.<boolean> | second array |

concepto.array_union(arr1, arr2) ⇒ Array.<string> | Array.<Object> | Array.<boolean>

Helper method for joining the values (which can be anything) between two arrays.

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | arr1 | Array.<string> | Array.<Object> | Array.<boolean> | first array | | arr2 | Array.<string> | Array.<Object> | Array.<boolean> | second array |

concepto.debug(message, [data])

Helper method for defining how to display (or do with them; if you overload it) debug messages.

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | message | string | Object | message to display. It can also be an Object of open-console params. | | [data] | * | data variable to show with message |

concepto.debug_time(id)

Helper method for measuring (start) time in ms from this method until debug_timeEnd() method and show it in the console.

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | id | string | id key (which can also have spaces and/or symbols) with a unique id to identify the stopwatch. |

concepto.exists(dir_or_file) ⇒ boolean

Helper to test if a given file exists or not

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | dir_or_file | string | full directory or file to test |

concepto.debug_timeEnd(id)

Helper method for measuring (end) time in ms from the call of debug_time() method.

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | id | string | id key used in the call for debug_time() method. |

concepto.debug_table(title)

Helper method for showing a table with each command execution time and amount of calls

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | title | string | Optional custom title for table. |

concepto.hasBrotherID(id, x_id) ⇒ Boolean

Helper method to return true if given node id has a brother of given command x_id

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | id | string | ID of NodeDSL object to query | | x_id | string | Command object x_id to test for |

concepto.hasBrotherBefore(id) ⇒ Boolean

Helper method to return true if given node ID has a brother before it

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | id | string | ID of NodeDSL object to query |

concepto.hasBrotherNext(id) ⇒ Boolean

Helper method to return true if given node ID has a brother following it

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | id | string | ID of NodeDSL object to query |

concepto.isExactParentID(id, x_id) ⇒ Boolean

Helper method to return true if given Command object x_id is the exact parent for the given NodeDSL object id

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | id | string | ID of NodeDSL object to query | | x_id | string | Command object x_id to test for |

concepto.hasParentID(id, x_id) ⇒ Boolean

Helper method to return true if given Command object x_id is the parent or is an ancestor for the given NodeDSL object id

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | id | string | ID of NodeDSL object to query | | x_id | string | Command object x_id to test for |

concepto.getParentIDs(id, array) ⇒ string | Array.<Object>

Helper method to return all Command object x_ids parents of given NodeDSL id; if array=true,

Kind: instance method of concepto

| Param | Type | Default | Description | | --- | --- | --- | --- | | id | string | | ID of NodeDSL object to query | | array | Boolean | false | If true, returns array of objects with x_id and ids, instead of a list of NodeDSL ids. |

concepto.getParentIDs2Array(id) ⇒ Array.<Object>

Helper method to return all Command object x_ids parents of given NodeDSL id as an array (its an alias for getParentIDs)

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | id | string | ID of NodeDSL object to query |

~~concepto.getParentIDs2ArrayWXID(id) ⇒ Array.<Object>~~

Deprecated

Helper method to return all NodeDSL ids parents of given NodeDSL id

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | id | string | ID of NodeDSL object to query |

concepto.tagParams(struct) ⇒ string

Helper method to return a tag with key/values as tag attributes

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | struct | Object | Object with keys and values to transform from. |

concepto.struct2params(struct) ⇒ string

Helper method to transform object keys/values into params for customtags usage

Kind: instance method of concepto

| Param | Type | Description | | --- | --- | --- | | struct | Object | Object with keys and values to transform from. |

concepto~AutocompleteItem : Object

An autocomplete object representing an item within the autocomplete list

Kind: inner typedef of concepto
Properties

| Name | Type | Description | | --- | --- | --- | | parentsAll | Array.<string> | Optionally indicates if this node item needs to have all of these parents (node texts for now). | | parents | Array.<string> | Optionally indicates if this node item needs to have any of these parents (node texts for now). | | extends_ | string | Optionally indicates if this item extends another existing one. | | text | string | Indicates the text to show; aka keyword to complete. | | hint | string | Indicates the html to show as the summary for the keyword. | | icons | Array.<string> | Array with icon names used in the node. | | level | Array.<number> | Array with supported level numbers. | | attributes | Object | Object with a key for each attribute supported by the node (the key is the attribute name, the value is an object with keys: type, default, hint - supports icon placeholders like {icon:idea} within their texts). | | events | Object | Object with a key for each event supported by the node. |

concepto~NodeDSL : Object

A node object representation of a DSL node.

Kind: inner typedef of concepto
Properties

| Name | Type | Description | | --- | --- | --- | | id | number | Node unique ID. | | level | number | Indicates the depth level from the center of the dsl map. | | text | string | Indicates the text defined in the node itself. | | text_rich | string | Indicates the html defined in the node itself. | | text_note | string | Indicates the text/html defined in the notes view of the node (if any). | | image | string | Image link defined as an image within the node. | | cloud | Object | Cloud information of the node. | | cloud.bgcolor | string | Background color of cloud. | | cloud.used | boolean | True if cloud is used, false otherwise. | | arrows | Array.<Arrow> | Visual connections of this node with other nodes #module_concepto..Arrow. | | nodes | Array.<NodeDSL> | Children nodes of current node. | | font | Object | Define font, size and styles of node texts. | | font.face | Object | Font face type used on node. | | font.size | Object | Font size used on node. | | font.bold | Object | True if node text is in bold. | | font.italic | Object | True if node text is in italics. | | style | string | Style applied to the node. | | color | string | Text color of node. | | bgcolor | string | Background color of node. | | link | string | Link defined on node. | | position | string | Position in relation of central node (left,right). | | attributes | Object | Object with each attribute (key is attribute name, value is attribute value). | | icons | Array.<string> | Array with icon names used in the node. | | date_modified | date | Date of node when it was last modified. | | date_created | date | Date of node when it was created. |

concepto~Arrow : Object

Arrow object definition, for connections to other nodes within a DSL.

Kind: inner typedef of concepto
Properties

| Name | Type | Description | | --- | --- | --- | | target | string | Target node ID of connection. | | color | string | Color of visual connection. | | style | string | Graphical representation type of link (source-to-target, target-to-source, both-ways). |

concepto~Command : Object

A command object specifying requirements for a node to execute its function.

Kind: inner typedef of concepto
Properties

| Name | Type | Description | | --- | --- | --- | | [x_icons] | string | List of required icons that the node must define to be a match for this command. | | [x_not_icons] | string | List of icons that the node cannot define to be a match for this command. | | [x_not_empty] | string | List of keys that must not be empty to be a match for this command (can be any key from a NodeDSL object). Example: 'attribute[src],color' | | [x_not_text_contains] | string | List of strings, which cannot be within the node text. | | [x_empty] | string | List of NodeDSL keys that must be empty to be a match for this command. | | [x_text_contains] | string | List of strings, that can be contain in node text (if delimiter is |) or that must be all contained within the node text (if delimiter is comma). | | [x_text_pattern] | string | Array.<string> | Minimatch pattern to match to be a match for this command. Can also be an array of patterns (one must match). | | [x_level] | string | Numeric conditions that the level of the node must met (example: '>2,<5' or '2,3,4'). | | [x_all_hasparent] | string | List of commands ids (keys), which must be ancestors of the node to be a match for this command. | | [x_or_hasparent] | string | List of commands ids (keys), which at least one must be an ancestor of the node to be a match for this command. | | [x_or_isparent] | string | List of commands ids (keys), which at least one must be the exact parent of the node to be a match for this command. | | [autocomplete] | Object | Describes the node for the autocomplete feature of Concepto DSL software and its related documentation. The feature also takes into account the definition of the command (x_level and x_icons) | | [autocomplete.key_text] | string | String that the node text must have for this command to be suggested. | | [autocomplete.hint] | string | Text description for this command to be shown on Concepto DSL. | | func | function | Function to execute with a matching node. Receives one argument and it must be a NodeDSL object. |


© 2020-2022 Pablo Schaffner <[email protected]>.