芝麻web文件管理V1.00
编辑当前文件:/home/r5772835/public_html/blog.ycreate.jp/wp-content/plugins/codoc/src/block/block.js
/** * BLOCK: codoc-block * * Registering a basic block with Gutenberg. * Simple block, renders and saves the same content without any interactivity. */ // Import CSS. import './style.scss'; import './editor.scss'; import icon from './icon'; //import { ENTER } from '@wordpress/keycodes'; const { ENTER } = wp.keycodes; const { __ } = wp.i18n; // Import __() from wp.i18n const { Component } = wp.element; const { registerBlockType } = wp.blocks; // Import registerBlockType() from wp.blocks const { InspectorControls, RichText } = wp.editor; const { SelectControl, PanelBody, ToggleControl, CheckboxControl, RangeControl, } = wp.components; const { getDefaultBlockName, createBlock, } = wp.blocks; const { withState } = wp.compose; const CODOC_URL = OPTIONS.codoc_url; const CODOC_USER_CODE = OPTIONS.codoc_usercode; const CODOC_PLUGIN_VERSION = OPTIONS.codoc_plugin_version; const CODOC_ENTRIES_CLASS = 'codoc-entries'; const CODOC_ACCOUNT_IS_PRO = OPTIONS.codoc_account_is_pro; //import Cookies from 'universal-cookie'; //const cookies = new Cookies(); class CodocControls extends Component { constructor( props ) { super( ...arguments ); this.subscriptionsFetched = []; this.fetchSubscriptions(); } fetchSubscriptions() { const { setAttributes, attributes: { fetching, } } = this.props; if (fetching) { return } setAttributes( { fetching: true } ) let url = CODOC_URL + '/api/v1/cms/' + CODOC_USER_CODE + '/subscriptions?without_token=1'; fetch(url) .then( res => res.json() ) .then( res => { let list = []; if (res.status && res.subscriptions) { for ( var i = 0; i < res.subscriptions.length; i++ ) { let info = { value: res.subscriptions[i].code, label: res.subscriptions[i].title, } list[i] = info } } if (list.length) { this.subscriptionsFetched = list; } setAttributes( { fetching: false } ) }) } getShowPriceHelp( checked ) { return checked ? __( 'Enable','codoc' ) : __( 'Disable','codoc' ); } getShowSupportHelp( checked ) { return checked ? __( 'Accept' ,'codoc') : __( 'Do not accept' ,'codoc'); } getShowPaywalledSupportHelp( checked ) { return checked ? __( 'The paid part will be hidden upon access, but will be displayed after tapping "Pay to Read". Viewers can freely specify the amount to purchase based on the content. Please note that there may be cases where it is not purchased.' ,'codoc') : __( ' ' ); } getStatusLimitedHelp( checked ) { return checked ? __( 'Unlisted' ,'codoc') : __( 'Published' ,'codoc'); } render() { const { setAttributes, attributes: { showPrice, price, limited, limitedCount, affiliateMode, affiliateRate, showSupport, showPaywalledSupport, statusLimited, subscriptions, } } = this.props; const toggleShowPrice = () => setAttributes( { showPrice: ! showPrice } ); const toggleLimited = () => setAttributes( { limited: ! limited } ); const toggleShowPaywalledSupport = () => setAttributes( { showPaywalledSupport: ! showPaywalledSupport } ); const toggleStatusLimited = () => setAttributes( { statusLimited: ! statusLimited } ); const toggleAffiliateMode = () => setAttributes( { affiliateMode: ! affiliateMode } ); const toggleShowSupport = () => setAttributes( { showSupport: ! showSupport } ); const SubscriptionCheckBoxes = withState({ checked_obj: Object.assign(new Object, subscriptions) })( ( { checked_obj , setState } ) => (
{ this.subscriptionsFetched.map((v) => (
{ check ? checked_obj[v.value] = true : delete checked_obj[v.value] setAttributes({subscriptions : checked_obj}) setState({checked_obj}) } } />
) ) }
) ) const affiliateRateOptions = [ { value: '0.0500', label:'5%' }, { value: '0.1000', label:'10%' }, { value: '0.1500', label:'15%' }, { value: '0.2000', label:'20%' }, { value: '0.2500', label:'25%' }, { value: '0.3000', label:'30%' }, { value: '0.3500', label:'35%' }, { value: '0.4000', label:'40%' }, { value: '0.4500', label:'45%' }, { value: '0.5000', label:'50%' }, ]; return(
{ // do validate this setAttributes({ price: value }); }} min="100" max={ CODOC_ACCOUNT_IS_PRO == 1 ? 100000 : 50000 } />
{ // do validate this setAttributes({ limitedCount: value }); }} initialPosition={ limitedCount } min="0" max="100" />
{ setAttributes( { affiliateRate: value } ); }}/>
{ __('Subscriptions','codoc') }
{ __('Add','codoc') }
); } }; class EditBlockContent extends Component { constructor() { super( ...arguments ); // デフォルト値 this.props.setAttributes({ version: CODOC_PLUGIN_VERSION }); this.props.setAttributes({ showPrice: this.props.attributes.showPrice == null ? true : this.props.attributes.showPrice }); this.props.setAttributes({ price: this.props.attributes.price == null ? 500 : this.props.attributes.price }); this.props.setAttributes({ limited: this.props.attributes.limited == null ? false : this.props.attributes.limited }); this.props.setAttributes({ limitedCount: this.props.attributes.limitedCount == null ? 10 : this.props.attributes.limitedCount }); this.props.setAttributes({ affiliateMode: this.props.attributes.affiliateMode == null ? false : this.props.attributes.affiliateMode }); this.props.setAttributes({ affiliateRate: this.props.attributes.affiliateRate == null ? '0.0500' : this.props.attributes.affiliateRate }); this.props.setAttributes({ showSupport: this.props.attributes.showSupport == null ? false : this.props.attributes.showSupport }); this.props.setAttributes({ showPaywalledSupport: this.props.attributes.showPaywalledSupport == null ? false : this.props.attributes.showPaywalledSupport }); this.props.setAttributes({ statusLimited: this.props.attributes.statusLimited == null ? false : this.props.attributes.statusLimited }); this.props.setAttributes({ subscriptions: this.props.attributes.subscriptions == null ? {} : this.props.attributes.subscriptions }); this.onChangeInput = this.onChangeInput.bind( this ); this.onKeyDown = this.onKeyDown.bind( this ); this.state = { defaultText: __( 'To continue reading, ...','codoc' ), }; } onChangeInput( event ) { this.setState( { defaultText: '', } ); const value = event.target.value.length === 0 ? undefined : event.target.value; this.props.setAttributes( { customText: value } ); } onKeyDown( event ) { const { keyCode } = event; const { insertBlocksAfter } = this.props; if ( keyCode === ENTER ) { insertBlocksAfter( [ createBlock( getDefaultBlockName() ) ] ); } } render() { const { attributes: { customText, }, setAttributes } = this.props; const { defaultText } = this.state; //const value = customText !== undefined ? customText : defaultText; const value = customText ? customText : defaultText; //const value = defaultText; const inputLength = value.length + 10; return[
,
]; } }; registerBlockType( 'codoc/codoc-block', { title: __( 'codoc' ,'codoc'), description: __( 'The area from this block down is a paid area that only authenticated codoc users can view.','codoc' ), icon, category: 'layout', supports: { customClassName: false, className: false, html: false, multiple: false, }, keywords: [ __( 'codoc Block' ,'codoc'), __( 'plugin for codoc' ,'codoc'), __( 'codoc-block' ,'codoc'), ], attributes: { showPrice: { type: 'boolean', default: null, }, price: { type: 'number', default: null, }, limited: { type: 'boolean', default: null, }, limitedCount: { type: 'number', default: null, }, affiliateMode: { type: 'boolean', default: null, }, affiliateRate: { type: 'string', default: null, }, showSupport: { type: 'boolean', default: null, }, showPaywalledSupport: { type: 'boolean', default: null, }, statusLimited: { type: 'boolean', default: null, }, subscriptions: { type: 'object', default: null, }, customText: { type: 'string', default: '', }, version: { type: 'string', default: null, }, }, edit: EditBlockContent, save: function( props ) { const { setAttributes, attributes: { customText, } } = props; return ( // return if link behavior normal
{ customText && !! customText.length && (
)}
) }, } );