able of Contents
- Project Setup
- Installation
- Generating Minified CSS
- Using the Custom Bootstrap CSS
- Previewing the Cheatsheet
- Custom SASS Variables
- Custom Button Components
- Custom Carousel Component
This project primarily uses pnpm
as the package manager, but you can also use npm
or other package managers if preferred. The project also uses sass
to generate a minified Bootstrap CSS file
First, install the necessary packages by running the following command:
pnpm install
or
npm install
To generate the minified Bootstrap CSS file, run the following command:
pnpm sass
or
npm run sass
To use the custom Bootstrap CSS file, include the following link in your HTML head tag
<link
rel="stylesheet"
href="https://cdn.jsdelivr.net/gh/zesty-io/salvation-army-theme/styles/bootstrap.css"
/>
To preview the cheatsheet, simply open the index.html
file in your preferred browser.
- Install the Live Server extension in Visual Studio Code.
- Right-click on the
index.html
file in the file explorer. - Select "Open with Live Server".
This will automatically open the index.html
file in your browser and update the preview whenever you make changes.
The custom SASS variables for the Bootstrap CSS file are defined in bootstrap/abstracts/_variables.scss
. You can modify these variables to customize the Bootstrap styles according to your needs.
The colors defined in the $theme-colors
map can be utilized in your HTML by applying the corresponding bg-{color-name}
classes. Here’s how to use them:
Primary Colors:
- Use
bg-primary-50
for a background color of#ffebeb
. - Use
bg-primary-100
for a background color of#ff838b
. - Use
bg-primary-200
for a background color of#eb2533
. - Use
bg-primary-300
for a background color of#c5000e
. - Use
bg-primary-400
for a background color of#9e121c
.
Secondary Colors:
- Use
bg-secondary-50
for a background color of#d7e9ff
. - Use
bg-secondary-100
for a background color of#77a9ee
. - Use
bg-secondary-150
for a background color of#61769c
. - Use
bg-secondary-200
for a background color of#002056
.
Other Colors:
- Use
bg-background-modal
for a background color of#121212
. - Use
bg-photo-overlay
for a background color of#1c1b1f
. - Use
bg-success
for a background color of#12825f
. - Use
bg-warning
for a background color of#f2ab53
. - Use
bg-dark
for a background color of#575757
. - Use
bg-dark-100
for a background color of#1c1b1f
. - Use
bg-dark-50
for a background color of#1c1b1f
with 50% opacity. - Use
bg-light
for a background color of#fff
. - Use
bg-area
for a background color of#efefef
.
The font sizes defined in the $font-sizes
and $display-font-sizes
maps can be utilized in your HTML by applying the corresponding fs-{size}
and display-{size}
classes. Here’s how to use them:
- Use
fs-1
for theh1
font size (5rem). - Use
fs-2
for theh2
font size (3.75rem). - Use
fs-3
for theh3
font size (3rem). - Use
fs-4
for theh4
font size (2.125rem). - Use
fs-5
for theh5
font size (1.75rem). - Use
fs-6
for theh6
font size (1.5rem). - Use
fs-7
for the large title font size (1.25rem).
- Use
display-1
for the extra-large body font size (1.125rem). - Use
display-2
for the large body font size (1rem). - Use
display-3
for the medium body font size (0.875rem). - Use
display-4
for the small body font size (0.75rem). - Use
display-5
for the caption font size (0.625rem).
The opacity levels defined in the $opacity
map can be utilized in your HTML by applying the corresponding opacity-{level}
, bg-opacity-{level}
, or link-opacity-{level}
classes. Here’s how to use them:
Opacity Levels:
- Use
opacity-0
,bg-opacity-0
, orlink-opacity-0
for0%
opacity. - Use
opacity-5
,bg-opacity-5
, orlink-opacity-5
for5%
opacity. - Use
opacity-10
,bg-opacity-10
, orlink-opacity-10
for10%
opacity. - Use
opacity-15
,bg-opacity-15
, orlink-opacity-15
for15%
opacity. - Use
opacity-20
,bg-opacity-20
, orlink-opacity-20
for20%
opacity. - Use
opacity-25
,bg-opacity-25
, orlink-opacity-25
for25%
opacity. - Use
opacity-30
,bg-opacity-30
, orlink-opacity-30
for30%
opacity. - Use
opacity-35
,bg-opacity-35
, orlink-opacity-35
for35%
opacity. - Use
opacity-40
,bg-opacity-40
, orlink-opacity-40
for40%
opacity. - Use
opacity-45
,bg-opacity-45
, orlink-opacity-45
for45%
opacity. - Use
opacity-50
,bg-opacity-50
, orlink-opacity-50
for50%
opacity. - Use
opacity-55
,bg-opacity-55
, orlink-opacity-55
for55%
opacity. - Use
opacity-60
,bg-opacity-60
, orlink-opacity-60
for60%
opacity. - Use
opacity-65
,bg-opacity-65
, orlink-opacity-65
for65%
opacity. - Use
opacity-70
,bg-opacity-70
, orlink-opacity-70
for70%
opacity. - Use
opacity-75
,bg-opacity-75
, orlink-opacity-75
for75%
opacity. - Use
opacity-80
,bg-opacity-80
, orlink-opacity-80
for80%
opacity. - Use
opacity-85
,bg-opacity-85
, orlink-opacity-85
for85%
opacity. - Use
opacity-90
,bg-opacity-90
, orlink-opacity-90
for90%
opacity. - Use
opacity-95
,bg-opacity-95
, orlink-opacity-95
for95%
opacity. - Use
opacity-100
,bg-opacity-100
, orlink-opacity-100
for100%
opacity.
The box shadows defined in your SASS file can be utilized in your HTML by applying the corresponding shadow-{size}
classes. Here’s how to use them:
Box Shadows:
- Use
shadow
for the default box shadow:0px 4px 4px -1px rgba(36, 104, 147, 0.04)
. - Use
shadow-sm
for a small box shadow:0px 1px 2px 0px rgba(36, 104, 147, 0.04)
. - Use
shadow-lg
for a large box shadow:0px 4px 8px 0px rgba(36, 104, 147, 0.04)
. - Use
shadow-xl
for an extra-large box shadow:0px 8px 12px 0px rgba(36, 104, 147, 0.04)
.
rounded
- Property:
border-radius
- Class:
rounded
- Values:
$spacers
(e.g.,rounded-1
,rounded-2
, etc.) - Description: Applies uniform rounding to all four corners of an element.
- Property:
rounded-top
- Property:
border-top-left-radius
,border-top-right-radius
- Class:
rounded-top
- Values:
$spacers
- Description: Applies rounding to the top-left and top-right corners of an element.
- Property:
rounded-end
- Property:
border-top-right-radius
,border-bottom-right-radius
- Class:
rounded-end
- Values:
$spacers
- Description: Applies rounding to the top-right and bottom-right corners of an element. Useful for right-to-left text direction or end alignment.
- Property:
rounded-bottom
- Property:
border-bottom-right-radius
,border-bottom-left-radius
- Class:
rounded-bottom
- Values:
$spacers
- Description: Applies rounding to the bottom-right and bottom-left corners of an element.
- Property:
rounded-start
- Property:
border-bottom-left-radius
,border-top-left-radius
- Class:
rounded-start
- Values:
$spacers
- Description: Applies rounding to the bottom-left and top-left corners of an element. Useful for left-to-right text direction or start alignment.
- Property:
Below is a list of example values based on the $spacer
unit, which defines the size of the rounding:
$spacer = 1
rounded-0
:0
- No rounding.rounded-1
:$spacer * 0.25
- Small rounding, 25% of the spacer unit.rounded-2
:$spacer * 0.5
- Moderate rounding, 50% of the spacer unit.rounded-3
:$spacer * 0.75
- Larger rounding, 75% of the spacer unit.rounded-4
:$spacer
- Full spacer unit rounding.rounded-5
:$spacer * 1.25
- Larger rounding, 125% of the spacer unit.rounded-6
:$spacer * 1.5
- Significant rounding, 150% of the spacer unit.rounded-7
:$spacer * 1.75
- More rounding, 175% of the spacer unit.rounded-8
:$spacer * 2
- Double spacer unit rounding.rounded-9
:$spacer * 2.25
- Extra rounding, 225% of the spacer unit.rounded-10
:$spacer * 2.5
- Large rounding, 250% of the spacer unit.rounded-11
:$spacer * 2.75
- Very large rounding, 275% of the spacer unit.rounded-12
:$spacer * 3
- Extreme rounding, 300% of the spacer unit.rounded-14
:$spacer * 3.5
- Maximum rounding, 350% of the spacer unit.rounded-15
:$spacer * 3.75
- Larger rounding, 375% of the spacer unit.rounded-16
:$spacer * 4
- Full maximum rounding, 400% of the spacer unit.rounded-17
:$spacer * 4.25
- Additional rounding, 425% of the spacer unit.rounded-18
:$spacer * 5
- Very large rounding, 500% of the spacer unit.rounded-19
:$spacer * 6
- Maximum rounding, 600% of the spacer unit.
top
- Property:
top
- Values: A combination of
$position-values
and$spacers
- Description: Applies a
top
offset to an element, pushing it downward from its normal position. The value is determined by merging predefined position values with spacer values.
- Property:
bottom
- Property:
bottom
- Values: A combination of
$position-values
and$spacers
- Description: Applies a
bottom
offset to an element, pulling it upward from its normal position. The value is determined by merging predefined position values with spacer values.
- Property:
start
- Property:
left
- Class:
start
- Values: A combination of
$position-values
and$spacers
- Description: Applies a
left
offset to an element. This is used to position elements in left-to-right (LTR) layouts. The value is determined by merging predefined position values with spacer values.
- Property:
end
- Property:
right
- Class:
end
- Values: A combination of
$position-values
and$spacers
- Description: Applies a
right
offset to an element. This is used to position elements in left-to-right (LTR) layouts. The value is determined by merging predefined position values with spacer values.
- Property:
The values for these classes are defined by merging position values with spacer units. Below is an example of how these values might be structured:
$position-values
: A map of predefined position values such as0
,auto
, or any specific offset values you define.$spacers
: A set of values defining standard spacing units.
For instance:
top-0
:0
- No offset from the top.top-1
: A small offset, such as$spacer * 0.25
.top-2
: A moderate offset, such as$spacer * 0.5
.top-3
: A larger offset, such as$spacer * 0.75
.
Similarly, you can apply these values to the bottom
, start
, and end
classes.
<div class="position-relative">
<div class="top-3">This element is offset 3 units from the top.</div>
<div class="bottom-2">This element is offset 2 units from the bottom.</div>
<div class="start-4">This element is offset 4 units from the start (left).</div>
<div class="end-5">This element is offset 5 units from the end (right).</div>
</div>
Use the following classes to create buttons with basic styles:
<!-- Default Button Sizes -->
<button class="btn btn-primary">Primary Button</button>
<button class="btn btn-secondary">Secondary Button</button>
<button class="btn btn-info">Info Button</button>
<button class="btn btn-light">Light Button</button>
<!-- Large Buttons -->
<button class="btn btn-primary btn-lg">Primary Button</button>
<button class="btn btn-secondary btn-lg">Secondary Button</button>
<button class="btn btn-info btn-lg">Info Button</button>
<button class="btn btn-light btn-lg">Light Button</button>
<!-- Small Buttons -->
<button class="btn btn-primary btn-sm">Primary Button</button>
<button class="btn btn-secondary btn-sm">Secondary Button</button>
<button class="btn btn-info btn-sm">Info Button</button>
<button class="btn btn-light btn-sm">Light Button</button>
The Carousel component allows you to create a slideshow of items. Use the following classes and HTML structure to integrate a carousel into your webpage.
<article
class="my-3"
id="carousel"
>
<div class="bd-heading sticky-xl-top align-self-start mt-5 mb-3 mt-xl-0 mb-xl-2">
<h4>Carousel</h4>
<a
class="d-flex align-items-center"
href="https://getbootstrap.com/docs/5.3/components/carousel/"
>Documentation</a
>
</div>
<div>
<div class="bd-example-snippet bd-code-snippet">
<div class="bd-example m-0 border-0">
<div
id="carouselExampleCaptions"
class="carousel slide"
data-bs-ride="carousel"
>
<div class="carousel-control-container">
<button
class="carousel-control-prev hide"
type="button"
data-bs-target="#carouselExampleCaptions"
data-bs-slide="prev"
>
<span class="material-symbols-outlined">arrow_back</span>
<span class="visually-hidden">Previous</span>
</button>
<div class="carousel-indicators">
<button
type="button"
data-bs-target="#carouselExampleCaptions"
data-bs-slide-to="0"
class="active"
aria-label="Slide 1"
aria-current="true"
></button>
<button
type="button"
data-bs-target="#carouselExampleCaptions"
data-bs-slide-to="1"
aria-label="Slide 2"
></button>
<button
type="button"
data-bs-target="#carouselExampleCaptions"
data-bs-slide-to="2"
aria-label="Slide 3"
></button>
</div>
<button
class="carousel-control-next"
type="button"
data-bs-target="#carouselExampleCaptions"
data-bs-slide="next"
>
<span class="material-symbols-outlined">arrow_forward</span>
<span class="visually-hidden">Next</span>
</button>
</div>
<div class="carousel-inner">
<div class="carousel-item active">
<svg
class="bd-placeholder-img bd-placeholder-img-lg d-block w-100"
width="800"
height="400"
xmlns="http://www.w3.org/2000/svg"
role="img"
aria-label="Placeholder: First slide"
preserveAspectRatio="xMidYMid slice"
focusable="false"
>
<title>Placeholder</title>
<rect
width="100%"
height="100%"
fill="#777"
></rect>
<text
x="50%"
y="50%"
fill="#555"
dy=".3em"
>
First slide
</text>
</svg>
<div class="carousel-caption d-none d-md-block">
<h5>First slide label</h5>
<p>Some representative placeholder content for the first slide.</p>
</div>
</div>
<div class="carousel-item">
<svg
class="bd-placeholder-img bd-placeholder-img-lg d-block w-100"
width="800"
height="400"
xmlns="http://www.w3.org/2000/svg"
role="img"
aria-label="Placeholder: Second slide"
preserveAspectRatio="xMidYMid slice"
focusable="false"
>
<title>Placeholder</title>
<rect
width="100%"
height="100%"
fill="#666"
></rect>
<text
x="50%"
y="50%"
fill="#444"
dy=".3em"
>
Second slide
</text>
</svg>
<div class="carousel-caption d-none d-md-block">
<h5>Second slide label</h5>
<p>Some representative placeholder content for the second slide.</p>
</div>
</div>
<div class="carousel-item">
<svg
class="bd-placeholder-img bd-placeholder-img-lg d-block w-100"
width="800"
height="400"
xmlns="http://www.w3.org/2000/svg"
role="img"
aria-label="Placeholder: Third slide"
preserveAspectRatio="xMidYMid slice"
focusable="false"
>
<title>Placeholder</title>
<rect
width="100%"
height="100%"
fill="#555"
></rect>
<text
x="50%"
y="50%"
fill="#333"
dy=".3em"
>
Third slide
</text>
</svg>
<div class="carousel-caption d-none d-md-block">
<h5>Third slide label</h5>
<p>Some representative placeholder content for the third slide.</p>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</article>
const myCarousel = document.getElementById('carousel');
const prevBtn = myCarousel.querySelector('.carousel-control-prev');
const nextBtn = myCarousel.querySelector('.carousel-control-next');
const items = myCarousel.querySelectorAll('.carousel-item');
myCarousel.addEventListener('slide.bs.carousel', (event) => {
if (event.to === 0) {
prevBtn.classList.add('hide');
} else prevBtn.classList.remove('hide');
if (event.to === items.length - 1) nextBtn.classList.add('hide');
else nextBtn.classList.remove('hide');
});
- Previous Button: Moves the carousel to the previous slide.
class="carousel-control-prev"
: Style class for the previous button.data-bs-slide="prev"
: Data attribute to specify the action.<span class="material-symbols-outlined">arrow_back</span>
: Icon for the button.aria-label="Previous"
: Accessible label.
- Next Button: Moves the carousel to the next slide.
class="carousel-control-next"
: Style class for the next button.data-bs-slide="next"
: Data attribute to specify the action.<span class="material-symbols-outlined">arrow_forward</span>
: Icon for the button.aria-label="Next"
: Accessible label.
- Indicators: Small buttons that indicate the current slide and allow navigation to a specific slide.
class="carousel-indicators"
: Container for the indicators.<button type="button" data-bs-slide-to="0" class="active" aria-label="Slide 1" aria-current="true"></button>
: Indicator for the first slide.data-bs-slide-to="N"
: Specifies which slide the button corresponds to.aria-current="true"
: Indicates the active slide.
- Carousel Item: Represents each slide within the carousel.
class="carousel-item"
: Style class for the item.class="active"
: Indicates the currently visible slide.- Content: Typically includes an image or other content along with optional captions.
- Caption: Provides text and description for each slide.
class="carousel-caption d-none d-md-block"
: Style class for the caption.- Contains elements like
<h5>
and<p>
to provide slide labels and descriptions.