hyoo_artist
v0.0.2
Published
**M**am owns language-**A**gnostic **M**odules. This is base **MAM** project.
Maintainers
Keywords
Readme
MAM
Mam owns language-Agnostic Modules. This is base MAM project.
Articles
Features
- Agnostic modules. Module is directory with mixed source files (JS, TS, CSS, JSON, HTML, Tree, images etc).
- Automatic dependency tracking. You don't need import/export - simply use namespaced names in accordance to directory structure, like
$mol_button_major/$jin.time.momentin*.JAM.JS/*.TSor--mol_theme_back/[mol_page_title]/.my-header-avatarin*.CSS. - Development server with automatic bundling on request. Only if you use it then it will have bundled.
- Build any module as standalone bundle. You can develope thousand of modules in one project.
- Cordova project generation. Simply add
config.xmlto module and-cordovadir with cordova project will have generated.
Cloud usage
Installation
Checkout this repo (~2s):
git clone https://github.com/hyoo-ru/mam.git ./mam && cd mamLinux limits
$mol_build and typescript uses inotify by default on Linux to monitor directories for changes. It's not uncommon to encounter a system limit on the number of files you can monitor.
/etc/sysctl.d/20-watch.conf
fs.inotify.max_user_watches=524288
fs.file-max=500000Development server
Install node modules and build dev server from actual sources
npm installStart dev server:
npm startOpen simple $mol based ToDoMVC application:
start http://localhost:9080/hyoo/todomvc/-/test.htmlManual build
- Execute
npm start hyoo/todomvcto build standalone ToDoMVC application athyoo/todomvc/-. - Execute
npm start mol/regexpto build standalone $mol_regexp library atmol/regexp/-.
NPM Integration
Publish to NPM
npm start mol/regexp
npm publish mol/regexp/-Usage from NPM
Import to CJS
const { $mol_regexp: RE } = require( 'mol_regexp' )Import to ESM
import { $mol_regexp as RE } from 'mol_regexp'NodeJS dependencies
Using $node namespace you can auto-install and dynamically lazy load any NPM packages:
const isOdd = $node['is-odd']( '123' )Bundling NPM dependencies
It's better to use implementations from MAM ecosystem. But you can bundle NPM packages too through adapter like:
// lib/ramda/ramda.ts
namespace $ {
export let $lib_ramda = require('ramda/src/index.js') as typeof import('ramda')
}Custom package
- Create dir for your namespace.
myin example. - Create dir for your module.
my/alertin example. - Create module source file.
my/alert/alert.tswith contentfunction $my_alert( msg : string ) { alert( msg ) }in example. - Create dir for your application module.
my/appin example. - Create application source file.
my/app/app.tswith content$my_alert( 'Hello, World!' )in example. - Create application web entry point.
my/app/index.htmlwith content<script src="-/web.js"></script>in example. - Start development server:
npm start - Open your application.
http://localhost:9080/my/app/-/test.htmlin example.
MAM based projects
- https://github.com/hyoo-ru?q=hyoo.ru
