//tips
//smart contract
Storageからリンクを取得してdatabaseに新規登録することができた。
更新することもできている。ただ、storagelinkを追っていくと、databaseに2つのドキュメントが追加されている。
何度か実験すると無事に機能していることを確認できた。
これでeditでの画像登録時または更新時にstorageだけでなくデータベースにまでnftimageのパスを格納することができた。
各idのeditページにてimageの登録をして回る。id3,id3は意図的に何も登録せずに様子を見る。
その後に[id]ページのnft表示をstoragelinkからのものに変更。
pile.storagelink = data.storagelink?data.storagelink:null
if(Item.storagelink !=null||Item.storagelink !=undefined){
if(storagelink==undefined||storagelink==null||storagelink==''){
setstoragelink(Item.storagelink)
setstoragelinkdocid(Item.docid)
}
}
const [storagelink, setstoragelink] = useState('')
const [storagelinkdocid, setstoragelinkdocid] = useState('')
画像表示部分を下記に変更。
{storagelink &&
<div>
<img src={storagelink} alt="" width="250" height="250" onClick={handleClickNFTImage}/>
</div>
これによりimageの設定などは必要無くなったのでeditおよび[id]で下記などはコメントアウト。
getDownloadURL(gsReference)
// .then(url => {
// setImage(url)
http://localhost:3000/IDに戻り、storagelinkのurlの中身が表示されているかを確認。
Id3のようにstoragelinkがない場合にはpublicに保存しておいたimageを代わりに表示してあげる。
Nftimageがない人用に"/noimage.jpg”を表示させるようにしたら取得ドキュメントの数が多いため大量のnoimage.jpgが表示されてしまった。各useridに対して一つのみ表示されるなどする必要があるか。
{ninja.map((item,index) => (
<div key={index}>
{item.storagelink ?
<Grid item xs={12} md={6} lg={4} key={index}>
<img src={item.storagelink} alt="" width="100" height="100" onClick={()=>router.push('/ID/'+item.userid)}/>
</Grid>
:
<Grid item xs={12} md={6} lg={4} key={index}>
<img src="/noimage.jpg" alt="" width="100" height="100" onClick={()=>router.push('/ID/'+item.userid)}/>
</Grid>
}
</div>
))}
こちらは実験で実施したため一旦もとに戻す。[id],editページの方にはこの方法で表示してしまって良いかもしれない。
{storagelink ?
<div>
<img src={storagelink} alt="" width="250" height="250" onClick={handleClickNFTImage}/>
</div>
:
<div>
<img src="/noimage.jpg" alt="" width="200" height="250" onClick={handleClickNFTImage}/>
</div>
}
こちらで問題なく対応できた。
http://localhost:3000/IDでのnftimageの並べ方が縦一列になっているのである程度デバイスの大きさを勘案しながら縦横に等間隔に並べていく。