xsoft / cms
CMS
Requires
- doctrine/dbal: *
- hermit/logs: 1.*
- laravel/framework: 5.8.*
- xsoft/adminpanel: 1.*
Requires (Dev)
- dev-master
- 2.2.1
- 2.2
- 2.1.16
- 2.1.15
- 2.1.14
- 2.1.13
- 2.1.12
- 2.1.11
- 2.1.10
- 2.1.9
- 2.1.8
- 2.1.7
- 2.1.6
- 2.1.5
- 2.1.4.1
- 2.1.4
- 2.1.3.11
- 2.1.3.10
- 2.1.3.9
- 2.1.3.8
- 2.1.3.7
- 2.1.3.6
- 2.1.3.5
- 2.1.3.4
- 2.1.3.3
- 2.1.3.2
- 2.1.3.1
- 2.1.3
- 2.1.2
- 2.1.1.8
- 2.1.1.7
- 2.1.1.6
- 2.1.1.5
- 2.1.1.4
- 2.1.1.3
- 2.1.1.2
- 2.1.1.1
- 2.1.1
- 2.1.0.3
- 2.1.0.2
- 2.1.0.1
- 2.1
- 2.0.2.2
- 2.0.2.1
- 2.0.2
- 2.0.1
- 2.0
- 1.4.10
- 1.4.9
- 1.4.8.3
- 1.4.8.2
- 1.4.8.1
- 1.4.8
- 1.4.7.13
- 1.4.7.12
- 1.4.7.11
- 1.4.7.10
- 1.4.7.9
- 1.4.7.8
- 1.4.7.7
- 1.4.7.6
- 1.4.7.5
- 1.4.7.4
- 1.4.7.3
- 1.4.7.2
- 1.4.7.1
- 1.4.7
- 1.4.6.9
- 1.4.6.8
- 1.4.6.7
- 1.4.6.6
- 1.4.6.5
- 1.4.6.4
- 1.4.6.3
- 1.4.6.2
- 1.4.6.1
- 1.4.6
- 1.4.5.1
- 1.4.5
- 1.4.4.4
- 1.4.4.3
- 1.4.4.2
- 1.4.4.1
- 1.4.4
- 1.4.3.4
- 1.4.3.3
- 1.4.3.2
- 1.4.3.1
- 1.4.3
- 1.4.2
- 1.4.1
- 1.4
- 1.3.2.3
- 1.3.2.2
- 1.3.2.1
- 1.3.2
- 1.3.1.2
- 1.3.1.1
- 1.3.1
- 1.3.0.3
- 1.3.0.2
- 1.3.0.1
- 1.3
- 1.2.3.3
- 1.2.3.2
- 1.2.3.1
- 1.2.3
- 1.2.2.1
- 1.2.2
- 1.2.1.3
- 1.2.1.2
- 1.2.1.1
- 1.2.1
- 1.2
- 1.1.7
- 1.1.6
- 1.1.5
- 1.1.4
- 1.1.3
- 1.1.2.1
- 1.1.2
- 1.1.1.1
- 1.1.1
- 1.1
- 1.0.4
- 1.0.3.2
- 1.0.3.1
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0
- 0.9.6
- 0.9.5
- 0.9.4.5
- 0.9.4
- 0.9.3.1
- 0.9.3
- 0.9.2
- 0.9.1
- 0.9
- 0.8
- 0.7
- 0.6.3
- 0.6.2
- 0.6.1
- 0.6
- 0.5
- 0.4
- 0.3
- 0.2
- 0.1
- dev-cms_v1
- dev-urls_prefixes
- dev-makeModelRework
- dev-galleries_and_articles
- dev-urls_and_language_changes
- dev-urls
- dev-front_render_remake
- dev-containers
- dev-multiple_layouts
- dev-importExportPages
- dev-newLayout
This package is auto-updated.
Last update: 2025-03-19 20:30:33 UTC
README
Cms Package
composer require xsoft/cms 2.*
Installation
Add:
- In your Providers/AppServiceProvider::register() :
Schema::defaultStringLength(191);
- To your .env file:
ADMIN_DOMAIN=admin.YOUR_DOMAIN
FRONT_DOMAIN=YOUR_DOMAIN
Use command
php artisan cms:start --install
Warning!
Using this command can break application, so use it only on project Init!
In order for Hermit/Logs to log errors use command php artisan logs:install
and follow instructions given in console.
Initialize styles
Add
mix.sass('resources/sass/AdminPanel/main.scss', 'public/admin/vendor/admin-panel/css/adminPanel.css')
.sass('resources/sass/admin/skin.scss', 'public/admin/css')
.sass('resources/sass/admin/custom.scss', 'public/admin/css');
In your webpack.mix.js
Then run npm install
and npm run dev
Commands
cms:start {--install} {--update}
- creates storage:link and storage structure
--install
- first command that should be run after downloading the package--update
- run this when it is specified in update notes
cms:version {--update}
- displays currently installed version of cms
--update
- updates version in configs table
make:cms:directories
- checks and creates necessary directoriesmake:cms:globalWidget
- create global widgetmake:cms:section
- create custom sectionmake:cms:widgetTemplate {name?}
- create custom widgetmake:cms:model {model_name}
- create source model
Updates
php artisan cms:start --update
* -> 2.1
Reworked front views rendering and added customizable url for pages.
Information about how to update version 1.* to 2.1 is specified in V2UPDATE.md
file.
Variables with data accessible in front views
resources\views\front\templates\sections\*
resources\views\front\templates\section.blade.php
Section $section
resources\views\front\templates\widgets\*
FrontWidget $data
Data for widgets is build based on specified inputs on widget modal. Inputs which value should be passed to front widget must have 'data' class. That data is then accesible by get($element)
method where $element
is the created input name.
If you want to manage your data before passing it to widgets blade file add to that widgets modal in resources\views\admin\templates\widgets\modals\YOUR_WIDGET
:
<input id="source_model" name="custom_front_model" type="text" value="NAME" class="data static no-clear" hidden>
<input id="source_content_type" name="custom_content_type" type="text" value="CONTENT_TYPE" class="data static no-clear" hidden>
NAME
- partial name of the front service where you can manage your data (app\Htpp\Services\Front\'NAME'Service.php
)CONTENT_TYPE
- name of method insideapp\Htpp\Services\Front\'NAME'Service.php
that will be called to get data
Method must have the following format
IMPORTANT: DO NOT OVERRIDE $data
VARIABLE. It is an array that have important information that is used on widget rendering process. However you can add whatever you need to it and then access on blade by $data->get('your_index')
.
static public function CONTENT_TYPE($widget, $data, $pageLanguage)
{
***YOUR CODE HERE***
return [
'data' => $data,
'blade' => $widget->template->blade_name,
];
}
resources\views\front\templates\widget.blade.php
FrontWidget $frontWidget
resources\views\front\layouts\*
resources\views\front\index.blade.php
DataProcessor $dataProcessor
Front objects Classes
Column
Xsoft\Cms\Helpers\FrontProcessors\Column
Constructor accepts PageLanguage object, Section object, column order, column size.
Available methods:
getSize()
- returns column size (for bootstraps css 'col' class)getContainers()
- returns Collection of Container objectsgetWidgets()
- returns Collection of FrontWidget objects based on widgets added to this column in administration panelgetView()
- returns View object (contains widgets ready to render)
DataProcessor
Xsoft\Cms\Helpers\FrontProcessors\DataProcessor
Constructor requires PageLanguage object.
Available methods:
getPageLanguage()
- returns PageLanguage objectgetLanguage()
- returns language code fetched from given PageLanguagegetSections()
- returns Collection of Section objectsgetHeaderMenu()
- returns View object for header menugetFooterMenu()
- returns View object for footer menugetSourceObject()
- returns Model object when page is a single view of specified source model otherwise returns nullgetMetaData()
- returns View object of metadata specified inresources\views\front\layouts\partials\metaData.blade.php
getPageOptions()
- returns an array of options specified in administration panel for given in constructor PageLanguage objectgetMainPageUrl()
- returns string with url to current language main pagegetFrontLanguageChangeData()
- returns array of urls forresources\views\front\layouts\partials\languageChange.blade.php
Each menu is defined in resources\views\front\layouts\partials\menu.blade.php
FrontWidget
Xsoft\Cms\Helpers\FrontProcessors\FrontWidget
Constructor requires array of data processed in Xsoft\Cms\Services\Front\WidgetService
(if widget displays data from source model data is processed in: App\Http\Services\Front\'MODEL_NAME'Service.php
).
Available methods:
get($element)
-$element
- index of data to return it's value or null if given element doesn’t existall()
- returns array with datagetTag()
- returns PageSection objects template tag field valuegetClasses()
- returns string of classes defined in administration panel for this widget or nullgetStyles()
- returns string of styles defined in administration panel for this widget or nullgetBladeName()
- returns Widget objects template blade_name field value
Section
Xsoft\Cms\Helpers\FrontProcessors\Section
Constructor requires PageLanguage object nad PageSection object.
Available methods:
getPageSection()
- returns PageSection objectgetClasses()
- returns string of classes defined in administration panel for this section or nullgetStyles()
- returns string of styles defined in administration panel for this section or nullgetSlug()
- returns PageSection objects slug field valuegetBladeName()
- returns PageSection objects template blade_name field valuegetTag()
- returns PageSection objects template tag field valuegetContainers()
- returns Collection of Container objects (only those that are attached directly to section)getColumns()
- returns Collection of Column objectsgetColumn($order)
- returns Column object specified by$order
variablegetColumnView($order)
- returns View object of Column object specified by$order
variablegetView()
- returns View object for sectiongetSectionContent()
- returns View object of all content wrapped by specified containers
Partials
FileManager
@include('cms::admin.filemanager.manager',[
'type' => 'single|multi', (REQUIRED)
'fileTypes' => ['image','icon',...], (REQUIRED)
'name' => INPUT_NAME, (REQUIRED)
'data' => EXISTING_VALUE,
'label' => INPUT_LABEL,
'sublabel' => INPUT_SUBLABEL,
'required' => true|false,
'deletable' => true|false
])
RouteSelect
{!! RouteSelector::build(
INPUT_LABEL,
INPUT_NAME,
EXISTING_VALUE
) !!}
URL
@include('cms::admin.partials.url',[
'label' => INPUT_LABEL, (REQUIRED)
'item' => OBJECT_WITH_URL, (REQUIRED)
'name' => INPUT_NAME (REQUIRED)
])
GallerySelect
@include('cms::admin.partials.gallerySelect',[
'label' => INPUT_LABEL,
'name' => INPUT_NAME,
'value' => GALLERY_ID
])