Project

atomic_cms

0.0
No commit activity in last 3 years
No release in over 3 years
There's a lot of open issues
Live CMS powered by atomic assets.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

= 1.0.0.pre2
>= 4.0.3, ~> 4.0
~> 5.2
~> 4.2
~> 3.3
 Project Readme

Atomic CMS

The biggest problem with any content management system is the admin users are given too much or too little power when editing their site. This gem provides a means to manage usage of components created from the gem Atomic Assets. By providing admin users with a way to manage their Atomic Assets, developers and designers are able to ensure the components they create remained styled properly while allowing admins to update their content as needed without developer intervention. Below are instructions for getting started.

Gemfile

After initializing a new Rails application, or adding to an existing application, add the following gems to your Gemfile.

gem 'atomic_cms', github: 'verypossible/atomic_cms'
gem 'devise'

Note: devise is optional if you do not want admin users to login.

Then perform a bundle install.

Initialization

Active Admin

To initialize Active Admin:

rails generate atomic_cms:install

Remove the comments migration Active Admin created along with disabling comments on line 122 of the Active Admin initializer.

Now you shall run the migration and seeds with:

bundle exec rake db:create
bundle exec rake db:migrate

To verify, start the server and visit localhost:3000/admin. If you can login as admin@example.com with the password password you have successfully completed this step.

Atomic CMS

Routes

Update your config/routes.rb to include the following:

mount AtomicCms::Engine => "/atomic_cms", as: :atomic_cms
# If you are going to use a catch all route add the following line
get "*path", to: "pages#show", controller: "pages", as: :page, format: false
root to: 'pages#show', controller: "pages"

The last two lines need to be at the END of your routes.rb file.

Devise Authentication

Change the mount point above to be the following:

  authenticate :admin_user, -> (u) { u.admin? } do
    mount AtomicCms::Engine => "/atomic_cms", as: :atomic_cms
  end

where u is the user and admin? the authentication method you have on that user; it should return a boolean value.

Scaffold Generator

Execute the following to create a model for your static pages:

rails g atomic_cms:scaffold page

After this you should run your migrations.

Here is a list of everything that is generated for you:

  • Model
  • Controller
  • Active Admin Form
  • Migration Will need to be edited
  • Show View
  • Route

Media Upload

To install the media tables so that you can upload files until your heart is literally full run:

rake atomic_cms:install:migrations
rake db:migrate

Also, you should configure paperclip to use s3, since s3 is better than local file storage.

class Application < Rails::Application
  ...
  config.paperclip_defaults = {
    storage: :s3,
    s3_protocol: "https",
    s3_credentials: {
      bucket: ENV.fetch("AWS_S3_BUCKET", ""),
      access_key_id: ENV.fetch("AWS_ACCESS_KEY", ""),
      secret_access_key: ENV.fetch("AWS_SECRET", ""),
      s3_region: ENV.fetch("AWS_REGION", ""),
    }
  }
  ...
end

Styles

In order for component previews to have the proper project styling, active_admin.scss will need to be updated to import your application.scss. NOTE: If you are using bourbon, bitters, and neat you will not be able to straight import application.scss as certain styles within base must be imported under the #component_preview selector. Below is an example of how this is properly imported:

@import "active_admin/mixins";
@import "active_admin/base";
@import "bourbon";
@import "neat";
@import "base/variables";
@import "base/grid-settings";
@import "atomic_cms";

#component_preview {
  @import "reset";
  @import "base/buttons";
  @import "base/forms";
  @import "base/lists";
  @import "base/tables";
  @import "base/typography";
  @import "components/*";
  @include font-feature-settings("kern", "liga", "pnum");
  -webkit-font-smoothing: antialiased;
  color: $base-font-color;
  font-family: $base-font-family;
  font-size: 16px;
  line-height: $base-line-height;
  // When editing a page through the CMS,
  // images with broken links will not be displayed
  img[src="image"] {
    display: none !important;
  }
}

// Overriding any non-variable SASS must be done after the fact.
// For example, to change the default status-tag color:
//
//   .status_tag { background: #6090DB; }

NOTE: At the minimum, here is what is needed in active_admin.scss:

@import "active_admin/mixins";
@import "active_admin/base";
@import "atomic_cms";

#component_preview {
  // Include application specific styling here
}

Components

Generate components by executing the following:

rails g atomic_assets:component text_block

In order for components to be utilized when managing content, a partial needs to be created similar to the following at app/views/admin/_edit_buttons.html.slim:

ol.edit-buttons
  li
    = link_to 'Text Block', atomic_cms.edit_component_path('text_block'), class: 'button'

Config

Update config/application.rb to include:

config.autoload_paths += %W(#{config.root}/lib, #{config.root}/app/components/**/)

Gotcha's

When creating a path for a page, from the examples above, make sure to include a leading '/', for example: '/home' -or- '/bears'

License

Atomic CMS is released under the MIT License.