423 lines
36 KiB
PHTML
423 lines
36 KiB
PHTML
<?php
|
|
|
|
$new = $this->getParam('new', false);
|
|
$logs = $this->getParam('logs', null);
|
|
|
|
?>
|
|
<div
|
|
data-service="databases.getCollection"
|
|
data-param-collection-id="{{router.params.collection}}"
|
|
data-param-database-id="{{router.params.databaseId}}"
|
|
data-scope="sdk"
|
|
data-event="load,databases.updateDocument"
|
|
data-name="project-collection">
|
|
|
|
<div
|
|
data-service="databases.getDocument"
|
|
data-param-collection-id="{{router.params.collection}}"
|
|
data-param-database-id="{{router.params.databaseId}}"
|
|
data-param-document-id="{{router.params.id}}"
|
|
data-scope="sdk"
|
|
data-event="load"
|
|
data-name="project-document"
|
|
data-success="default">
|
|
|
|
<div class="cover">
|
|
<h1 class="zone xl margin-bottom-large">
|
|
<a data-ls-attrs="href=/console/databases/collection?id={{router.params.collection}}&databaseId={{router.params.databaseId}}&project={{router.params.project}}" class="back text-size-small link-return-animation--start"><i class="icon-left-open"></i> <span data-ls-bind="{{project-collection.name}}"></span></a>
|
|
|
|
<br />
|
|
|
|
<span data-ls-if="({{project-document.$id}})" data-ls-bind="Document"> </span>
|
|
<span data-ls-if="(!{{project-document.$id}})" data-ls-bind="Document"> </span>
|
|
</h1>
|
|
</div>
|
|
|
|
<div data-ui-modal class="modal width-large box close" data-button-hide="on" data-open-event="open-json">
|
|
<button type="button" class="close pull-end" data-ui-modal-close=""><i class="icon-cancel"></i></button>
|
|
|
|
<h2>JSON View</h2>
|
|
|
|
<div class="margin-bottom">
|
|
<input type="hidden" data-ls-bind="{{project-document}}" data-forms-code />
|
|
</div>
|
|
|
|
<button data-ui-modal-close="" type="button" class="reverse">Cancel</button>
|
|
</div>
|
|
|
|
<div class="zone xl margin-bottom-no">
|
|
<ul class="phases clear" data-ui-phases data-selected="{{router.params.tab}}">
|
|
<li data-state="/console/databases/document?id={{router.params.id}}&collection={{router.params.collection}}&databaseId={{router.params.databaseId}}&project={{router.params.project}}">
|
|
<h2 class="margin-bottom">Overview</h2>
|
|
|
|
<div class="row responsive">
|
|
<div class="col span-8 margin-bottom">
|
|
<form
|
|
data-analytics
|
|
data-analytics-activity
|
|
data-analytics-event="submit"
|
|
data-analytics-category="console"
|
|
data-service="{{|documentAction}}"
|
|
data-name="project-document"
|
|
data-scope="sdk"
|
|
data-event="submit"
|
|
data-failure="alert"
|
|
data-failure-param-alert-classname="error"
|
|
<?php if($new): ?>
|
|
data-analytics-label="Create Database Document"
|
|
data-success="trigger,redirect"
|
|
data-success-param-trigger-events="databases.createDocument"
|
|
data-success-param-redirect-url="/console/databases/collection?id={{project-collection.$id}}&databaseId={{router.params.databaseId}}&project={{router.params.project}}"
|
|
data-failure-param-alert-text="Failed to create document"
|
|
<?php else: ?>
|
|
data-analytics-label="Update Database Document"
|
|
data-success="trigger,alert"
|
|
data-success-param-trigger-events="databases.updateDocument"
|
|
data-success-param-alert-text="Your document was updated"
|
|
data-failure-param-alert-text="Failed to update document"
|
|
<?php endif; ?>
|
|
>
|
|
|
|
<input type="hidden" name="collectionId" data-ls-bind="{{project-collection.$id}}" />
|
|
<input type="hidden" name="databaseId" data-ls-bind="{{router.params.databaseId}}" />
|
|
<?php if(!$new): ?><input type="hidden" name="documentId" data-ls-bind="{{project-document.$id}}" /><?php endif; ?>
|
|
|
|
<div class="box">
|
|
<?php if($new): ?>
|
|
<label for="documentId">Document ID</label>
|
|
<input
|
|
type="hidden"
|
|
data-custom-id
|
|
data-id-type="auto"
|
|
data-validator="databases.getDocument"
|
|
required
|
|
maxlength="36"
|
|
name="documentId"
|
|
id="documentId"
|
|
maxlength="36"
|
|
pattern="^[a-zA-Z0-9][a-zA-Z0-9._-]{0,35}$" />
|
|
<?php endif; ?>
|
|
|
|
<fieldset name="data" data-cast-to="object" data-ls-attrs="x-init=doc = {{project-document}}" x-data="{doc: {}}">
|
|
<ul data-ls-attrs="x-init=attributes = {{project-collection.attributes}}" x-data="{attributes: []}">
|
|
<template x-for="attr in attributes.filter(a => a.status === 'available')">
|
|
<li>
|
|
<label>
|
|
<div x-text="attr.key" class="margin-bottom-tiny"></div>
|
|
<span x-show="attr.required" class="text-size-xs text-danger text-fade">required</span>
|
|
<span x-show="!attr.required" class="text-size-xs text-fade">optional</span>
|
|
</label>
|
|
<template x-if="!attr.array">
|
|
<div>
|
|
<template x-if="attr.type === 'integer'">
|
|
<input
|
|
type="number"
|
|
step="1"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
:min="attr.min"
|
|
:max="attr.max"
|
|
x-model="doc[attr.key]"
|
|
data-cast-to="integer" />
|
|
</template>
|
|
<template x-if="attr.type === 'double'">
|
|
<input
|
|
type="number"
|
|
step="any"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
:min="attr.min"
|
|
:max="attr.max"
|
|
x-model="doc[attr.key]"
|
|
data-cast-to="float" />
|
|
</template>
|
|
<template x-if="attr.type === 'boolean'">
|
|
<input
|
|
class="button switch margin-bottom"
|
|
type="checkbox"
|
|
:name="attr.key"
|
|
:checked="doc[attr.key]" />
|
|
</template>
|
|
<template x-if="attr.type === 'datetime'">
|
|
<input
|
|
type="datetime-local"
|
|
step=".001"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
x-model="doc[attr.key]"
|
|
data-cast-to="string" />
|
|
</template>
|
|
<template x-if="attr.type === 'string' && !attr.format">
|
|
<textarea
|
|
data-forms-text-resize
|
|
data-forms-text-direction
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
:maxlength="attr.size"
|
|
x-model="doc[attr.key]"
|
|
data-cast-to="string"></textarea>
|
|
</template>
|
|
<template x-if="attr.format === 'ip'">
|
|
<textarea
|
|
data-forms-text-resize
|
|
data-forms-text-direction
|
|
pattern="((^\s*((([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]))\s*$)|(^\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(%.+)?\s*$))"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
x-model="doc[attr.key]"
|
|
data-cast-to="string"></textarea>
|
|
</template>
|
|
<template x-if="attr.format === 'email'">
|
|
<textarea
|
|
data-forms-text-resize
|
|
data-forms-text-direction
|
|
type="email"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
x-model="doc[attr.key]"
|
|
data-cast-to="string"></textarea>
|
|
</template>
|
|
<template x-if="attr.format === 'url'">
|
|
<textarea
|
|
data-forms-text-resize
|
|
data-forms-text-direction
|
|
type="url"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
x-model="doc[attr.key]"
|
|
data-cast-to="string"></textarea>
|
|
</template>
|
|
<template x-if="attr.format === 'enum'">
|
|
<select
|
|
:required="attr.required"
|
|
:name="attr.key"
|
|
data-cast-to="string">
|
|
<option :disabled="attr.required" selected label=" "></option>
|
|
|
|
<template x-for="element in attr.elements">
|
|
<option
|
|
:value="element"
|
|
x-text="element"
|
|
:selected="doc[attr.key] === element"></option>
|
|
</template>
|
|
</select>
|
|
</template>
|
|
</div>
|
|
</template>
|
|
<template x-if="attr.array">
|
|
<div>
|
|
<input type="hidden" :required="attr.required" :name="attr.key" data-cast-to="array-empty">
|
|
<template x-for="(node, index) in doc[attr.key]">
|
|
<div class="row responsive thin margin-bottom-tiny">
|
|
<div class="col span-11 margin-bottom-small">
|
|
<template x-if="attr.type === 'integer'">
|
|
<input
|
|
type="number"
|
|
step="1"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
:min="attr.min"
|
|
:max="attr.max"
|
|
x-model="doc[attr.key][index]"
|
|
data-cast-to="integer" />
|
|
</template>
|
|
<template x-if="attr.type === 'double'">
|
|
<input
|
|
type="number"
|
|
step="any"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
:min="attr.min"
|
|
:max="attr.max"
|
|
x-model="doc[attr.key][index]"
|
|
data-cast-to="float" />
|
|
</template>
|
|
<template x-if="attr.type === 'boolean'">
|
|
<input
|
|
class="button switch"
|
|
:class="(doc[attr.key].length - 1) === index ? 'margin-bottom' : ''"
|
|
type="checkbox"
|
|
:name="attr.key"
|
|
:value="attr.key"
|
|
:checked="doc[attr.key][index]" />
|
|
</template>
|
|
<template x-if="attr.type === 'datetime'">
|
|
<input
|
|
type="datetime-local"
|
|
step=".001"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
x-model="doc[attr.key][index]"
|
|
data-cast-to="string" />
|
|
</template>
|
|
<template x-if="attr.type === 'string' && !attr.format">
|
|
<textarea
|
|
data-forms-text-resize
|
|
data-forms-text-direction
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
:maxlength="attr.size"
|
|
x-model="doc[attr.key][index]"
|
|
data-cast-to="string"></textarea>
|
|
</template>
|
|
<template x-if="attr.format === 'ip'">
|
|
<textarea
|
|
data-forms-text-resize
|
|
data-forms-text-direction
|
|
pattern="((^\s*((([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]))\s*$)|(^\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(%.+)?\s*$))"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
x-model="doc[attr.key][index]"
|
|
data-cast-to="string"></textarea>
|
|
</template>
|
|
<template x-if="attr.format === 'email'">
|
|
<textarea
|
|
data-forms-text-resize
|
|
data-forms-text-direction
|
|
type="email"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
x-model="doc[attr.key][index]"
|
|
data-cast-to="string"></textarea>
|
|
</template>
|
|
<template x-if="attr.format === 'url'">
|
|
<textarea
|
|
data-forms-text-resize
|
|
data-forms-text-direction
|
|
type="url"
|
|
:placeholder="attr.default"
|
|
:name="attr.key"
|
|
:required="attr.required"
|
|
x-model="doc[attr.key][index]"
|
|
data-cast-to="string"></textarea>
|
|
</template>
|
|
<template x-if="attr.format === 'enum'">
|
|
<select
|
|
:required="attr.required"
|
|
:name="attr.key"
|
|
data-cast-to="string">
|
|
<option :disabled="attr.required" selected label=" "></option>
|
|
|
|
<template x-for="element in attr.elements">
|
|
<option
|
|
:value="element"
|
|
x-text="element"
|
|
:selected="doc[attr.key][index] === element"></option>
|
|
</template>
|
|
</select>
|
|
</template>
|
|
</div>
|
|
<div class="col span-1 margin-bottom-small">
|
|
<button type="button" class="dark danger small round pull-end" style="margin-top: 10px;" @click="doc[attr.key].splice(index, 1)"><i class="icon-cancel"></i></button>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
<button type="button" class="margin-end margin-bottom-small reverse" @click="doc = addAttribute(doc, attr.key)"> Add Attribute </button>
|
|
</div>
|
|
</template>
|
|
</li>
|
|
</template>
|
|
</ul>
|
|
</fieldset>
|
|
|
|
<div class="toggle margin-bottom" data-ls-ui-open data-button-aria="Open Permissions">
|
|
<i class="icon-plus pull-end margin-top-tiny"></i>
|
|
<i class="icon-minus pull-end margin-top-tiny"></i>
|
|
|
|
<h3 class="margin-bottom-large">Permissions</h3>
|
|
|
|
<label for="collection-read">Read Access <span class="text-size-small">(<a data-ls-attrs="href={{env.HOME}}/docs/permissions" target="_blank" rel="noopener">Learn more</a>)</span></label>
|
|
<input type="hidden" id="collection-read" name="read" data-forms-tags data-cast-to="json" data-ls-bind="{{project-document.$read}}" placeholder="User ID, Team ID or Role" />
|
|
<div class="text-fade text-size-xs margin-top-negative-small margin-bottom">Add 'role:all' for wildcard access</div>
|
|
|
|
<label for="collection-write">Write Access <span class="text-size-small">(<a data-ls-attrs="href={{env.HOME}}/docs/permissions" target="_blank" rel="noopener">Learn more</a>)</label>
|
|
<input type="hidden" id="collection-write" name="write" data-forms-tags data-cast-to="json" data-ls-bind="{{project-document.$write}}" placeholder="User ID, Team ID or Role" />
|
|
<div class="text-fade text-size-xs margin-top-negative-small margin-bottom">Add 'role:all' for wildcard access</div>
|
|
</div>
|
|
|
|
<button data-ls-if="({{project-document.$id}})">Update</button>
|
|
<button data-ls-if="(!{{project-document.$id}})">Create</button>
|
|
</div>
|
|
|
|
</form>
|
|
</div>
|
|
<div class="col span-4 sticky-top">
|
|
|
|
<div data-ls-if="({{project-document.$id}})">
|
|
<label>Document ID</label>
|
|
<div class="input-copy margin-bottom">
|
|
<input type="text" autocomplete="off" placeholder="" data-ls-bind="{{project-document.$id}}" disabled data-forms-copy class="margin-bottom-no" />
|
|
</div>
|
|
</div>
|
|
|
|
<label>Collection ID</label>
|
|
<div class="input-copy margin-bottom">
|
|
<input type="text" autocomplete="off" placeholder="" data-ls-bind="{{router.params.collection}}" disabled data-forms-copy class="margin-bottom-no" />
|
|
</div>
|
|
|
|
<ul class="margin-bottom-large text-fade text-size-small" data-ls-if="({{project-document.$id}})">
|
|
<li class="margin-bottom-small"><i class="icon-angle-circled-right margin-start-tiny margin-end-tiny"></i>
|
|
<button data-ls-ui-trigger="open-json"
|
|
class="link text-size-small"
|
|
data-analytics
|
|
data-analytics-event="click"
|
|
data-analytics-category="console"
|
|
data-analytics-label="View as JSON (Document)">
|
|
View as JSON
|
|
</button>
|
|
</li>
|
|
<li class="margin-bottom-small"><i class="icon-angle-circled-right margin-start-tiny margin-end-tiny"></i> Last Updated: <span data-ls-bind="{{project-document.$updatedAt|dateText}}"></span></li>
|
|
<li class="margin-bottom-small"><i class="icon-angle-circled-right margin-start-tiny margin-end-tiny"></i> Created: <span data-ls-bind="{{project-document.$createdAt|dateText}}"></span></li>
|
|
</ul>
|
|
|
|
<div data-ls-if="({{project-document.$id}})">
|
|
<form name="databases.deleteDocument" class="margin-bottom"
|
|
data-analytics
|
|
data-analytics-activity
|
|
data-analytics-event="submit"
|
|
data-analytics-category="console"
|
|
data-analytics-label="Delete Collection Document"
|
|
data-service="databases.deleteDocument"
|
|
data-event="submit"
|
|
data-param-database-id="{{router.params.databaseId}}"
|
|
data-param-collection-id="{{router.params.collection}}"
|
|
data-param-document-id="{{project-document.$id}}"
|
|
data-confirm="Are you sure you want to delete this document?"
|
|
data-success="alert,trigger,redirect"
|
|
data-success-param-alert-text="Document deleted successfully"
|
|
data-success-param-trigger-events="databases.deleteDocument"
|
|
data-success-param-redirect-url="/console/databases/collection?id={{router.params.collection}}&project={{router.params.project}}&databaseId={{router.params.databaseId}}"
|
|
data-failure="alert"
|
|
data-failure-param-alert-text="Failed to delete collection"
|
|
data-failure-param-alert-classname="error">
|
|
|
|
<button type="submit" class="danger fill">Delete Document</button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</li>
|
|
<?php if(!$new): ?>
|
|
<li data-state="/console/databases/document/activity?id={{router.params.id}}&collection={{router.params.collection}}&project={{router.params.project}}">
|
|
<h2>Activity</h2>
|
|
|
|
<?php echo $logs->render(); ?>
|
|
</li>
|
|
<?php endif; ?>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|