Terrasen Comfort Colors Shirt | Throne Of Glass Quote T-Shirt Aelin Galathynius Rowan Manon Licensed SJM Universe Merch Bookish Shirt Gift

$14.98
$32.00
-53%
people are viewing this right now
Colors:  Black
Sizes:  S
Quantity

Description

Bookish "The World Will Be Saved" Quote shirt from the beloved Throne Of Glass series! Subtle SJM merch for fans of Aelin, Rowan, Dorian, Manon, Lysandra and many more!

The retro illustrated style design offers a ton of elevated bookish style and will make you want to wear it while reading your favorite fantasy romance book.

Comfort Colors Shirt
? Direct to Garment printing (no vinyl to crack, peel or shrink!)
? 100% ring-spun cotton
? Medium weight fabric
? Relaxed fit
? Sewn-in twill label

BUY THIS DESIGN AS A SWEATSHIRT HERE:

CLICK HERE TO SHOP OTHER BOOK LOVER PRODUCTS:

SIZING
The size chart is listed in photos above. Please use the measurement for the most accurate sizing.
Feel free to contact us if you need any size that you can't find in our drop down menu.

CUSTOMIZATION
Would you like this design on a different t-shirt, sweater, sweatshirt, hoodie, hat, socks, bag, poster, wall decal or anything else? Please feel free to reach out to me and I will do my best to get it made for you.

QUESTIONS?
I'm happy to answer them! Message me and I'll get back to you as soon as possible.

LICENSING
From Throne Of Lgass, by Sarah J. Maas, ? 2012. Artwork by ChapterCatchers LLC. Created with permission of Writers House LLC acting as agent for the author.

The art depicted on the products listed for sale is wholly original to me and has been approved by Sarah J. Maas for use on the products. Notwithstanding such approval, Sarah J. Maas has not collaborated with me in any way in the creation of the art, and the traits of any characters depicted in the art is in no way based on any foreknowledge by me of the traits of any characters in future books by Sarah J. Maas.

Customer Reviews

Here are what our customers say.

Write a Review
Customer Reviews
Wow you reached the bottom
Newest
Most liked
Highest ratings
Lowest ratings
×
class SpzCustomFileUpload extends SPZ.BaseElement { constructor(element) { super(element); this.uploadCount_ = 0; this.fileList_ = []; } buildCallback() { this.action = SPZServices.actionServiceForDoc(this.element); this.registerAction('upload', (data) => { this.handleFileUpload_(data.event?.detail?.data || []); }); this.registerAction('delete', (data) => { this.handleFileDelete_(data?.args?.data); }); this.registerAction('preview', (data) => { this.handleFilePreview_(data?.args?.data); }); this.registerAction('limit', (data) => { this.handleFileLimit_(); }); this.registerAction('sizeLimit', (data) => { this.handleFileSizeLimit_(); }); } isLayoutSupported(layout) { return layout == SPZCore.Layout.LOGIC; } setData_(count, file) { this.uploadCount_ = count; this.fileList_ = file; } handleFileUpload_(data) { data.forEach(i => { if(this.fileList_.some(j => j.url === i.url)) return; this.fileList_.push(i); }) this.uploadCount_++; sessionStorage.setItem('fileList', JSON.stringify(this.fileList_)); this.triggerEvent_("handleFileUpload", { count: this.uploadCount_, files: this.fileList_}); if(this.fileList_.length >= 5){ document.querySelector('#review_upload').style.display = 'none'; } if(this.fileList_.length > 0){ document.querySelector('.apps-reviews-write-anonymous-box').style.marginTop = '8px'; } } handleFileDelete_(index) { this.fileList_.splice(index, 1); this.uploadCount_--; sessionStorage.setItem('fileList', JSON.stringify(this.fileList_)); this.triggerEvent_("handleFileDelete", { count: this.uploadCount_, files: this.fileList_}); document.querySelector('#review_upload').style.display = 'block'; if(this.fileList_?.length === 0){ document.querySelector('.apps-reviews-write-anonymous-box').style.marginTop = '132px'; } } handleFilePreview_(index) { const finalPreviewData = this.fileList_[index]; const filePreviewModal = document.getElementById('filePreviewModal'); const fullScreenVideo = document.getElementById('fullScreenVideo'); const fullScreenImage = document.getElementById('fullScreenImage'); const previewModalClose = document.getElementById('previewModalClose'); const previewLoading = document.getElementById('previewLoading'); filePreviewModal.style.display = 'block'; previewLoading.style.display = 'flex'; if(finalPreviewData?.type === 'video'){ const media = this.mediaParse_(this.fileList_[index]?.url); fullScreenVideo.addEventListener('canplaythrough', function() { previewLoading.style.display = 'none'; }); fullScreenImage.src = ''; fullScreenImage.style.display = 'none'; fullScreenVideo.style.display = 'block'; fullScreenVideo.src = media.mp4 || ''; } else { fullScreenImage.onload = function() { previewLoading.style.display = 'none'; }; fullScreenVideo.src = ''; fullScreenVideo.style.display = 'none'; fullScreenImage.style.display = 'block'; fullScreenImage.src = finalPreviewData.url; } previewModalClose.addEventListener('click', function() { filePreviewModal.style.display = 'none'; }); } handleFileLimit_() { alert(window.AppReviewsLocale.comment_file_limit || 'please do not upload files more than 5'); this.triggerEvent_("handleFileLimit"); } handleFileSizeLimit_() { alert(window.AppReviewsLocale.comment_file_size_limit || 'File size does not exceed 10M'); } clear(){ this.fileList_ = []; this.uploadCount_ = 0; sessionStorage.setItem('fileList', JSON.stringify(this.fileList_)); this.triggerEvent_("handleClear", { count: this.uploadCount_, files: this.fileList_}); document.querySelector('#review_upload').style.display = 'block'; } mediaParse_(url) { var result = {}; try { url.replace(/[?&]+([^=&]+)=([^&]*)/gi, function (str, key, value) { try { result[key] = decodeURIComponent(value); } catch (e) { result[key] = value; } }); result.preview_image = url.split('?')[0]; } catch (e) {}; return result; } triggerEvent_(name, data) { const event = SPZUtils.Event.create(this.win, name, data); this.action.trigger(this.element, name, event); } } SPZ.defineElement('spz-custom-file-upload', SpzCustomFileUpload);
The review would not show in product details on storefront since it does not support to.