Is there a way I can twirl or tilt this ribbon text to enhance its readability?

I only want to rotate or flip the text on a ribbon box, not the entire box itself.

If you try to rotate the box directly, it may disrupt the string animation.

(function(){
var STATE_CLOSED = 0,
STATE_DETACHED = 1,
STATE_OPENED = 2,

TAG_HEIGHT = 30,
TAG_WIDTH = 200,
MAX_STRAIN = 40,

// Factor of page height that needs to be dragged for the
// curtain to fall
DRAG_THRESHOLD = 0.36;

VENDORS = [ 'Webkit', 'Moz', 'O', 'ms' ];

var dom = {
ribbon: null,
ribbonString: null,
ribbonTag: null,
curtain: null,
closeButton: null
},

// The current state of the ribbon
state = STATE_CLOSED,

// Ribbon text, correlates to states
closedText = '',
detachedText = '',

friction = 1.04;
gravity = 1.5,

// Resting position of the ribbon when curtain is closed
closedX = TAG_WIDTH * 0.55,
closedY = -TAG_HEIGHT * 0.1,

// Resting position of the ribbon when curtain is opened
openedX = TAG_WIDTH * 0.4,
openedY = TAG_HEIGHT,

velocity = 0,
rotation = 45,

curtainTargetY = 0,
curtainCurrentY = 0,

dragging = false,
dragTime = 0,
dragY = 0,

anchorA = new Point( closedX, closedY ),
anchorB = new Point( closedX, closedY ),

mouse = new Point();

function initialize() {

dom.ribbon = document.querySelector( '.forkit' );
dom.curtain = document.querySelector( '.forkit-curtain' );
dom.closeButton = document.querySelector( '.forkit-curtain .close-button' );

if( dom.ribbon ) {

// Fetch label texts from DOM
closedText = dom.ribbon.getAttribute( 'data-text' ) || '';
detachedText = dom.ribbon.getAttribute( 'data-text-detached' ) || closedText;


// Start the animation loop
animate();
}
}

// Omitted rest of the JavaScript code for brevity

});

initialize();

})();
.forkit-curtain {
text-align: center;
background: rgba( 0, 0, 0, 0.8 );
padding-top: 0%;
}

