patrikjak/utils

A simple utility package for Laravel

Maintainers

Package info

github.com/patrikjak/utils

pkg:composer/patrikjak/utils

Statistics

Installs: 822

Dependents: 2

Suggesters: 0

Stars: 0

Open Issues: 1

v2.13.1 2026-03-10 06:36 UTC

README

codecov

The Utils package is a versatile utility toolkit designed to enhance Laravel applications. It provides a variety of reusable classes and functions to streamline development, including CSS and JavaScript assets to support frontend components like buttons, modals, and tables. Easily integrate the package into your project, publish assets, and selectively include only the styles and functions you need for a highly customizable setup. Perfect for Laravel developers seeking to simplify their workflow with ready-to-use utilities.

Table of Contents

What's included:

  • CSS - A collection of reusable styles for buttons, modals, tables, and more.
  • JavaScript - A variety of functions to enhance user experience and streamline development.
  • Forms - A set of form components to simplify form creation.
  • Tables - A collection of table components to enhance data presentation.
  • Modals - A set of modal components to display content in a modal window.
  • Notifications - A collection of notification components to display messages to users.

You can find the full documentation here.

Installation

Install the package via Composer:

composer require patrikjak/utils

Setup

After installing the package, add the package provider to the providers array in bootstrap/providers.php.

use Patrikjak\Utils\UtilsServiceProvider;
 
return [
    ...
    UtilsServiceProvider::class,
];

Next, publish the pre-built assets:

php artisan vendor:publish --tag="pjutils-assets" --force

This copies the compiled CSS and JS files to public/vendor/pjutils/. Re-run it with --force after every package update.

If you want to customize the SCSS or TypeScript source files, publish them separately:

php artisan vendor:publish --tag="pjutils-sources"

Usage

The Utils package offers a variety of useful classes and functions.

CSS

To include all component styles, add the main.css file:

<link rel="stylesheet" href="{{ asset('vendor/pjutils/assets/main.css') }}">

You need to set border-box box-sizing for all elements in your CSS file to prevent layout issues:

* {
    box-sizing: border-box;
}

JavaScript

The package ships a pre-built ES module bundle. Include it as a <script> tag before your own scripts:

<script src="{{ asset('vendor/pjutils/assets/main.js') }}" defer type="module"></script>

type="module" is required. The bundle auto-initializes all components and exposes a window.pjutils global.

Auto-initialization

These components initialize automatically on page load — no manual calls needed: password visibility switch, table functions (pagination, sorting, filtering, search), dropdowns, file uploaders, accordions, tabs, clipboard, number inputs, comboboxes, tag inputs, repeaters.

Programmatic API

Symbol Type Description
Form class AJAX form submission with validation error handling
Modal class Programmatic modal creation and control
notify function Show notification messages
getData function Read HTML data attributes from elements
doAction function Bind custom row actions on a table
window.pjutils.notify('Saved', 'Success', 'success');

new window.pjutils.Form().bindSubmit();

const modal = new window.pjutils.Modal();
modal.setTitle('Hello').setBody('<p>Content</p>').open();

TypeScript

Add a declaration file at resources/js/pjutils.d.ts for full type safety — the import type imports are erased at build time, nothing from the vendor directory gets bundled:

import type Form from '../../vendor/patrikjak/utils/resources/assets/js/form/Form';
import type notify from '../../vendor/patrikjak/utils/resources/assets/js/utils/notification';
import type Modal from '../../vendor/patrikjak/utils/resources/assets/js/utils/Modal';
import type {getData} from '../../vendor/patrikjak/utils/resources/assets/js/helpers/general';
import type {doAction} from '../../vendor/patrikjak/utils/resources/assets/js/table/actions';

export {};

declare global {
    interface Window {
        pjutils: {
            Form: typeof Form;
            notify: typeof notify;
            Modal: typeof Modal;
            getData: typeof getData;
            doAction: typeof doAction;
        };
    }
}

Make sure resources/js is included in your tsconfig.json:

{
    "compilerOptions": {
        "target": "ESNext",
        "module": "ESNext",
        "moduleResolution": "bundler",
        "strict": true,
        "noEmit": true,
        "skipLibCheck": true
    },
    "include": [
        "resources/js/**/*"
    ]
}

To load the correct language for JS components, set the lang attribute on the <html> tag:

<html lang="{{ config('app.locale') }}">

Currently supported languages: en, sk.

Your vite.config.js must target esnext:

export default defineConfig({
    ...
    build: {
        target: 'esnext',
    },
});