this is the @magic core library.
builds a webapp with deeply nested component structure and globally/locally shared state and actions.
client html + css + js boilerplate = ~15kb uncompressed.
to get more information, head to the docs / demo
other related github organizations:
- @magic-modules - building blocks for your app
- @magic-themes - themes for your app
- @magic-libraries - client libraries
first commit
use @magic npm packages instead of github for installs
- update dependencies
- make @magic actually work in the client if @magic-modules/gdpr is not installed.
- dev server now correctly redirects urls if the trailing slash is missing
- html and markdown files can include state and variables
- @magic-themes can now add variables to the css colors without overwriting the default colors
- @magic-modules/messages gets autoloaded if it is installed.
- components now can be nested without array. div([p('text')]) can also be div(p('text'))
- Link({ to: '#hashLink' }) is local now
- very early blog implementation. it works, but the archive pages need more work.
always delete .tmp dir
fix 404 page regression
- blog/year/month archive pages are not 404'ing.
- blog archive pages now have links in them if needed (year page links to each month archive page)
- blog posts are wrapped in BlogPost automagically. BlogPost adds header and description automagically.
- config.HOIST allows adding any module at the bottom of the page (gdpr, messages will use that)
- config.HOIST can be an array or a string
- config.HOIST defaults to empty array
- app.actions.gdpr will only be added if Gdpr is included in config.HOIST
- allow arbitrary, module and page level init effects for initialState
- add SkipLink for screen readers. hash links to page start
- libraries can now be named with a - in their name and get camelCased
- svg tags are actually usable now. except color-profile and switch.
- update @magic/css which updates postcss
- color theme vars now export grey and bluegrey. copies gray and bluegray.
- config.BABEL is now being used for babel build
- config.THEME_VARS can be a function. gets passed { colors } if it is a function.
regression: babel should minify files on build.
- modules/MenuItem: only add submenu ul if submenu has items.length > 0
- link menu parent .to only gets prepended to link.to if link.to starts with - or #, not if it starts with /.
- add modules/MenuLink. use it in modules/MenuItem
- commonjs support is gone.
- minimum node version bumped to 13.5.0
- modules/Router.mjs: Link module now accepts action as prop
- modules/Router.mjs: scroll page back to top if the clicked link points to current page root
do not error if docs/sri-hashes.json does not exist
minimum node version of dependencies bumped to 13.5.0
- update dependencies
- update theme to show list-style for ordered lists (ol)
- better error handling
- remove lib/fs, use @magic/fs everywhere
- is @magic/types for isUpperCase and isLowerCase
add viewport and ie=edge html meta tags.
tasks/prepare/css: also load themes directly from node_modules/${theme_name}.
- all hail eris!
- css styles now inherit THEME_VARS from all possible source before transpiling styles.
- colors.bluegrey now is alias for colors.bluegray instead of undefined.
- client side routing scrolls to top in all cases, but is not animated. scroll-behavior + window.scroll() = bug
- Router: set document.title on pushstate if possible
- Seo: add image for social previews
- fix: do not error if none of the pages has state.title set.
config.IGNORED_STATIC is an array. can include path ('/file.ext') or extension ('.ext') strings.
do not create sri-hashes for config.IGNORED_STATIC files
themes can export Modules now, which can overwrite builtins.
fix some edgecases with exported theme modules
local config.THEME_VARS get deep merged over theme provided THEME_VARS now.
if multiple themes are installed, the last imported theme will overwrite earlier imported themes and their vars.
fix race condition in case of multiple themes. modules did not always get overwritten in the correct order.
MenuItem: fix link handling for rooted links. initial / will not be removed from links.
- themes: merge state, actions, effects, and subscriptions into app.
- maybeApp import: only suppress error if it is E_MODULE_NOT_FOUND.
fix: hash routing in webkit works (chromium, brave tested)
modules/app: correctly merge maybeApp and theme state, actions, effects and subscriptions.
- config: IGNORED_STATIC can be a string.
- config: items in IGNORED_STATIC do not have to start with a dot. will be added if it is missing.
- babel errors tell us to run
npm run format
to find the source of the error. Sourcemaps tbd - build worker process should always exit with process.exit(1), not panic.
- babel: do not mangle toplevel names. broke builds, adds 1kb+ to js. investigate, exterminate.
- only load Modules from theme if their names are CamelCased.
- handle state as a function in all imports, call it with config param
- @magic/transform handles @magic-modules now, which makes pure markdown pages possible.
fix: HOISTing broke in 0.0.39
hoisting happens in the footer.
fix: theme modules are now getting imported again.
update @magic/transmute: @magic-modules in markdown are no longer wrapped in p tags
add Credit module
add b, strong, i, and em styles (bold and italic)
- no more race conditions when importing multiple themes.
- Logo link works again.
modules/app: page.state gets inherited properly, markdown pages can see global state now.
import originalState from transmuted bundle.
FIX: process would hang if a markdown or html page had no state.
document.title does not error in client if only one page exists.
- nested state variables in template strings eg {{state.test.deep.var}} now work.
- replace parse5 with posthtml.
- custom markdown and custom html renderers added.
- @magic-modules in markdown and html can have keys that are arrays or objects now.
- state variables in template strings can be arrays (eg state.description). will be join(' ')ed
fix: remove admin for now
- transmute now returns empty strings instead of empty arrays and objects.
- transmute/render/markdown.codespan: do not show line numbers for code spans.
- do not pass modules to transmute.
@magic/transmute now correctly unescapes quot entities.
- Credits module does not error if style variables are not set.
tasks/prepare: module.state extends, but does not overwrite app.state when importing modules
update @magic/transmute, which now actually replaces all occurrences of html entities in a string, not just the first one.
- tasks/serve/handler: use array to collect req.body data. strings break unicode characters if the chunks split a character on transit
- only create sri-hashes for static files in conf.INCLUDED_HASH_EXTENSIONS
- update dependencies => minimist vuln
- modules/Router/Link.onclick: now also resets window.location.hash if the hash did not change.
- tasks/serve/handler: response data chunks are now always buffers.
update babel and @magic/transmute
update babel jsx and @magic/transmute
modules/Seo now allows arbitrary header fields.
modules/Header passes state.theme to Logo
magic can now serve a log of mime-types. see @magic/mime-types for full list
update dependencies
update @magic/transmute
@magic/transmute does not add p tags around Link and Img elements.
update dependencies
update dependencies
- update dependencies
- sri-hashes.json is a flat object: key = path, value = hash
- bump required node version
- update dependencies
- cli help expanded
- cli flags get passed to config
- better lib handling
update dependencies.
- src/index: export runCluster
- pkg: add type: module, add main field
- magic build --no-minify flag now works
- themes/theme_name.mjs is now a valid theme path
- apis can be served by @grundstein/gas and created on page, app and module level
- update dependencies
- hyperapp-render is a proper module now
- add config.API_DIR. load all files in that dir and use their default exports as lambdas.
- update babel build task
update babel
- FIX: sri-hashes for magic.js and magic.css get added to html again.
- update dependencies
update @magic/css
- Img module now has loading=lazy as default prop.
- update @magic/css
FIX: regression, reenable custom state for pages.
update lodash to mitigate development environment security issue.
update deps
icon sizes can be customized
update icon size usage
themes/reset.css: add icon animation for hoisted icons
update dependencies
update babel
- remove unused imports
- formatting
- split tasks/globals into separate files
- update api to allow self-contained lambdas which load their dependencies using await import
- update dependencies
update dependencies
update dependencies
update dependencies
update dependencies
- serve/prepareApi: remove console.log
- allow addition of third party scripts using ADD_SCRIPTS config variable
- update dependencies
git tagged but not published
- do not error if page is not a javascript module
- update dependencies
- add app.build task
- update dependencies
- if the app.mjs import fails because one of the app dependencies is missing, throw an error instead of silently not importing the app.
- update dependencies
- use @swc/core for dev builds to make them 10 times faster.
- update dependencies
- only duplicate unique page.state into app.state, 20-30% bundle size reduction.
- cluster/build task recovers from build errors, no restart needed.
- config.API_DIR now actually gets used
- api routes now 404 if they do not exist (redirected to WEB_ROOT before)
- update deps
- Router: on navigation scroll to top works in newer firefox, tradeoff: probably not in older.
- npm i -g magic now works and loads local node_modules as well as global
- further fixes regarding npm i -g magic
- bump required node version to 14.15.4
- update dependencies
update dependencies
update dependencies
- Header, Menu, MenuItem and Logo arguments updated
update dependencies (marked)
- update dependencies
- swc now handles links in pages correctly (dev)
- babel now handles links in pages correctly (production)
- prepare task now handles all urls in the state object, no need to handle it in babel/swc or in modules.
debump hyperapp-render from 4.0.0 to 3.5.0
- fix error in modules/Logo
- tasks/prepare/stateLinks now handles #hash and -expand links without parents
- check for broken links on build and dev
- better link handling, should now include all images and links in pages too
- update dependencies
- restructure most of the app tasks and remove global.config. this will allow us to seamlessly use @magic/core in the @magic/test library
- libs can now be static function instead of imports
- export renderToString
- magic.init can now be an actual array of code, instead of string only
- update dependencies
- more robust checkLinks testing
- libraries can be actual code or a string pointing to a file
- update hyperapp and use 2.0.12
- update hyperapp-render to 4.0.0
- update dependencies
- href link checkers handle mailto: links
- import hyperapp memo instead of Lazy
- starting to remove usages of config without explicit destructuring
- replaceSlashSlash all urls in robots.txt and sitemap.xml
- add ADD_TAGS to append arbitrary html after the #magic root
- the watch task can now watch files
- the watch task watches the config file
- FIX: tasks/prepare/page: change variable name to avoid "access before init" error when pages do not build successfully.
- update dependencies
- to keep dev builds fast, external links only get checked on build.
- deprecate config.mjs in favor of magic.(m)js
- magic.js config import will now error and exit if config does not exist
- if no config file is found, output an example config
- show a warning if config.mjs is still being used
- only checkLinks external links in production env
- swc handles OptionalChainingExpression and Computed
- nicer error messages
- add Permissions-Policy interest-cohort=() to maybe avoid FLOC tracking in chrome.
- add @magic/hyperapp bundle that exports hyperapp and hyperapp-render
correctly export renderToString from index (for @magic/test)
add silent option to silence log output and apply to config.
- update dependencies
- conf.ADD_STATIC can be used to import static files from multiple directories
- component handles prerendered hyperapp objects correctly again.
- html pages have their href and src elements prefixed with WEB_ROOT
- runConfig: bail early if config file is not found
- lib/findConfigFile: only process.exit if args.silent is false
update dependencies
-
update @babel/preset-env to avoid security issue
-
config: add PREPEND_SCRIPT and APPEND_SCRIPT to allow adding js script tags before and after the magic js
-
config: add PREPEND_JS and APPEND_JS to allow adding js contents before and after the magic js, directly into magic.js
-
config: add PREPEND_CSS and APPEND_CSS to allow adding css before and after magic js
-
config: add PREPEND_TAGS and APPEND_TAGS to allow adding html tags before and after #magic tag
- BUG: do not try to return an undefined hashes var if PREPEND_SCRIPTS or APPEND_SCRIPTS is empty
- swc: handle EmptyStatement
- update dependencies
make sure all app.static[key] keys start with a slash (config.ADD_STATIC)
- cluster.watch now also watches config.DIR.STATIC directories
- update dependencies
update dependencies
update dependencies to avoid circular dependency in @magic/types
update dependencies
update dependencies
update dependencies
update dependencies
update dependencies
- update dependencies
- theme: move css from html to body to prevent duplicate scrollbars in blink/webkit
- update dependencies
- config.DIR.LIB is an array and imports lib files from each of them
- theme imports now throw MODULE_NOT_FOUND errors in their internal imports, they got swallowed before
- CHECK_PROPS can be silenced
- update dependencies
update dependencies
- allow .js files for modules and libraries
- update dependencies
- better encoding for ' characters in state strings
- update dependencies
- update dependencies
- update dependencies
- @magic/test can now test @magic/core again
update dependencies
update dependencies
update dependencies
-
update dependencies
-
remove babel, swc can handle it by now (bundle js size 88k babel to 90k swc for this page, 18 byte difference if using zopfli).
-
config.BABEL deprecation warning
-
app.helpers deprecation warning
-
propTypes no longer need to be namespaced
// Module.mjs export const propTypes = [//...propTypes] // will turn into: export const propTypes = { Module: [//..propTypes]}
- update dependencies
- swc will prepend links in the return statements of modules with WEB_ROOT if needed.
- CHECK_PROPS supports oneOf and someOf. added some tests.
- update dependencies
- FIX from 0.0.145: CHECK_PROPS now can handle logging and errors.
- FIX from 0.0.145: swc can handle string literals in img src and srcset parameters
swc will now remove CHECK_PROPS from magic.js production bundles.
- update dependencies
- checkLinks supports NO_CHECK_LINKS_LIST in magic.js, which allows us to ignore known broken links, for example when pages block our http requests.
- update dependencies
- better error message if a module can not be required
- global html tags will always be defined in order to make sure they exist before requiring other Modules
update dependencies
- update dependencies
- FIX: bug when assigning local state of modules, only the last item was written, now they all get added to state.componentname.
- swc: add AwaitExpression and set swc.jsc.target to es2017, leading to async-await making it into the final bundle.
- module.global can now also be called module.globals
- tasks/prepare/js now makes sure that
import
ed modules work. - swc: add ForOfStatement
- downgrade swc
- magic now seems to work on windows.
- update dependencies
- link WEB_ROOT prefixing ignores Identifier, TemplateLiteral and BinaryExpression ast nodes, they are dynamic and should not be manipulated
- Img module will not automatically set role="presentation" when alt="", props.loading will always be set to lazy unless provided
- CheckLinks will not error if TemplateLiterals are used in the url
- Magic exports replaceSlashSlash from library
- modules/app will not error if state of a page is undefined in src/app.mjs
- reduce @swc/core version back to 1.3.41 to prevent errors when transpiling
...