import * as React from "react"; import * as Actions from "~/common/actions"; import * as Constants from "~/common/constants"; import * as System from "~/components/system"; import * as SVG from "~/common/svg"; import { css } from "@emotion/react"; import { dispatchCustomEvent } from "~/common/custom-events"; import ScenePage from "~/components/core/ScenePage"; import ScenePageHeader from "~/components/core/ScenePageHeader"; import CodeBlock from "~/components/system/CodeBlock"; const STYLES_KEY = css` display: flex; align-items: center; justify-content: space-between; width: 100%; max-width: 416px; background-color: ${Constants.system.foreground}; color: ${Constants.system.pitchBlack}; border-radius: 4px; height: 40px; `; const STYLES_KEY_LEFT = css` min-width: 10%; width: 100%; font-family: ${Constants.font.code}; padding: 0 16px; font-size: 11px; `; const STYLES_KEY_CONTAINER = css` height: 40px; display: flex; flex-direction: row; align-items: center; margin-bottom: 8px; `; const STYLES_CIRCLE_BUTTON = css` height: 40px; width: 40px; border-radius: 4px; display: inline-flex; align-items: center; justify-content: center; user-select: none; background: ${Constants.system.gray}; color: ${Constants.system.black}; box-shadow: 0 1px 4px rgba(0, 0, 0, 0.07); cursor: pointer; transition: 200ms ease all; :hover { background: ${Constants.system.brand}; color: ${Constants.system.white}; } `; class Key extends React.Component { state = { visible: false }; _handleToggleVisible = () => { this.setState({ visible: !this.state.visible }); }; _handleDelete = async (id) => { await this.props.onDelete(id); }; render() { return (
{this.state.visible ? (
{this.props.data.key}
) : (
XXXXXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXXXX
)}
this._handleDelete(this.props.data.id)} style={{ marginLeft: 8, }} >
); } } const EXAMPLE_GET_SLATE = ( key, slateId ) => `const response = await fetch('https://slate.host/api/v1/get-slate', { method: 'POST', headers: { 'Content-Type': 'application/json', // NOTE: your API key Authorization: 'Basic ${key}', }, body: JSON.stringify({ data: { // NOTE: your slate ID id: ${slateId} }}) }); const json = await response.json(); console.log(json);`; const EXAMPLE_GET = ( key ) => `const response = await fetch('https://slate.host/api/v1/get', { method: 'POST', headers: { 'Content-Type': 'application/json', // NOTE: your API key Authorization: 'Basic ${key}', }, body: JSON.stringify({ data: { // NOTE: optional, if you want your private slates too. private: false }}) }); const json = await response.json(); console.log(json);`; const EXAMPLE_GET_SLATE_RESPONSE = (key, slateId) => `{ data: { id: '${slateId}', updated_at: '2020-07-27T09:04:53.007Z', created_at: '2020-07-27T09:04:53.007Z', published_at: '2020-07-27T09:04:53.007Z', slatename: 'slatename', data: { name: "slatename", public: true, objects: [ { id: "data-xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", name: "data-xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", ownerId: "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", url: "https://slate.host/static/art-v2-social.png" } ], ownerId: "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" } } }`; const EXAMPLE_UPLOAD_TO_SLATE = ( key, slateId ) => `const url = 'https://slate.host/api/v1/upload-data/${slateId}'; let file = e.target.files[0]; let data = new FormData(); data.append("data", file); const response = await fetch(url, { headers: { // NOTE: your API key Authorization: 'Basic ${key}', }, body: data }); const json = await response.json(); // NOTE: the URL to your asset will be available in the JSON response. console.log(json);`; export default class SceneSettingsDeveloper extends React.Component { state = { loading: false, }; _handleSave = async (e) => { this.setState({ loading: true }); const response = await Actions.generateAPIKey(); if (!response) { dispatchCustomEvent({ name: "create-alert", detail: { alert: { message: "We're having trouble connecting right now. Please try again later", }, }, }); return this.setState({ loading: false }); } if (response.error) { dispatchCustomEvent({ name: "create-alert", detail: { alert: { decorator: response.decorator } }, }); return this.setState({ loading: false }); } await this.props.onRehydrate(); this.setState({ loading: false }); }; _handleDelete = async (id) => { this.setState({ loading: true }); if ( !window.confirm( "Are you sure you want to delete this key? This action is irreversible" ) ) { this.setState({ loading: false }); return; } const response = await Actions.deleteAPIKey({ id }); if (!response) { dispatchCustomEvent({ name: "create-alert", detail: { alert: { message: "We're having trouble connecting right now. Please try again later", }, }, }); return this.setState({ loading: false }); } if (response.error) { dispatchCustomEvent({ name: "create-alert", detail: { alert: { decorator: response.decorator } }, }); return this.setState({ loading: false }); } }; async componentDidMount() { if (!this.props.viewer.keys) { return; } if (!this.props.viewer.keys.length) { return; } const response = await fetch("/api/v1/get-slate", { method: "POST", headers: { "Content-Type": "application/json", Authorization: `Basic ${this.props.viewer.keys[0].key}`, }, }); const json = await response.json(); console.log(json); } render() { let key; if (this.props.viewer.keys) { if (this.props.viewer.keys.length) { key = this.props.viewer.keys[0].key; } } let slateId = "your-slate-uuid-v4-value"; if (this.props.viewer.slates) { if (this.props.viewer.slates.length) { slateId = this.props.viewer.slates[0].id; } } return ( You can use your API key to get slates and add images to slates. You can have a total of 10 keys at any given time.

{this.props.viewer.keys.map((k) => { return ; })}
Generate
{key ? (

) : null}
); } }