定制 patrikjak/utils 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

patrikjak/utils

最新稳定版本:v2.14.2

Composer 安装命令:

composer require patrikjak/utils

包简介

A simple utility package for Laravel

README 文档

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',
    },
});

统计信息

  • 总下载量: 1.02k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 2
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-10-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固