Conside this example from /sample/original/index.html
<!-- /sample/original/index.html -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Hello world</title>
<link rel="stylesheet" href="assets/style.css">
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.js"></script>
</head>
<body>
<div class="content">
<img src="https://ichef.bbci.co.uk/news/660/cpsprodpb/71E1/production/_99735192_gettyimages-459467912.jpg" alt="A permanent cat picture">
<p>Q: Why is this cat so grumpy?</p>
<p>A: Nobody knows.</p>
</div>
</body>
</html>
Here we have a page with 3 external assets.
<link rel="stylesheet" href="assets/style.css">
This references will simply not work when deployed, as your page will get a URL like arweave.net/your-tx-id
. As the arweave data API is flat you we can't have an assets
directory, and we can't have a named file. All data on the arweave network gets pseudorandom ID and address like arweave.net/hNvBcEOgEpeFTnYyLYayaU1h6jgG1KSl5Ujvab2js8Q
. you could upload your CSS first, then your HTML and use the CSS file transaction ID as the href
like <link rel="stylesheet" href="your-css-trasnaction-id">
but that's a lot of work.
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.js"></script>
<img src="https://ichef.bbci.co.uk/news/660/cpsprodpb/71E1/production/_99735192_gettyimages-459467912.jpg" alt="A permanent and grumpy cat">
These two lines wil work... for now. If the BBC change their image URLs or remove the linked image it's now gone forever, any arweave pages that refernced it will now have a blank space where that image was. The same issue exists for the cloudflare jQuery reference, so at some point this arweave page will stop working correctly. Maybe it's tomorrow, maybe it's 10 years.
We can use the --package
flag to avoid all of this. It works by looking for references to external content and then imports and inlines it directly into your HTML.
arweave deploy my-hello-world-demo/index.html --package
If you want to see how you file will be packaged before deploying then you can use the package command to test a packaged version of your file.
arweave package path-to-my-app/index.html my-packaged-output.html
Using the --package
flag
http://arweave.net/cxsNxKLNEzbCFu7_v7kYbp9Fpq0NWuDPcEieDsuYkHk
Without using the --package
flag
https://arweave.net/Oovrc3nWTpx3fAige-PuHQVnA1ebpJoGPxo1kLxJ3P8
This style sheet reference
<link rel="stylesheet" href="assets/style.css">
Becomes this
<style>
body {
background: #383B44;
text-align: center;
}
.content{
margin: 10% auto;
font-family: Arial, Helvetica, sans-serif;
font-size: 1.5rem;
color: #FFFFFF;
}
</style>
This JavaScript reference
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.js"></script>
Becomes this
<script>!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(e,t){"use strict";var n=[],r=e.document...
This image reference
<img src="https://ichef.bbci.co.uk/news/660/cpsprodpb/71E1/production/_99735192_gettyimages-459467912.jpg" alt="A permanent cat picture">
Becomes this
<img alt="A permanent cat picture" src="...