-
-
Notifications
You must be signed in to change notification settings - Fork 0
Docs
Welcome to the official documentation for Leatherfacee.js, a lightweight JavaScript framework designed to provide a robust, modular, and easy-to-use structure for building front-end applications. This guide will help you understand the core features and how to use them effectively.
- ChainsawAnim Class
- LefaceRender Class
- Component System
- Concurrent Mode
- Static Site Generator
- Directives
- Router
- Observer
- Services and Factories
The ChainsawAnim
class provides methods to create and manage CSS animations on DOM elements.
- constructor(t): Initialize with a target element.
- transform(t): Add a transformation to the list.
-
translate(x, y=0): Translate the element by
x
pixels horizontally andy
pixels vertically. -
rotate(deg): Rotate the element by
deg
degrees. -
scale(x, y=x): Scale the element by
x
andy
factors. - set(prop, value): Set a CSS property on the element.
- duration(time): Set the duration of the animation.
- end(callback): Apply the transformations and optionally execute a callback after the animation ends.
- Timeout(config): Execute functions sequentially with a specified interval.
- ATimeout(config): Execute functions with specified intervals for each.
const anim = new ChainsawAnim('#myElement');
anim.translate(100, 50).rotate(45).scale(1.5).duration('1s').end(() => {
console.log('Animation completed');
});
The LefaceRender
class is responsible for rendering templates and managing data reactivity.
- constructor(options): Initialize with data, methods, target element, and template.
- observe(data): Make data properties reactive.
- compileTemplate(): Compile the template with data bindings.
- render(): Render the compiled template to the target element.
- bindDirectives(): Bind directives in the template.
const renderer = new LefaceRender({
data: { message: 'Hello, World!' },
target: document.getElementById('app'),
template: '<p>{{message}}</p>'
});
Leatherfacee.js supports a component-based architecture with support for computed properties and concurrent rendering.
Base class for all components.
Extends LefaceComponent
to support computed properties.
Extends LefaceComputedComponent
to support concurrent rendering.
class MyComponent extends LefaceComponent {
render() {
this.element = document.createElement('div');
this.element.innerText = this.props.text;
document.body.appendChild(this.element);
}
}
const leface = new Leface();
leface.register('MyComponent', MyComponent);
leface.create('MyComponent', { text: 'Hello, Leatherfacee!' });
Enables concurrent rendering of components.
- enqueue(component): Enqueue a component for concurrent rendering.
class MyConcurrentComponent extends LefaceConcurrentComponent {
renderComponent(props) {
const element = document.createElement('div');
element.innerText = props.text;
document.body.appendChild(element);
return element;
}
}
leface.register('MyConcurrentComponent', MyConcurrentComponent);
leface.create('MyConcurrentComponent', { text: 'Rendering concurrently!' });
Generate a static site from registered components.
- generate(): Generate static HTML files for all registered components and package them into a ZIP file. Requires JSZip
leface.generateStaticSite();
Custom directives to extend HTML with custom behavior.
- register(name, hook): Register a new directive.
- apply(element, props): Apply directives to an element.
lefaceDirectives.register('my-directive', (element, value) => {
element.innerText = value;
});
Simple client-side router for single-page applications.
- registerRoute(path, component): Register a route with a component.
- navigateTo(path): Navigate to a registered route.
const router = new LefaceRouter();
router.registerRoute('/home', MyComponent);
router.navigateTo('/home');
Observe changes to component properties and re-render components.
- observe(instance): Observe properties of an instance.
- setProp(obj, prop, value): Set a property value and notify observers.
const observer = new LefaceObserver();
observer.observe(myComponentInstance);
observer.setProp(myComponentInstance.props, 'text', 'Updated text!');
Provide a way to manage dependencies and create instances of objects.
- register(name, service): Register a service.
- get(name): Retrieve a registered service.
- register(name, factory): Register a factory function.
- create(name, ...args): Create an instance using a factory function.
lefaceService.register('myService', new MyService());
const myService = lefaceService.get('myService');
lefaceFactory.register('myFactory', (arg1, arg2) => new MyClass(arg1, arg2));
const myInstance = lefaceFactory.create('myFactory', 'arg1', 'arg2');
The primary objective of the LefaceCrossPlatform
function is to simplify the process of delivering customized stylesheets tailored to specific device platforms. By detecting the user's device characteristics, such as screen size and platform type, it ensures an optimized browsing experience across different devices.
LefaceCrossPlatform(styles)
-
styles
(object): An object containing key-value pairs where the keys represent different device platforms (e.g., "Desktop", "Mobile", "Tablet") and the values specify the corresponding CSS file paths.
To utilize the LefaceCrossPlatform
function effectively, follow these steps:
-
Include the Function: Ensure that the
LefaceCrossPlatform
function is accessible within your JavaScript environment. You can either define it inline or include it from an external script file. -
Call the Function: Invoke the
LefaceCrossPlatform
function within your code, passing an object containing CSS file paths mapped to specific device platforms as an argument. -
Define CSS Paths: Provide CSS file paths for each targeted platform. These paths should point to the respective CSS files containing the styles intended for desktops, mobile devices, and tablets.
-
Implementation: Integrate the
LefaceCrossPlatform
function call into your web application's initialization code, typically within thewindow.onload
event handler or at an appropriate initialization phase.
LefaceCrossPlatform({
"Desktop": "styles/desktop.css",
"Mobile": "styles/mobile.css",
"Tablet": "styles/tablet.css"
});
In this example, the function is configured to load different CSS files based on the user's device platform. For desktops, it loads "desktop.css," for mobile devices, it loads "mobile.css," and for tablets, it loads "tablet.css."
LefaceCrossPlatform({
"Desktop": "styles/desktop.css",
"Mobile": "styles/mobile.css"
});
If tablet-specific styles are not provided, the function gracefully handles the absence of the "Tablet" key, ensuring compatibility with a wide range of configurations.
// Loading external CSS
LefaceUtils.loadExternalCSS('https://example.com/styles.css');
// Loading an external JS
LefaceUtils.loadExternalJS('https://example.com/script.js').then(() => {
console.log('Script loaded!');
}).catch((error) => {
console.error('FATAL ERROR:', error);
});
// Insert HTML
LefaceUtils.insertHTML('#myElement', '<p>Inserted content</p>');
// Modifying an element's attributes
LefaceUtils.setElementAttribute('#myElement', 'data-test', 'valor');
// Switching the visibility of an element
LefaceUtils.toggleVisibility('#myElement');
// Sanitize HTML
const sanitizedHTML = LefaceUtils.sanitizeHTML('<p onclick="alert(1)">Text</p>');
console.log(sanitizedHTML);
To make a GET request, you need to provide the URL of the resource you want to access and a callback function to handle the response.
LefaceRequests.get('https://api.example.com/data', function(response) {
console.log(response); // Here you can process the response
});
To make a POST request, in addition to the URL, you need to provide the data to be sent as a JavaScript object and a callback function to handle the response.
var data = { name: 'John', age: 25, city: 'New York' };
LefaceRequests.post('https://api.example.com/submit', data, function(response) {
console.log(response); // Here you can process the response
});
Lymple automatically handles network errors, such as connection failures or unexpected server responses. You can add error handlers to your callback function to deal with these situations.
LefaceRequests.get('https://api.example.com/data', function(response) {
console.log(response);
}, function(error) {
console.error('An error occurred:', error);
});
You can send custom headers with your requests, such as authorization or content headers. Simply add an object containing the desired headers as the last parameter.
var headers = { 'Authorization': 'Bearer token123' };
LefaceRequests.get('https://api.example.com/data', function(response) {
console.log(response);
}, null, headers);
- GET Request: Fetching weather data from a weather API.
LefaceRequests.get('https://api.weatherapi.com/forecast.json?key=YOUR_API_KEY&q=London', function(response) {
console.log(response);
});
- POST Request: Sending form data to the server.
var data = { name: 'Maria', age: 30, city: 'Rio de Janeiro' };
LefaceRequests.post('https://api.example.com/submit', data, function(response) {
console.log(response);
});
- GENERAL EXAMPLE:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="https://cdn.jsdelivr.net/gh/simplyYan/lympleRequest@main/lymple.js"></script>
</head>
<body>
<input type="text" name="nome" id="nome" placeholder="Type yout name">
<button onclick="send()">Send</button>
<script>
function send() {
var nome = document.getElementById("nome").value;
var data = { name: nome }
LefaceRequests.post('index.php', data, function(response) {
console.log(data)
console.log(response);
}, { 'Content-Type': 'application/json' });
}
</script>
</body>
</html>
<?php
if ($_SERVER["REQUEST_METHOD"] == "POST") {
$data = json_decode(file_get_contents("php://input"), true);
if (isset($data['name'])) {
$name = $data['name'];
echo "The name sent is: " . $name;
} else {
http_response_code(400);
echo "The 'name' field was not found in the data.";
}
} else {
http_response_code(405);
echo "Method not allowed. Only POST requests are accepted.";
}
?>