223 lines
12 KiB
PHTML
223 lines
12 KiB
PHTML
<div class="cover">
|
|
<h1 class="zone xl margin-bottom-large">
|
|
<a data-ls-attrs="href=/console/home?project={{router.params.project}}" class="back text-size-small link-return-animation--start"><i class="icon-left-open"></i> Home</a>
|
|
<br />
|
|
|
|
<span>Storage</span>
|
|
</h1>
|
|
</div>
|
|
|
|
<div class="zone xl">
|
|
<ul class="phases clear" data-ui-phases data-selected="{{router.params.tab}}">
|
|
<li data-state="/console/storage?project={{router.params.project}}">
|
|
<h2>Buckets</h2>
|
|
|
|
<div class="margin-top"
|
|
data-service="storage.listBuckets"
|
|
data-event="load,storage.createBucket,storage.updateBucket,storage.deleteBucket"
|
|
data-param-search="{{router.params.search}}"
|
|
data-param-limit="<?php echo APP_PAGING_LIMIT; ?>"
|
|
data-param-offset="{{router.params.offset}}"
|
|
data-param-order-type="ASC"
|
|
data-scope="sdk"
|
|
data-name="project-buckets">
|
|
|
|
<div data-ls-if="(!{{project-buckets.sum}})" class="box dashboard margin-bottom">
|
|
<div class="margin-bottom-small margin-top-small margin-end margin-start">
|
|
<h3 class="margin-bottom-small text-bold">No Buckets Found</h3>
|
|
|
|
<p class="margin-bottom-no">You haven't created any buckets for your project yet.</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div data-ls-if="0 != {{project-buckets.sum}}">
|
|
<ul data-ls-loop="project-buckets.buckets" data-ls-as="bucket" data-ls-append="" class="tiles cell-3 margin-bottom-small">
|
|
<li class="margin-bottom">
|
|
<a data-ls-attrs="href=/console/storage/bucket?id={{bucket.$id}}&project={{router.params.project}}" class="box">
|
|
<div data-ls-bind="{{bucket.name}}" class="text-one-liner margin-bottom text-bold"> </div>
|
|
|
|
<i class="icon-right-open"></i>
|
|
</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
|
|
<div class="pull-end text-align-center paging">
|
|
<form
|
|
data-service="storage.listBuckets"
|
|
data-event="submit"
|
|
data-param-search="{{router.params.search}}"
|
|
data-param-limit="<?php echo APP_PAGING_LIMIT; ?>"
|
|
data-param-order-type="DESC"
|
|
data-scope="sdk"
|
|
data-name="project-buckets"
|
|
data-success="state"
|
|
data-success-param-state-keys="search,offset">
|
|
<button name="offset" data-paging-back data-offset="{{router.params.offset}}" data-sum="{{project-buckets.sum}}" class="margin-end round small" aria-label="Back"><i class="icon-left-open"></i></button>
|
|
</form>
|
|
|
|
<span data-ls-bind="{{router.params.offset|pageCurrent}} / {{project-buckets.sum|pageTotal}}"></span>
|
|
|
|
<form
|
|
data-service="storage.listBuckets"
|
|
data-event="submit"
|
|
data-param-search="{{router.params.search}}"
|
|
data-param-limit="<?php echo APP_PAGING_LIMIT; ?>"
|
|
data-param-order-type="DESC"
|
|
data-scope="sdk"
|
|
data-name="project-buckets"
|
|
data-success="state"
|
|
data-success-param-state-keys="search,offset">
|
|
<button name="offset" data-paging-next data-offset="{{router.params.offset}}" data-sum="{{project-buckets.sum}}" class="margin-start round small" aria-label="Next"><i class="icon-right-open"></i></button>
|
|
</form>
|
|
</div>
|
|
|
|
<div data-ui-modal class="modal close box sticky-footer" data-button-text="Add Bucket">
|
|
<button type="button" class="close pull-end" data-ui-modal-close=""><i class="icon-cancel"></i></button>
|
|
|
|
<h1>New Bucket</h1>
|
|
|
|
<form
|
|
data-analytics
|
|
data-analytics-activity
|
|
data-analytics-event="submit"
|
|
data-analytics-category="console"
|
|
data-analytics-label="Create Storage Bucket"
|
|
data-service="storage.createBucket"
|
|
data-event="submit"
|
|
data-scope="sdk"
|
|
data-success="alert,reset,redirect,trigger"
|
|
data-success-param-alert-text="Bucket created successfully"
|
|
data-success-param-redirect-url="/console/storage/bucket/settings?id={{serviceData.$id}}&project={{router.params.project}}"
|
|
data-success-param-trigger-events="storage.createBucket"
|
|
data-failure="alert"
|
|
data-failure-param-alert-text="Failed to create bucket"
|
|
data-failure-param-alert-classname="error">
|
|
|
|
<label for="bucket-id">Bucket ID</label>
|
|
<input
|
|
type="hidden"
|
|
data-custom-id
|
|
data-id-type="auto"
|
|
data-validator="storage.getBucket"
|
|
required
|
|
maxlength="36"
|
|
name="bucketId" />
|
|
|
|
<label for="bucket-name">Name</label>
|
|
<input type="text" class="full-width" id="bucket-name" name="name" required autocomplete="off" maxlength="128" />
|
|
|
|
<input type="hidden" id="bucket-permission" name="permission" required value="file" />
|
|
<input type="hidden" id="bucket-read" name="read" required data-cast-to="json" value="<?php echo htmlentities(json_encode([])); ?>" />
|
|
<input type="hidden" id="bucket-write" name="write" required data-cast-to="json" value="<?php echo htmlentities(json_encode([])); ?>" />
|
|
|
|
<hr />
|
|
|
|
<button type="submit">Create</button> <button data-ui-modal-close="" type="button" class="reverse">Cancel</button>
|
|
</form>
|
|
</div>
|
|
|
|
</li>
|
|
|
|
<li data-state="/console/storage/usage?project={{router.params.project}}">
|
|
<form class="pull-end margin-start-small margin-top-small" data-ls-if="{{usage.range}} !== '90d'"
|
|
data-service="storage.getUsage"
|
|
data-event="submit"
|
|
data-name="usage"
|
|
data-param-range="90d">
|
|
<button class="tick">90d</button>
|
|
</form>
|
|
|
|
<button class="tick pull-end margin-start-small margin-top-small" data-ls-if="{{usage.range}} === '90d'" disabled>90d</button>
|
|
|
|
<form class="pull-end margin-start-small margin-top-small" data-ls-if="{{usage.range}} !== '30d'"
|
|
data-service="storage.getUsage"
|
|
data-event="submit"
|
|
data-name="usage">
|
|
<button class="tick">30d</button>
|
|
</form>
|
|
|
|
<button class="tick pull-end margin-start-small margin-top-small" data-ls-if="{{usage.range}} === '30d'" disabled>30d</button>
|
|
|
|
<form class="pull-end margin-start-small margin-top-small" data-ls-if="{{usage.range}} !== '24h'"
|
|
data-service="storage.getUsage"
|
|
data-event="submit"
|
|
data-name="usage"
|
|
data-param-range="24h">
|
|
<button class="tick">24h</button>
|
|
</form>
|
|
|
|
<button class="tick pull-end margin-start-small margin-top-small" data-ls-if="{{usage.range}} === '24h'" disabled>24h</button>
|
|
|
|
<h2>Usage</h2>
|
|
|
|
<div
|
|
data-service="storage.getUsage"
|
|
data-event="load"
|
|
data-name="usage">
|
|
|
|
<div class="box dashboard">
|
|
<div class="row responsive">
|
|
<div class="col span-12">
|
|
<div class="margin-top-negative-small margin-end-negative-large">
|
|
<div class="chart pull-end">
|
|
<input type="hidden" data-ls-bind="{{usage}}" data-forms-chart="Total Files=filesCount,Total Buckets=bucketsCount"/>
|
|
</div>
|
|
<div class="chart-metric">
|
|
<div class="value margin-bottom-small margin-top-small">
|
|
<span class="sum" data-ls-bind="{{usage.filesStorage|statsGetLast|humanFileSize}}">0</span>
|
|
<span class="sum" data-ls-bind="{{usage.filesStorage|statsGetLast|statsTotal|humanFileUnit}}"></span>
|
|
</div>
|
|
<div class="unit margin-start-no margin-bottom-small">Storage</div>
|
|
</div>
|
|
</div>
|
|
<ul class="chart-notes margin-top-small">
|
|
<li>Total Files <span data-ls-bind="({{usage.filesCount|statsGetLast|statsTotal}})"></span></li>
|
|
<li>Total Buckets <span data-ls-bind="({{usage.bucketsCount|statsGetLast|statsTotal}})"></span></li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="box dashboard">
|
|
<div class="row responsive">
|
|
<div class="col span-6">
|
|
<div class="value"><span class="sum" data-ls-bind="{{usage.bucketsCount|statsGetLast|statsTotal}}" data-default="0">0</span></div>
|
|
<div class="margin-top-small"><b class="text-size-small unit">Buckets</b></div>
|
|
</div>
|
|
<div class="col span-6">
|
|
<div class="value"><span class="sum" data-ls-bind="{{usage.filesCount|statsGetLast}}" data-default="0">0</span></div>
|
|
<div class="margin-top-small"><b class="text-size-small unit">Files</b></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="box margin-bottom-small margin-top-large">
|
|
<div class="margin-start-negative-small margin-end-negative-small margin-top-negative-small margin-bottom-negative-small">
|
|
<div class="chart margin-bottom-no">
|
|
<input type="hidden" data-ls-bind="{{usage}}" data-forms-chart="Buckets read=bucketsRead" data-height="140" />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<ul class="chart-notes margin-bottom-large">
|
|
<li>Buckets read</li>
|
|
</ul>
|
|
|
|
<div class="box margin-bottom-small">
|
|
<div class="margin-start-negative-small margin-end-negative-small margin-top-negative-small margin-bottom-negative-small">
|
|
<div class="chart margin-bottom-no">
|
|
<input type="hidden" data-ls-bind="{{usage}}" data-forms-chart="Buckets create=bucketsCreate,Buckets update=bucketsUpdate,Buckets delete=bucketsDelete" data-height="140" />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<ul class="chart-notes margin-bottom-large">
|
|
<li>Buckets create</li>
|
|
<li>Buckets update</li>
|
|
<li>Buckets delete</li>
|
|
</ul>
|
|
</div>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|