.forkit-curtain  .close-button {
position: absolute;
width: 32px;
height: 32px;
right: 20px;
top: 20px;
cursor: pointer;

background: url( middx...");

// Style CSS omitted for brevity

<p>This allows us to fill areas with transparent color; the first three numbers represent the color in RGB values and the fourth represents a transparency value between 0 and 1 (zero being fully transparent and one being fully opaque). We have long had the opacity property, which is similar, but....</p>

JSFiddle

Answer №1

Make sure to include the following code at the end of your CSS stylesheet.

#ribbonText{
transform: rotate(180deg)
}

Next, update the forkit anchor tag with this new code-

    <a class="forkit" data-text="<div id='ribbonText'>10% Off</div>"
data-text-detached="Scroll down >" href=""></a>

Similar questions

If you have not found the answer to your question or you are interested in this topic, then look at other similar questions below or use the search

Having trouble decoding URL in nodeJS

I have encountered an issue while using the express framework in NodeJS. I am attempting to send an activation link via email, but when activating the link, the URL becomes encoded and the express routes are unable to read it, leading to a 404 error page. ...

Navigating protected routes in a React application

Currently, I am facing an issue with my private routing setup. In my App.js code, I am using the user variable to determine if a user is logged in or not, and restrict access to private routes accordingly. However, there is a delay in fetching user data fr ...

The error message "TypeError: Cannot read property 'map' of undefined when trying to set state as an array"

Encountering an error while trying to map the state for my posts:[] object: Error message: TypeError: this.state.posts.map is not a function While searching for a solution, I found something similar on this link, but unfortunately, it did not solve the ...

Angular Routing for a specific page path

I am currently in the process of working on a project using the MEAN stack and I have encountered an issue with getting a specific template to display on a particular URL. Currently, when users visit www.myurl/catalog, it loads the catalog.html template, ...

Sending string variable from Perl CGI script to HTML frontend

Having just begun experimenting with AJAX, I'm encountering difficulties in passing variables back to my HTML script. In this setup, I'm using a combination of a XAMPP webserver, JavaScript, and jQuery for the HTML script, along with a Perl cgi ...

Repairing a syntax error in a jQuery selector variable

$(".className").click(function(){ var link = $(this).find("a").attr('href'); //output is '#myID' var findItems = $(link '.mydiv').length; //WRONG var findItems = $(link + '.mydiv').length; ...

Display drop-down item when selected for the first time and hide it when selected for the same item for the second time

Is there a way to display form input when "C" is selected and hide it when "A", "B", or "D" are selected? If "C" is selected again after initially showing the form input, should it be hidden? For example, if "C" is selected for the first time, the form inp ...

Using Ajax with the submitHandler function in jQuery Validation Plugin

Currently, I'm working with the jQuery validation plugin in conjunction with ASP.NET MVC. I am trying to utilize $.Ajax() to submit a form, but I'm encountering an issue where the entire section of code I have written seems to be getting skipped ...

Can you create a while loop that continuously asks for user input, stores the responses, and then makes them accessible in an array?

When developing a Yeoman generator, the necessary dependencies can be found at https://github.com/sboudrias/mem-fs-editor#copytplfrom-to-context-settings and https://github.com/SBoudrias/Inquirer.js/. The main goal is to prompt the user with a question an ...

Using the Same Component Multiple Times in React-Redux

Is it possible to render multiple instances of the same container component in React-Redux without each instance being affected by data changes from another instance? <ContainerInstance1 data={data1}/> <ContainerInstance2 data={data2}/> Curre ...

Joi has decided against incorporating custom operators into their extended features

I am having trouble extending the joi class with custom operators. My goal is to validate MongoDB Ids, but when I try to use the extended object, I encounter the following error: error: uncaughtException: JoiObj.string(...).objectId is not a function TypeE ...

What's the best way to organize Python objects for optimal JSON serialization?

Recently transitioning from JavaScript to Python, I am facing a challenge in understanding how to effectively communicate between client and server using JSON. Specifically, I am struggling to find the equivalent of an easily jsonifyable object attribute i ...

How can we automate the process of assigning the hash(#) in Angular?

Is it possible to automatically assign a unique hash(#) to elements inside an ngFor loop? <div *ngFor="let item of itemsArray; index as i"> <h3 #[item][i]> {{ item }} </h3> </div> I would like the outp ...

Is there a discrepancy between the data posted using jQuery and the payload in Json?

Why is it that when I create a string in Jquery, the Chrome Javascript Debugger displays it like this: {"ClaimType":"Trade","ClaimedProductId":4,"ClaimingUserId":3,"Message":"","TradeOffers":"[{"OfferedProductId":"3","OfferedQuantity":"2"},{"OfferedProduc ...

The issue arises when trying to apply Bootstrap CSS styles to dynamically created elements using JavaScript

I utilized JavaScript to create a Bootstrap Modal and followed the correct classes as outlined in the Bootstrap documentation, but unfortunately, the JavaScript-created elements are not being affected. Even after adding the Bootstrap classes and attribute ...

Button functionality disabled in Firefox, yet functional in Chrome

Here is the header code snippet: <header id="app-header" className="fluid-container navbar navbar-default"> <div> <button className={buttonClass} onClick={this.openSideBar}> ...

The jQuery click event does not fire within a bootstrap carousel

I am trying to set up a bootstrap carousel where clicking on an image inside it will trigger a self-made lightbox. However, I am facing some issues with the JavaScript code not being triggered with the following syntax: $('html').on("click", ".l ...

Tips for Accessing a New Website Using the Floating Layer Close Button

How can I trigger the opening of a new browser window when a visitor clicks the close "x" on my floating layer ad? The close button is within an HTML link code ("a href"), but simply putting a URL in there does not seem to work. <script language=" ...

Is there a way to verify the presence of data returned by an API?

I am trying to implement a system in my Index.vue where I need to check if my API request returns any data from the fetchData function. Once the data is fetched, I want to return either a boolean value or something else to my Index.vue. Additionally, I wou ...

The JavaScript function you are trying to access is not defined, resulting in a

While attempting to run an Ajax request, I encountered a ReferenceError: getData is not defined in the Console. Interestingly, this code was functioning perfectly around 6 months ago. Despite looking through previously posed questions, I have been unable ...