Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/beenotung/auto-cms

Auto turn any webpage into editable CMS without coding.
https://github.com/beenotung/auto-cms

cli cms content editor html low-code nocode server

Last synced: 6 days ago
JSON representation

Auto turn any webpage into editable CMS without coding.

Awesome Lists containing this project

README

        

# auto-cms

Auto turn any webpage into editable CMS without coding.

[![npm Package Version](https://img.shields.io/npm/v/auto-cms-server)](https://www.npmjs.com/package/auto-cms-server)

## Features

- [x] Click with `Ctrl` key or `Alt` key to show menu
- [x] Edit from web UI
- text
- link
- image
- audio
- video
- [x] media management
- [x] view
- [x] upload
- [x] delete
- [ ] see which pages are using the media
- [x] support image
- [x] support video / audio
- [x] Reuse html template
- For common header, footer, e.t.c.
- [ ] style editing
- text alignment
- text color
- font size
- font family
- [x] SEO settings
- title
- description
- preview image
- [x] Save changes to file
- [x] Custom 404 layout (send `404.html` if exists, otherwise send `index.html`)
- [x] Multi-language support
- convert 150+ languages with [node-EasyNMT](https://github.com/beenotung/node-EasyNMT)
- convert traditional Chinese / simplified Chinese with [繁化姬 API](https://docs.zhconvert.org)
- convert 104 languages with [open-google-translator](https://github.com/vidya-hub/open-google-translator)
- [x] Contact form
- [x] IFrame inlining
- [ ] Auto scan 404
- [x] Auto setup `.env` file
- [x] Robust
- Correctly set Content-Type even when the filename of the HTML file is not ending with `.html`
- Support next.js image proxy url (e.g. "/\_next/image?url=xxx&w=xx&q=xx")
- Auto backup edits
- View and restore from backups

## Enhancement

- [x] support editing element with multiple text nodes with br
- [x] cleanup html
- remove duplicated script, style and css link caused by repeated runtime script injection
- deduplicate class names
- remove tracking scripts
- fix elements position
- move `title`, `meta`, `link` from `body` into `head`

## Usage

Usage with installation to lock the version:

```bash
npm i -D auto-cms-server
npx auto-cms-server
```

Usage without installation:

```bash
npx -y auto-cms-server
```

## API

### Multi Language

The `LANG` cookie is used to specified the client-preferred language. Possible values are: `en`, `zh_cn`, and `zh_hk`.

The default value can be set in the environment variable `AUTO_CMS_DEFAULT_LANG`.

Below is example UI and code to show and set the language:

```html

Language:


English



簡體中文



繁體中文

{
let lang = new URLSearchParams(document.cookie).get('LANG')
langForm.lang.value = lang
langForm.lang.forEach(input => {
input.addEventListener('change', event => {
if (input.checked) {
document.cookie = 'LANG=' + input.value
location.reload()
}
})
})
}

```

### Submit Contact Form

```
Method: POST
Pathname: /contact
Content-Type: application/x-www-form-urlencoded or application/json
Accept: text/html or application/json
Body Fields:
- name
- email
- tel
- company_name
- business_nature
- remark
- extra
```

All body fields are optional.

If you submit additional fields in the request body, they will be stored as JSON in the `extra` field.

If the `Accept` is `application/json`, the response will be a json object with optional `error` string; otherwise the response will be a html page.

The response file can be configured in the env variable `SUBMIT_CONTACT_RESULT_PAGE`. If it is not specified, or specified as `default`, a simple html page will be response as below:

```html




Submitted


Your submission has been received.


${error ? `
${escapeHTML(error)}

` : ''}

Back to home page.


```

If you want to implement custom form submission experience, you can do that with AJAX like below example:

```html

Contact Form




Nickname:




Email:





async function submitContact(event) {
let form = event.target
let result = form.querySelector('.contact-form--submit-result')
function showResult(text) {
result.textContent = text
}
try {
let formData = new FormData(form)
let params = new URLSearchParams(formData)
let body = params.toString()
event.preventDefault()
let res = await fetch('/contact', {
method: 'POST',
headers: {
'Content-Type': 'application/x-www-form-urlencoded',
'Accept': 'application/json',
},
body,
})
let json = await res.json()
if (json.error) throw json.error
showResult('Thank you. Your submission is received.')
} catch (error) {
showResult(String(error))
}
}

```

## License

This project is licensed with [BSD-2-Clause](./LICENSE)

This is free, libre, and open-source software. It comes down to four essential freedoms [[ref]](https://seirdy.one/2021/01/27/whatsapp-and-the-domestication-of-users.html#fnref:2):

- The freedom to run the program as you wish, for any purpose
- The freedom to study how the program works, and change it so it does your computing as you wish
- The freedom to redistribute copies so you can help others
- The freedom to distribute copies of your modified versions to others